diff --git a/api/.codemodsignore b/api/.codemodsignore deleted file mode 100644 index 52900c05968..00000000000 --- a/api/.codemodsignore +++ /dev/null @@ -1,2 +0,0 @@ -node_modules -codemods/ diff --git a/api/.depcheckrc b/api/.depcheckrc index 95d3bf788af..e584121ca09 100644 --- a/api/.depcheckrc +++ b/api/.depcheckrc @@ -1,12 +1,20 @@ ignores: [ + '@babel/plugin-syntax-import-assertions', 'bookshelf-validate', - 'mocha-junit-reporter', 'eslint-plugin-mocha', 'eslint-plugin-yml', + 'hapi-swagger', + 'hapi-sentry', 'jscodeshift', + 'mocha-junit-reporter', + 'pg-connection-string', 'pino-pretty', ] + +# @babel/plugin-syntax-import-assertions is used by eslint +# see https://github.com/babel/babel/blob/main/packages/babel-plugin-syntax-import-assertions/README.md + # "bookshelf-validate" is used in ./lib/infrastructure/bookshelf.js # code => bookshelf.plugin('bookshelf-validate', # see https://github.com/kripod/bookshelf-validate#configuration @@ -23,6 +31,17 @@ ignores: # code => plugins: - yaml # see https://github.com/ota-meshi/eslint-plugin-yml#book-usage +# "hapi-sentry" is used in ./lib/infrastructure/plugins/sentry.js +# see https://github.com/hydra-newmedia/hapi-sentry + +# "hapi-swagger" is used in ./lib/application/authentication/index.js +# see https://github.com/hapi-swagger/hapi-swagger + +# @babel/plugin-syntax-import-assertions is used by eslint +# see https://github.com/babel/babel/blob/main/packages/babel-plugin-syntax-import-assertions/README.md + # "pino-pretty" is used in ../lib/infrastructure/logger.js # code => target: 'pino-pretty' # see https://github.com/pinojs/pino-pretty#programmatic-integration + +# "pg-connection-string" is used in api/tests/acceptance/database/configuration.cjs diff --git a/api/.eslintignore b/api/.eslintignore index 6e2affd079f..5be701dfcbd 100644 --- a/api/.eslintignore +++ b/api/.eslintignore @@ -1,4 +1,4 @@ # https://eslint.org/docs/user-guide/configuring#eslintignore # .file are implicitly ignored, unless explicitly specified here node_modules/ -codemods/ +nyc.config.js diff --git a/api/.eslintrc.yaml b/api/.eslintrc.yaml index 62ed23c07ba..c3caaaeb990 100644 --- a/api/.eslintrc.yaml +++ b/api/.eslintrc.yaml @@ -4,11 +4,18 @@ extends: - 'plugin:mocha/recommended' - 'plugin:prettier/recommended' - 'plugin:chai-expect/recommended' + - 'plugin:node/recommended-module' + - 'plugin:import/recommended' + parserOptions: ecmaVersion: 2020 requireConfigFile: false + babelOptions: + parserOpts: + plugins: + - importAssertions -parser: "@babel/eslint-parser" +parser: '@babel/eslint-parser' globals: include: true @@ -41,3 +48,16 @@ rules: # Refer to scripts/_template.js for reliable alternatives to process.exit() node/no-process-exit: error unicorn/no-empty-file: error + node/no-unpublished-import: + - error + - allowModules: + - chai + - flush-write-stream + - form-data + - mockdate + - nock + - proxyquire + - sinon + - split2 + - stream-to-promise + - pino-pretty diff --git a/api/codemods/migrate-cjs-to-esm/package-lock.json b/api/codemods/migrate-cjs-to-esm/package-lock.json deleted file mode 100644 index dbe44a940af..00000000000 --- a/api/codemods/migrate-cjs-to-esm/package-lock.json +++ /dev/null @@ -1,8823 +0,0 @@ -{ - "name": "migrate-cjs-to-esm", - "lockfileVersion": 2, - "requires": true, - "packages": { - "": { - "name": "migrate-cjs-to-esm", - "dependencies": { - "jscodeshift": "^0.14.0" - }, - "devDependencies": { - "@types/jscodeshift": "^0.11.6", - "jest": "^29.4.3" - } - }, - "node_modules/@ampproject/remapping": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz", - "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==", - "dependencies": { - "@jridgewell/gen-mapping": "^0.1.0", - "@jridgewell/trace-mapping": "^0.3.9" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@babel/code-frame": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", - "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", - "dependencies": { - "@babel/highlight": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/compat-data": { - "version": "7.20.14", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.20.14.tgz", - "integrity": "sha512-0YpKHD6ImkWMEINCyDAD0HLLUH/lPCefG8ld9it8DJB2wnApraKuhgYTvTY1z7UFIfBTGy5LwncZ+5HWWGbhFw==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/core": { - "version": "7.20.12", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.20.12.tgz", - "integrity": "sha512-XsMfHovsUYHFMdrIHkZphTN/2Hzzi78R08NuHfDBehym2VsPDL6Zn/JAD/JQdnRvbSsbQc4mVaU1m6JgtTEElg==", - "dependencies": { - "@ampproject/remapping": "^2.1.0", - "@babel/code-frame": "^7.18.6", - "@babel/generator": "^7.20.7", - "@babel/helper-compilation-targets": "^7.20.7", - "@babel/helper-module-transforms": "^7.20.11", - "@babel/helpers": "^7.20.7", - "@babel/parser": "^7.20.7", - "@babel/template": "^7.20.7", - "@babel/traverse": "^7.20.12", - "@babel/types": "^7.20.7", - "convert-source-map": "^1.7.0", - "debug": "^4.1.0", - "gensync": "^1.0.0-beta.2", - "json5": "^2.2.2", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/babel" - } - }, - "node_modules/@babel/core/node_modules/convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==" - }, - "node_modules/@babel/generator": { - "version": "7.21.1", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.21.1.tgz", - "integrity": "sha512-1lT45bAYlQhFn/BHivJs43AiW2rg3/UbLyShGfF3C0KmHvO5fSghWd5kBJy30kpRRucGzXStvnnCFniCR2kXAA==", - "dependencies": { - "@babel/types": "^7.21.0", - "@jridgewell/gen-mapping": "^0.3.2", - "@jridgewell/trace-mapping": "^0.3.17", - "jsesc": "^2.5.1" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/generator/node_modules/@jridgewell/gen-mapping": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", - "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", - "dependencies": { - "@jridgewell/set-array": "^1.0.1", - "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@babel/helper-annotate-as-pure": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz", - "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==", - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz", - "integrity": "sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw==", - "peer": true, - "dependencies": { - "@babel/helper-explode-assignable-expression": "^7.18.6", - "@babel/types": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-compilation-targets": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.7.tgz", - "integrity": "sha512-4tGORmfQcrc+bvrjb5y3dG9Mx1IOZjsHqQVUz7XCNHO+iTmqxWnVg3KRygjGmpRLJGdQSKuvFinbIb0CnZwHAQ==", - "dependencies": { - "@babel/compat-data": "^7.20.5", - "@babel/helper-validator-option": "^7.18.6", - "browserslist": "^4.21.3", - "lru-cache": "^5.1.1", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-create-class-features-plugin": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.21.0.tgz", - "integrity": "sha512-Q8wNiMIdwsv5la5SPxNYzzkPnjgC0Sy0i7jLkVOCdllu/xcVNkr3TeZzbHBJrj+XXRqzX5uCyCoV9eu6xUG7KQ==", - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.21.0", - "@babel/helper-member-expression-to-functions": "^7.21.0", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/helper-replace-supers": "^7.20.7", - "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0", - "@babel/helper-split-export-declaration": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-create-regexp-features-plugin": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.21.0.tgz", - "integrity": "sha512-N+LaFW/auRSWdx7SHD/HiARwXQju1vXTW4fKr4u5SgBUTm51OKEjKgj+cs00ggW3kEvNqwErnlwuq7Y3xBe4eg==", - "peer": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "regexpu-core": "^5.3.1" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-define-polyfill-provider": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.3.tgz", - "integrity": "sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww==", - "peer": true, - "dependencies": { - "@babel/helper-compilation-targets": "^7.17.7", - "@babel/helper-plugin-utils": "^7.16.7", - "debug": "^4.1.1", - "lodash.debounce": "^4.0.8", - "resolve": "^1.14.2", - "semver": "^6.1.2" - }, - "peerDependencies": { - "@babel/core": "^7.4.0-0" - } - }, - "node_modules/@babel/helper-environment-visitor": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz", - "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-explode-assignable-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz", - "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==", - "peer": true, - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-function-name": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.21.0.tgz", - "integrity": "sha512-HfK1aMRanKHpxemaY2gqBmL04iAPOPRj7DxtNbiDOrJK+gdwkiNRVpCpUJYbUT+aZyemKN8brqTOxzCaG6ExRg==", - "dependencies": { - "@babel/template": "^7.20.7", - "@babel/types": "^7.21.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-hoist-variables": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", - "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-member-expression-to-functions": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.21.0.tgz", - "integrity": "sha512-Muu8cdZwNN6mRRNG6lAYErJ5X3bRevgYR2O8wN0yn7jJSnGDu6eG59RfT29JHxGUovyfrh6Pj0XzmR7drNVL3Q==", - "dependencies": { - "@babel/types": "^7.21.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-module-imports": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz", - "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==", - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-module-transforms": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.21.2.tgz", - "integrity": "sha512-79yj2AR4U/Oqq/WOV7Lx6hUjau1Zfo4cI+JLAVYeMV5XIlbOhmjEk5ulbTc9fMpmlojzZHkUUxAiK+UKn+hNQQ==", - "dependencies": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-module-imports": "^7.18.6", - "@babel/helper-simple-access": "^7.20.2", - "@babel/helper-split-export-declaration": "^7.18.6", - "@babel/helper-validator-identifier": "^7.19.1", - "@babel/template": "^7.20.7", - "@babel/traverse": "^7.21.2", - "@babel/types": "^7.21.2" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-optimise-call-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz", - "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==", - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-plugin-utils": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.20.2.tgz", - "integrity": "sha512-8RvlJG2mj4huQ4pZ+rU9lqKi9ZKiRmuvGuM2HlWmkmgOhbs6zEAw6IEiJ5cQqGbDzGZOhwuOQNtZMi/ENLjZoQ==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-remap-async-to-generator": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz", - "integrity": "sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==", - "peer": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-wrap-function": "^7.18.9", - "@babel/types": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-replace-supers": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.20.7.tgz", - "integrity": "sha512-vujDMtB6LVfNW13jhlCrp48QNslK6JXi7lQG736HVbHz/mbf4Dc7tIRh1Xf5C0rF7BP8iiSxGMCmY6Ci1ven3A==", - "dependencies": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-member-expression-to-functions": "^7.20.7", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/template": "^7.20.7", - "@babel/traverse": "^7.20.7", - "@babel/types": "^7.20.7" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-simple-access": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz", - "integrity": "sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==", - "dependencies": { - "@babel/types": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-skip-transparent-expression-wrappers": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz", - "integrity": "sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==", - "dependencies": { - "@babel/types": "^7.20.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-split-export-declaration": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", - "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-string-parser": { - "version": "7.19.4", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.19.4.tgz", - "integrity": "sha512-nHtDoQcuqFmwYNYPz3Rah5ph2p8PFeFCsZk9A/48dPc/rGocJ5J3hAAZ7pb76VWX3fZKu+uEr/FhH5jLx7umrw==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-validator-identifier": { - "version": "7.19.1", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", - "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-validator-option": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.21.0.tgz", - "integrity": "sha512-rmL/B8/f0mKS2baE9ZpyTcTavvEuWhTTW8amjzXNvYG4AwBsqTLikfXsEofsJEfKHf+HQVQbFOHy6o+4cnC/fQ==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-wrap-function": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.20.5.tgz", - "integrity": "sha512-bYMxIWK5mh+TgXGVqAtnu5Yn1un+v8DDZtqyzKRLUzrh70Eal2O3aZ7aPYiMADO4uKlkzOiRiZ6GX5q3qxvW9Q==", - "peer": true, - "dependencies": { - "@babel/helper-function-name": "^7.19.0", - "@babel/template": "^7.18.10", - "@babel/traverse": "^7.20.5", - "@babel/types": "^7.20.5" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helpers": { - "version": "7.20.13", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.20.13.tgz", - "integrity": "sha512-nzJ0DWCL3gB5RCXbUO3KIMMsBY2Eqbx8mBpKGE/02PgyRQFcPQLbkQ1vyy596mZLaP+dAfD+R4ckASzNVmW3jg==", - "dependencies": { - "@babel/template": "^7.20.7", - "@babel/traverse": "^7.20.13", - "@babel/types": "^7.20.7" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/highlight": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", - "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", - "dependencies": { - "@babel/helper-validator-identifier": "^7.18.6", - "chalk": "^2.0.0", - "js-tokens": "^4.0.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/highlight/node_modules/ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dependencies": { - "color-convert": "^1.9.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/highlight/node_modules/chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dependencies": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/highlight/node_modules/color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "dependencies": { - "color-name": "1.1.3" - } - }, - "node_modules/@babel/highlight/node_modules/color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==" - }, - "node_modules/@babel/highlight/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/@babel/highlight/node_modules/has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/highlight/node_modules/supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dependencies": { - "has-flag": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/parser": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.21.2.tgz", - "integrity": "sha512-URpaIJQwEkEC2T9Kn+Ai6Xe/02iNaVCuT/PtoRz3GPVJVDpPd7mLo+VddTbhCRU9TXqW5mSrQfXZyi8kDKOVpQ==", - "bin": { - "parser": "bin/babel-parser.js" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz", - "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.20.7.tgz", - "integrity": "sha512-sbr9+wNE5aXMBBFBICk01tt7sBf2Oc9ikRFEcem/ZORup9IMUdNhW7/wVLEbbtlWOsEubJet46mHAL2C8+2jKQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0", - "@babel/plugin-proposal-optional-chaining": "^7.20.7" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.13.0" - } - }, - "node_modules/@babel/plugin-proposal-async-generator-functions": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.20.7.tgz", - "integrity": "sha512-xMbiLsn/8RK7Wq7VeVytytS2L6qE69bXPB10YCmMdDZbKF4okCqY74pI/jJQ/8U0b/F6NrT2+14b8/P9/3AMGA==", - "peer": true, - "dependencies": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-remap-async-to-generator": "^7.18.9", - "@babel/plugin-syntax-async-generators": "^7.8.4" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-class-properties": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz", - "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==", - "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-class-static-block": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.21.0.tgz", - "integrity": "sha512-XP5G9MWNUskFuP30IfFSEFB0Z6HzLIUcjYM4bYOPHXl7eiJ9HFv8tWj6TXTN5QODiEhDZAeI4hLok2iHFFV4hw==", - "peer": true, - "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.21.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-class-static-block": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.12.0" - } - }, - "node_modules/@babel/plugin-proposal-dynamic-import": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz", - "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-dynamic-import": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-export-namespace-from": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz", - "integrity": "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9", - "@babel/plugin-syntax-export-namespace-from": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-json-strings": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz", - "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-json-strings": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-logical-assignment-operators": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.20.7.tgz", - "integrity": "sha512-y7C7cZgpMIjWlKE5T7eJwp+tnRYM89HmRvWM5EQuB5BoHEONjmQ8lSNmBUwOyy/GFRsohJED51YBF79hE1djug==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-nullish-coalescing-operator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz", - "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-numeric-separator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz", - "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-numeric-separator": "^7.10.4" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-object-rest-spread": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.20.7.tgz", - "integrity": "sha512-d2S98yCiLxDVmBmE8UjGcfPvNEUbA1U5q5WxaWFUGRzJSVAZqm5W6MbPct0jxnegUZ0niLeNX+IOzEs7wYg9Dg==", - "peer": true, - "dependencies": { - "@babel/compat-data": "^7.20.5", - "@babel/helper-compilation-targets": "^7.20.7", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-transform-parameters": "^7.20.7" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-optional-catch-binding": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz", - "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-optional-chaining": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.21.0.tgz", - "integrity": "sha512-p4zeefM72gpmEe2fkUr/OnOXpWEf8nAgk7ZYVqqfFiyIG7oFfVZcCrU64hWn5xp4tQ9LkV4bTIa5rD0KANpKNA==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0", - "@babel/plugin-syntax-optional-chaining": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-private-methods": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz", - "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==", - "peer": true, - "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-private-property-in-object": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.21.0.tgz", - "integrity": "sha512-ha4zfehbJjc5MmXBlHec1igel5TJXXLDDRbuJ4+XT2TJcyD9/V1919BA8gMvsdHcNMBy4WBUBiRb3nw/EQUtBw==", - "peer": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-create-class-features-plugin": "^7.21.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-private-property-in-object": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-unicode-property-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz", - "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==", - "peer": true, - "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=4" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-async-generators": { - "version": "7.8.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", - "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-bigint": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", - "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-class-properties": { - "version": "7.12.13", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", - "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.12.13" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-class-static-block": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", - "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-dynamic-import": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", - "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-export-namespace-from": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", - "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.3" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-flow": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.18.6.tgz", - "integrity": "sha512-LUbR+KNTBWCUAqRG9ex5Gnzu2IOkt8jRJbHHXFT9q+L9zm7M/QQbEqXyw1n1pohYvOyWC8CjeyjrSaIwiYjK7A==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-import-assertions": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz", - "integrity": "sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.19.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-import-meta": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", - "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.10.4" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-json-strings": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", - "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-jsx": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz", - "integrity": "sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-logical-assignment-operators": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", - "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.10.4" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", - "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-numeric-separator": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", - "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.10.4" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-object-rest-spread": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", - "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-optional-catch-binding": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", - "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-optional-chaining": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", - "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-private-property-in-object": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", - "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-top-level-await": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", - "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-typescript": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.20.0.tgz", - "integrity": "sha512-rd9TkG+u1CExzS4SM1BlMEhMXwFLKVjOAFFCDx9PbX5ycJWDoWMcwdJH9RhkPu1dOgn5TrxLot/Gx6lWFuAUNQ==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.19.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-arrow-functions": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.20.7.tgz", - "integrity": "sha512-3poA5E7dzDomxj9WXWwuD6A5F3kc7VXwIJO+E+J8qtDtS+pXPAhrgEyh+9GBwBgPq1Z+bB+/JD60lp5jsN7JPQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-async-to-generator": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.20.7.tgz", - "integrity": "sha512-Uo5gwHPT9vgnSXQxqGtpdufUiWp96gk7yiP4Mp5bm1QMkEmLXBO7PAGYbKoJ6DhAwiNkcHFBol/x5zZZkL/t0Q==", - "peer": true, - "dependencies": { - "@babel/helper-module-imports": "^7.18.6", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-remap-async-to-generator": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-block-scoped-functions": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz", - "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-block-scoping": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.21.0.tgz", - "integrity": "sha512-Mdrbunoh9SxwFZapeHVrwFmri16+oYotcZysSzhNIVDwIAb1UV+kvnxULSYq9J3/q5MDG+4X6w8QVgD1zhBXNQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-classes": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.21.0.tgz", - "integrity": "sha512-RZhbYTCEUAe6ntPehC4hlslPWosNHDox+vAs4On/mCLRLfoDVHf6hVEd7kuxr1RnHwJmxFfUM3cZiZRmPxJPXQ==", - "peer": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-compilation-targets": "^7.20.7", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.21.0", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-replace-supers": "^7.20.7", - "@babel/helper-split-export-declaration": "^7.18.6", - "globals": "^11.1.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-computed-properties": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.20.7.tgz", - "integrity": "sha512-Lz7MvBK6DTjElHAmfu6bfANzKcxpyNPeYBGEafyA6E5HtRpjpZwU+u7Qrgz/2OR0z+5TvKYbPdphfSaAcZBrYQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/template": "^7.20.7" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-destructuring": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.20.7.tgz", - "integrity": "sha512-Xwg403sRrZb81IVB79ZPqNQME23yhugYVqgTxAhT99h485F4f+GMELFhhOsscDUB7HCswepKeCKLn/GZvUKoBA==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-dotall-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz", - "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==", - "peer": true, - "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-duplicate-keys": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz", - "integrity": "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-exponentiation-operator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz", - "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==", - "peer": true, - "dependencies": { - "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-flow-strip-types": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.21.0.tgz", - "integrity": "sha512-FlFA2Mj87a6sDkW4gfGrQQqwY/dLlBAyJa2dJEZ+FHXUVHBflO2wyKvg+OOEzXfrKYIa4HWl0mgmbCzt0cMb7w==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-flow": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-for-of": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.21.0.tgz", - "integrity": "sha512-LlUYlydgDkKpIY7mcBWvyPPmMcOphEyYA27Ef4xpbh1IiDNLr0kZsos2nf92vz3IccvJI25QUwp86Eo5s6HmBQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-function-name": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz", - "integrity": "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==", - "peer": true, - "dependencies": { - "@babel/helper-compilation-targets": "^7.18.9", - "@babel/helper-function-name": "^7.18.9", - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-literals": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz", - "integrity": "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-member-expression-literals": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz", - "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-modules-amd": { - "version": "7.20.11", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.20.11.tgz", - "integrity": "sha512-NuzCt5IIYOW0O30UvqktzHYR2ud5bOWbY0yaxWZ6G+aFzOMJvrs5YHNikrbdaT15+KNO31nPOy5Fim3ku6Zb5g==", - "peer": true, - "dependencies": { - "@babel/helper-module-transforms": "^7.20.11", - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-modules-commonjs": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.21.2.tgz", - "integrity": "sha512-Cln+Yy04Gxua7iPdj6nOV96smLGjpElir5YwzF0LBPKoPlLDNJePNlrGGaybAJkd0zKRnOVXOgizSqPYMNYkzA==", - "dependencies": { - "@babel/helper-module-transforms": "^7.21.2", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-simple-access": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-modules-systemjs": { - "version": "7.20.11", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.20.11.tgz", - "integrity": "sha512-vVu5g9BPQKSFEmvt2TA4Da5N+QVS66EX21d8uoOihC+OCpUoGvzVsXeqFdtAEfVa5BILAeFt+U7yVmLbQnAJmw==", - "peer": true, - "dependencies": { - "@babel/helper-hoist-variables": "^7.18.6", - "@babel/helper-module-transforms": "^7.20.11", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-validator-identifier": "^7.19.1" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-modules-umd": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz", - "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==", - "peer": true, - "dependencies": { - "@babel/helper-module-transforms": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-named-capturing-groups-regex": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.20.5.tgz", - "integrity": "sha512-mOW4tTzi5iTLnw+78iEq3gr8Aoq4WNRGpmSlrogqaiCBoR1HFhpU4JkpQFOHfeYx3ReVIFWOQJS4aZBRvuZ6mA==", - "peer": true, - "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.20.5", - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/plugin-transform-new-target": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz", - "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-object-super": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz", - "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/helper-replace-supers": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-parameters": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.20.7.tgz", - "integrity": "sha512-WiWBIkeHKVOSYPO0pWkxGPfKeWrCJyD3NJ53+Lrp/QMSZbsVPovrVl2aWZ19D/LTVnaDv5Ap7GJ/B2CTOZdrfA==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-property-literals": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz", - "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-regenerator": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.20.5.tgz", - "integrity": "sha512-kW/oO7HPBtntbsahzQ0qSE3tFvkFwnbozz3NWFhLGqH75vLEg+sCGngLlhVkePlCs3Jv0dBBHDzCHxNiFAQKCQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "regenerator-transform": "^0.15.1" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-reserved-words": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz", - "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-shorthand-properties": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz", - "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-spread": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.20.7.tgz", - "integrity": "sha512-ewBbHQ+1U/VnH1fxltbJqDeWBU1oNLG8Dj11uIv3xVf7nrQu0bPGe5Rf716r7K5Qz+SqtAOVswoVunoiBtGhxw==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-sticky-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz", - "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-template-literals": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz", - "integrity": "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-typeof-symbol": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz", - "integrity": "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-typescript": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.21.0.tgz", - "integrity": "sha512-xo///XTPp3mDzTtrqXoBlK9eiAYW3wv9JXglcn/u1bi60RW11dEUxIgA8cbnDhutS1zacjMRmAwxE0gMklLnZg==", - "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.21.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-typescript": "^7.20.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-unicode-escapes": { - "version": "7.18.10", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.10.tgz", - "integrity": "sha512-kKAdAI+YzPgGY/ftStBFXTI1LZFju38rYThnfMykS+IXy8BVx+res7s2fxf1l8I35DV2T97ezo6+SGrXz6B3iQ==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-unicode-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz", - "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==", - "peer": true, - "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/preset-env": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.20.2.tgz", - "integrity": "sha512-1G0efQEWR1EHkKvKHqbG+IN/QdgwfByUpM5V5QroDzGV2t3S/WXNQd693cHiHTlCFMpr9B6FkPFXDA2lQcKoDg==", - "peer": true, - "dependencies": { - "@babel/compat-data": "^7.20.1", - "@babel/helper-compilation-targets": "^7.20.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-validator-option": "^7.18.6", - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6", - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.9", - "@babel/plugin-proposal-async-generator-functions": "^7.20.1", - "@babel/plugin-proposal-class-properties": "^7.18.6", - "@babel/plugin-proposal-class-static-block": "^7.18.6", - "@babel/plugin-proposal-dynamic-import": "^7.18.6", - "@babel/plugin-proposal-export-namespace-from": "^7.18.9", - "@babel/plugin-proposal-json-strings": "^7.18.6", - "@babel/plugin-proposal-logical-assignment-operators": "^7.18.9", - "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6", - "@babel/plugin-proposal-numeric-separator": "^7.18.6", - "@babel/plugin-proposal-object-rest-spread": "^7.20.2", - "@babel/plugin-proposal-optional-catch-binding": "^7.18.6", - "@babel/plugin-proposal-optional-chaining": "^7.18.9", - "@babel/plugin-proposal-private-methods": "^7.18.6", - "@babel/plugin-proposal-private-property-in-object": "^7.18.6", - "@babel/plugin-proposal-unicode-property-regex": "^7.18.6", - "@babel/plugin-syntax-async-generators": "^7.8.4", - "@babel/plugin-syntax-class-properties": "^7.12.13", - "@babel/plugin-syntax-class-static-block": "^7.14.5", - "@babel/plugin-syntax-dynamic-import": "^7.8.3", - "@babel/plugin-syntax-export-namespace-from": "^7.8.3", - "@babel/plugin-syntax-import-assertions": "^7.20.0", - "@babel/plugin-syntax-json-strings": "^7.8.3", - "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", - "@babel/plugin-syntax-numeric-separator": "^7.10.4", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", - "@babel/plugin-syntax-optional-chaining": "^7.8.3", - "@babel/plugin-syntax-private-property-in-object": "^7.14.5", - "@babel/plugin-syntax-top-level-await": "^7.14.5", - "@babel/plugin-transform-arrow-functions": "^7.18.6", - "@babel/plugin-transform-async-to-generator": "^7.18.6", - "@babel/plugin-transform-block-scoped-functions": "^7.18.6", - "@babel/plugin-transform-block-scoping": "^7.20.2", - "@babel/plugin-transform-classes": "^7.20.2", - "@babel/plugin-transform-computed-properties": "^7.18.9", - "@babel/plugin-transform-destructuring": "^7.20.2", - "@babel/plugin-transform-dotall-regex": "^7.18.6", - "@babel/plugin-transform-duplicate-keys": "^7.18.9", - "@babel/plugin-transform-exponentiation-operator": "^7.18.6", - "@babel/plugin-transform-for-of": "^7.18.8", - "@babel/plugin-transform-function-name": "^7.18.9", - "@babel/plugin-transform-literals": "^7.18.9", - "@babel/plugin-transform-member-expression-literals": "^7.18.6", - "@babel/plugin-transform-modules-amd": "^7.19.6", - "@babel/plugin-transform-modules-commonjs": "^7.19.6", - "@babel/plugin-transform-modules-systemjs": "^7.19.6", - "@babel/plugin-transform-modules-umd": "^7.18.6", - "@babel/plugin-transform-named-capturing-groups-regex": "^7.19.1", - "@babel/plugin-transform-new-target": "^7.18.6", - "@babel/plugin-transform-object-super": "^7.18.6", - "@babel/plugin-transform-parameters": "^7.20.1", - "@babel/plugin-transform-property-literals": "^7.18.6", - "@babel/plugin-transform-regenerator": "^7.18.6", - "@babel/plugin-transform-reserved-words": "^7.18.6", - "@babel/plugin-transform-shorthand-properties": "^7.18.6", - "@babel/plugin-transform-spread": "^7.19.0", - "@babel/plugin-transform-sticky-regex": "^7.18.6", - "@babel/plugin-transform-template-literals": "^7.18.9", - "@babel/plugin-transform-typeof-symbol": "^7.18.9", - "@babel/plugin-transform-unicode-escapes": "^7.18.10", - "@babel/plugin-transform-unicode-regex": "^7.18.6", - "@babel/preset-modules": "^0.1.5", - "@babel/types": "^7.20.2", - "babel-plugin-polyfill-corejs2": "^0.3.3", - "babel-plugin-polyfill-corejs3": "^0.6.0", - "babel-plugin-polyfill-regenerator": "^0.4.1", - "core-js-compat": "^3.25.1", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/preset-flow": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/preset-flow/-/preset-flow-7.18.6.tgz", - "integrity": "sha512-E7BDhL64W6OUqpuyHnSroLnqyRTcG6ZdOBl1OKI/QK/HJfplqK/S3sq1Cckx7oTodJ5yOXyfw7rEADJ6UjoQDQ==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/helper-validator-option": "^7.18.6", - "@babel/plugin-transform-flow-strip-types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/preset-modules": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz", - "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==", - "peer": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", - "@babel/plugin-transform-dotall-regex": "^7.4.4", - "@babel/types": "^7.4.4", - "esutils": "^2.0.2" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/preset-typescript": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.21.0.tgz", - "integrity": "sha512-myc9mpoVA5m1rF8K8DgLEatOYFDpwC+RkMkjZ0Du6uI62YvDe8uxIEYVs/VCdSJ097nlALiU/yBC7//3nI+hNg==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-validator-option": "^7.21.0", - "@babel/plugin-transform-typescript": "^7.21.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/register": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/register/-/register-7.21.0.tgz", - "integrity": "sha512-9nKsPmYDi5DidAqJaQooxIhsLJiNMkGr8ypQ8Uic7cIox7UCDsM7HuUGxdGT7mSDTYbqzIdsOWzfBton/YJrMw==", - "dependencies": { - "clone-deep": "^4.0.1", - "find-cache-dir": "^2.0.0", - "make-dir": "^2.1.0", - "pirates": "^4.0.5", - "source-map-support": "^0.5.16" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/register/node_modules/make-dir": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", - "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", - "dependencies": { - "pify": "^4.0.1", - "semver": "^5.6.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@babel/register/node_modules/semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", - "bin": { - "semver": "bin/semver" - } - }, - "node_modules/@babel/register/node_modules/source-map-support": { - "version": "0.5.21", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", - "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", - "dependencies": { - "buffer-from": "^1.0.0", - "source-map": "^0.6.0" - } - }, - "node_modules/@babel/regjsgen": { - "version": "0.8.0", - "resolved": "https://registry.npmjs.org/@babel/regjsgen/-/regjsgen-0.8.0.tgz", - "integrity": "sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA==", - "peer": true - }, - "node_modules/@babel/runtime": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.21.0.tgz", - "integrity": "sha512-xwII0//EObnq89Ji5AKYQaRYiW/nZ3llSv29d49IuxPhKbtJoLP+9QUUZ4nVragQVtaVGeZrpB+ZtG/Pdy/POw==", - "peer": true, - "dependencies": { - "regenerator-runtime": "^0.13.11" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/template": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.20.7.tgz", - "integrity": "sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==", - "dependencies": { - "@babel/code-frame": "^7.18.6", - "@babel/parser": "^7.20.7", - "@babel/types": "^7.20.7" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/traverse": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.21.2.tgz", - "integrity": "sha512-ts5FFU/dSUPS13tv8XiEObDu9K+iagEKME9kAbaP7r0Y9KtZJZ+NGndDvWoRAYNpeWafbpFeki3q9QoMD6gxyw==", - "dependencies": { - "@babel/code-frame": "^7.18.6", - "@babel/generator": "^7.21.1", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.21.0", - "@babel/helper-hoist-variables": "^7.18.6", - "@babel/helper-split-export-declaration": "^7.18.6", - "@babel/parser": "^7.21.2", - "@babel/types": "^7.21.2", - "debug": "^4.1.0", - "globals": "^11.1.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/types": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.21.2.tgz", - "integrity": "sha512-3wRZSs7jiFaB8AjxiiD+VqN5DTG2iRvJGQ+qYFrs/654lg6kGTQWIOFjlBo5RaXuAZjBmP3+OQH4dmhqiiyYxw==", - "dependencies": { - "@babel/helper-string-parser": "^7.19.4", - "@babel/helper-validator-identifier": "^7.19.1", - "to-fast-properties": "^2.0.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@bcoe/v8-coverage": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", - "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", - "dev": true - }, - "node_modules/@istanbuljs/load-nyc-config": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", - "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", - "dev": true, - "dependencies": { - "camelcase": "^5.3.1", - "find-up": "^4.1.0", - "get-package-type": "^0.1.0", - "js-yaml": "^3.13.1", - "resolve-from": "^5.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@istanbuljs/schema": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", - "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/console": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.4.3.tgz", - "integrity": "sha512-W/o/34+wQuXlgqlPYTansOSiBnuxrTv61dEVkA6HNmpcgHLUjfaUbdqt6oVvOzaawwo9IdW9QOtMgQ1ScSZC4A==", - "dev": true, - "dependencies": { - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "jest-message-util": "^29.4.3", - "jest-util": "^29.4.3", - "slash": "^3.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/core": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.4.3.tgz", - "integrity": "sha512-56QvBq60fS4SPZCuM7T+7scNrkGIe7Mr6PVIXUpu48ouvRaWOFqRPV91eifvFM0ay2HmfswXiGf97NGUN5KofQ==", - "dev": true, - "dependencies": { - "@jest/console": "^29.4.3", - "@jest/reporters": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "jest-changed-files": "^29.4.3", - "jest-config": "^29.4.3", - "jest-haste-map": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-regex-util": "^29.4.3", - "jest-resolve": "^29.4.3", - "jest-resolve-dependencies": "^29.4.3", - "jest-runner": "^29.4.3", - "jest-runtime": "^29.4.3", - "jest-snapshot": "^29.4.3", - "jest-util": "^29.4.3", - "jest-validate": "^29.4.3", - "jest-watcher": "^29.4.3", - "micromatch": "^4.0.4", - "pretty-format": "^29.4.3", - "slash": "^3.0.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "peerDependencies": { - "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" - }, - "peerDependenciesMeta": { - "node-notifier": { - "optional": true - } - } - }, - "node_modules/@jest/environment": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.4.3.tgz", - "integrity": "sha512-dq5S6408IxIa+lr54zeqce+QgI+CJT4nmmA+1yzFgtcsGK8c/EyiUb9XQOgz3BMKrRDfKseeOaxj2eO8LlD3lA==", - "dev": true, - "dependencies": { - "@jest/fake-timers": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "jest-mock": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/expect": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.4.3.tgz", - "integrity": "sha512-iktRU/YsxEtumI9zsPctYUk7ptpC+AVLLk1Ax3AsA4g1C+8OOnKDkIQBDHtD5hA/+VtgMd5AWI5gNlcAlt2vxQ==", - "dev": true, - "dependencies": { - "expect": "^29.4.3", - "jest-snapshot": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/expect-utils": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.4.3.tgz", - "integrity": "sha512-/6JWbkxHOP8EoS8jeeTd9dTfc9Uawi+43oLKHfp6zzux3U2hqOOVnV3ai4RpDYHOccL6g+5nrxpoc8DmJxtXVQ==", - "dev": true, - "dependencies": { - "jest-get-type": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/fake-timers": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.4.3.tgz", - "integrity": "sha512-4Hote2MGcCTWSD2gwl0dwbCpBRHhE6olYEuTj8FMowdg3oQWNKr2YuxenPQYZ7+PfqPY1k98wKDU4Z+Hvd4Tiw==", - "dev": true, - "dependencies": { - "@jest/types": "^29.4.3", - "@sinonjs/fake-timers": "^10.0.2", - "@types/node": "*", - "jest-message-util": "^29.4.3", - "jest-mock": "^29.4.3", - "jest-util": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/globals": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.4.3.tgz", - "integrity": "sha512-8BQ/5EzfOLG7AaMcDh7yFCbfRLtsc+09E1RQmRBI4D6QQk4m6NSK/MXo+3bJrBN0yU8A2/VIcqhvsOLFmziioA==", - "dev": true, - "dependencies": { - "@jest/environment": "^29.4.3", - "@jest/expect": "^29.4.3", - "@jest/types": "^29.4.3", - "jest-mock": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/reporters": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.4.3.tgz", - "integrity": "sha512-sr2I7BmOjJhyqj9ANC6CTLsL4emMoka7HkQpcoMRlhCbQJjz2zsRzw0BDPiPyEFDXAbxKgGFYuQZiSJ1Y6YoTg==", - "dev": true, - "dependencies": { - "@bcoe/v8-coverage": "^0.2.3", - "@jest/console": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@jridgewell/trace-mapping": "^0.3.15", - "@types/node": "*", - "chalk": "^4.0.0", - "collect-v8-coverage": "^1.0.0", - "exit": "^0.1.2", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "istanbul-lib-coverage": "^3.0.0", - "istanbul-lib-instrument": "^5.1.0", - "istanbul-lib-report": "^3.0.0", - "istanbul-lib-source-maps": "^4.0.0", - "istanbul-reports": "^3.1.3", - "jest-message-util": "^29.4.3", - "jest-util": "^29.4.3", - "jest-worker": "^29.4.3", - "slash": "^3.0.0", - "string-length": "^4.0.1", - "strip-ansi": "^6.0.0", - "v8-to-istanbul": "^9.0.1" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "peerDependencies": { - "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" - }, - "peerDependenciesMeta": { - "node-notifier": { - "optional": true - } - } - }, - "node_modules/@jest/schemas": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.4.3.tgz", - "integrity": "sha512-VLYKXQmtmuEz6IxJsrZwzG9NvtkQsWNnWMsKxqWNu3+CnfzJQhp0WDDKWLVV9hLKr0l3SLLFRqcYHjhtyuDVxg==", - "dev": true, - "dependencies": { - "@sinclair/typebox": "^0.25.16" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/source-map": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.4.3.tgz", - "integrity": "sha512-qyt/mb6rLyd9j1jUts4EQncvS6Yy3PM9HghnNv86QBlV+zdL2inCdK1tuVlL+J+lpiw2BI67qXOrX3UurBqQ1w==", - "dev": true, - "dependencies": { - "@jridgewell/trace-mapping": "^0.3.15", - "callsites": "^3.0.0", - "graceful-fs": "^4.2.9" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/test-result": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.4.3.tgz", - "integrity": "sha512-Oi4u9NfBolMq9MASPwuWTlC5WvmNRwI4S8YrQg5R5Gi47DYlBe3sh7ILTqi/LGrK1XUE4XY9KZcQJTH1WJCLLA==", - "dev": true, - "dependencies": { - "@jest/console": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/istanbul-lib-coverage": "^2.0.0", - "collect-v8-coverage": "^1.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/test-sequencer": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.4.3.tgz", - "integrity": "sha512-yi/t2nES4GB4G0mjLc0RInCq/cNr9dNwJxcGg8sslajua5Kb4kmozAc+qPLzplhBgfw1vLItbjyHzUN92UXicw==", - "dev": true, - "dependencies": { - "@jest/test-result": "^29.4.3", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.4.3", - "slash": "^3.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/transform": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.4.3.tgz", - "integrity": "sha512-8u0+fBGWolDshsFgPQJESkDa72da/EVwvL+II0trN2DR66wMwiQ9/CihaGfHdlLGFzbBZwMykFtxuwFdZqlKwg==", - "dev": true, - "dependencies": { - "@babel/core": "^7.11.6", - "@jest/types": "^29.4.3", - "@jridgewell/trace-mapping": "^0.3.15", - "babel-plugin-istanbul": "^6.1.1", - "chalk": "^4.0.0", - "convert-source-map": "^2.0.0", - "fast-json-stable-stringify": "^2.1.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.4.3", - "jest-regex-util": "^29.4.3", - "jest-util": "^29.4.3", - "micromatch": "^4.0.4", - "pirates": "^4.0.4", - "slash": "^3.0.0", - "write-file-atomic": "^4.0.2" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/types": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.4.3.tgz", - "integrity": "sha512-bPYfw8V65v17m2Od1cv44FH+SiKW7w2Xu7trhcdTLUmSv85rfKsP+qXSjO4KGJr4dtPSzl/gvslZBXctf1qGEA==", - "dev": true, - "dependencies": { - "@jest/schemas": "^29.4.3", - "@types/istanbul-lib-coverage": "^2.0.0", - "@types/istanbul-reports": "^3.0.0", - "@types/node": "*", - "@types/yargs": "^17.0.8", - "chalk": "^4.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jridgewell/gen-mapping": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", - "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==", - "dependencies": { - "@jridgewell/set-array": "^1.0.0", - "@jridgewell/sourcemap-codec": "^1.4.10" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@jridgewell/set-array": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" - }, - "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.17", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz", - "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==", - "dependencies": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" - } - }, - "node_modules/@sinclair/typebox": { - "version": "0.25.23", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.25.23.tgz", - "integrity": "sha512-VEB8ygeP42CFLWyAJhN5OklpxUliqdNEUcXb4xZ/CINqtYGTjL5ukluKdKzQ0iWdUxyQ7B0539PAUhHKrCNWSQ==", - "dev": true - }, - "node_modules/@sinonjs/commons": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-2.0.0.tgz", - "integrity": "sha512-uLa0j859mMrg2slwQYdO/AkrOfmH+X6LTVmNTS9CqexuE2IvVORIkSpJLqePAbEnKJ77aMmCwr1NUZ57120Xcg==", - "dev": true, - "dependencies": { - "type-detect": "4.0.8" - } - }, - "node_modules/@sinonjs/fake-timers": { - "version": "10.0.2", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.0.2.tgz", - "integrity": "sha512-SwUDyjWnah1AaNl7kxsa7cfLhlTYoiyhDAIgyh+El30YvXs/o7OLXpYH88Zdhyx9JExKrmHDJ+10bwIcY80Jmw==", - "dev": true, - "dependencies": { - "@sinonjs/commons": "^2.0.0" - } - }, - "node_modules/@types/babel__core": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.0.tgz", - "integrity": "sha512-+n8dL/9GWblDO0iU6eZAwEIJVr5DWigtle+Q6HLOrh/pdbXOhOtqzq8VPPE2zvNJzSKY4vH/z3iT3tn0A3ypiQ==", - "dev": true, - "dependencies": { - "@babel/parser": "^7.20.7", - "@babel/types": "^7.20.7", - "@types/babel__generator": "*", - "@types/babel__template": "*", - "@types/babel__traverse": "*" - } - }, - "node_modules/@types/babel__generator": { - "version": "7.6.4", - "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", - "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", - "dev": true, - "dependencies": { - "@babel/types": "^7.0.0" - } - }, - "node_modules/@types/babel__template": { - "version": "7.4.1", - "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", - "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", - "dev": true, - "dependencies": { - "@babel/parser": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "node_modules/@types/babel__traverse": { - "version": "7.18.3", - "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.18.3.tgz", - "integrity": "sha512-1kbcJ40lLB7MHsj39U4Sh1uTd2E7rLEa79kmDpI6cy+XiXsteB3POdQomoq4FxszMrO3ZYchkhYJw7A2862b3w==", - "dev": true, - "dependencies": { - "@babel/types": "^7.3.0" - } - }, - "node_modules/@types/graceful-fs": { - "version": "4.1.6", - "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.6.tgz", - "integrity": "sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/istanbul-lib-coverage": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", - "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", - "dev": true - }, - "node_modules/@types/istanbul-lib-report": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", - "dev": true, - "dependencies": { - "@types/istanbul-lib-coverage": "*" - } - }, - "node_modules/@types/istanbul-reports": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", - "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", - "dev": true, - "dependencies": { - "@types/istanbul-lib-report": "*" - } - }, - "node_modules/@types/jscodeshift": { - "version": "0.11.6", - "resolved": "https://registry.npmjs.org/@types/jscodeshift/-/jscodeshift-0.11.6.tgz", - "integrity": "sha512-3lJ4DajWkk4MZ1F7q+1C7jE0z0xOtbu0VU/Kg3wdPq2DUvJjySSlu3B5Q/bICrTxugLhONBO7inRUWsymOID/A==", - "dev": true, - "dependencies": { - "ast-types": "^0.14.1", - "recast": "^0.20.3" - } - }, - "node_modules/@types/node": { - "version": "18.14.0", - "resolved": "https://registry.npmjs.org/@types/node/-/node-18.14.0.tgz", - "integrity": "sha512-5EWrvLmglK+imbCJY0+INViFWUHg1AHel1sq4ZVSfdcNqGy9Edv3UB9IIzzg+xPaUcAgZYcfVs2fBcwDeZzU0A==", - "dev": true - }, - "node_modules/@types/prettier": { - "version": "2.7.2", - "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.7.2.tgz", - "integrity": "sha512-KufADq8uQqo1pYKVIYzfKbJfBAc0sOeXqGbFaSpv8MRmC/zXgowNZmFcbngndGk922QDmOASEXUZCaY48gs4cg==", - "dev": true - }, - "node_modules/@types/stack-utils": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", - "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", - "dev": true - }, - "node_modules/@types/yargs": { - "version": "17.0.22", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.22.tgz", - "integrity": "sha512-pet5WJ9U8yPVRhkwuEIp5ktAeAqRZOq4UdAyWLWzxbtpyXnzbtLdKiXAjJzi/KLmPGS9wk86lUFWZFN6sISo4g==", - "dev": true, - "dependencies": { - "@types/yargs-parser": "*" - } - }, - "node_modules/@types/yargs-parser": { - "version": "21.0.0", - "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", - "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==", - "dev": true - }, - "node_modules/ansi-escapes": { - "version": "4.3.2", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", - "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", - "dev": true, - "dependencies": { - "type-fest": "^0.21.3" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/ansi-regex": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/anymatch": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", - "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", - "dev": true, - "dependencies": { - "normalize-path": "^3.0.0", - "picomatch": "^2.0.4" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/argparse": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", - "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", - "dev": true, - "dependencies": { - "sprintf-js": "~1.0.2" - } - }, - "node_modules/ast-types": { - "version": "0.14.2", - "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.14.2.tgz", - "integrity": "sha512-O0yuUDnZeQDL+ncNGlJ78BiO4jnYI3bvMsD5prT0/nsgijG/LpNBIr63gTjVTNsiGkgQhiyCShTgxt8oXOrklA==", - "dev": true, - "dependencies": { - "tslib": "^2.0.1" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/babel-core": { - "version": "7.0.0-bridge.0", - "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-7.0.0-bridge.0.tgz", - "integrity": "sha512-poPX9mZH/5CSanm50Q+1toVci6pv5KSRv/5TWCwtzQS5XEwn40BcCrgIeMFWP9CKKIniKXNxoIOnOq4VVlGXhg==", - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/babel-jest": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.4.3.tgz", - "integrity": "sha512-o45Wyn32svZE+LnMVWv/Z4x0SwtLbh4FyGcYtR20kIWd+rdrDZ9Fzq8Ml3MYLD+mZvEdzCjZsCnYZ2jpJyQ+Nw==", - "dev": true, - "dependencies": { - "@jest/transform": "^29.4.3", - "@types/babel__core": "^7.1.14", - "babel-plugin-istanbul": "^6.1.1", - "babel-preset-jest": "^29.4.3", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "slash": "^3.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "peerDependencies": { - "@babel/core": "^7.8.0" - } - }, - "node_modules/babel-plugin-istanbul": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", - "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.0.0", - "@istanbuljs/load-nyc-config": "^1.0.0", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-instrument": "^5.0.4", - "test-exclude": "^6.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/babel-plugin-jest-hoist": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.4.3.tgz", - "integrity": "sha512-mB6q2q3oahKphy5V7CpnNqZOCkxxZ9aokf1eh82Dy3jQmg4xvM1tGrh5y6BQUJh4a3Pj9+eLfwvAZ7VNKg7H8Q==", - "dev": true, - "dependencies": { - "@babel/template": "^7.3.3", - "@babel/types": "^7.3.3", - "@types/babel__core": "^7.1.14", - "@types/babel__traverse": "^7.0.6" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/babel-plugin-polyfill-corejs2": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.3.tgz", - "integrity": "sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q==", - "peer": true, - "dependencies": { - "@babel/compat-data": "^7.17.7", - "@babel/helper-define-polyfill-provider": "^0.3.3", - "semver": "^6.1.1" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/babel-plugin-polyfill-corejs3": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.6.0.tgz", - "integrity": "sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA==", - "peer": true, - "dependencies": { - "@babel/helper-define-polyfill-provider": "^0.3.3", - "core-js-compat": "^3.25.1" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/babel-plugin-polyfill-regenerator": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.4.1.tgz", - "integrity": "sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw==", - "peer": true, - "dependencies": { - "@babel/helper-define-polyfill-provider": "^0.3.3" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/babel-preset-current-node-syntax": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", - "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", - "dev": true, - "dependencies": { - "@babel/plugin-syntax-async-generators": "^7.8.4", - "@babel/plugin-syntax-bigint": "^7.8.3", - "@babel/plugin-syntax-class-properties": "^7.8.3", - "@babel/plugin-syntax-import-meta": "^7.8.3", - "@babel/plugin-syntax-json-strings": "^7.8.3", - "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", - "@babel/plugin-syntax-numeric-separator": "^7.8.3", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", - "@babel/plugin-syntax-optional-chaining": "^7.8.3", - "@babel/plugin-syntax-top-level-await": "^7.8.3" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/babel-preset-jest": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.4.3.tgz", - "integrity": "sha512-gWx6COtSuma6n9bw+8/F+2PCXrIgxV/D1TJFnp6OyBK2cxPWg0K9p/sriNYeifKjpUkMViWQ09DSWtzJQRETsw==", - "dev": true, - "dependencies": { - "babel-plugin-jest-hoist": "^29.4.3", - "babel-preset-current-node-syntax": "^1.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" - }, - "node_modules/brace-expansion": { - "version": "1.1.11", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", - "dependencies": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "node_modules/braces": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", - "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", - "dependencies": { - "fill-range": "^7.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/browserslist": { - "version": "4.21.5", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.5.tgz", - "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==", - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/browserslist" - } - ], - "dependencies": { - "caniuse-lite": "^1.0.30001449", - "electron-to-chromium": "^1.4.284", - "node-releases": "^2.0.8", - "update-browserslist-db": "^1.0.10" - }, - "bin": { - "browserslist": "cli.js" - }, - "engines": { - "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" - } - }, - "node_modules/bser": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", - "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", - "dev": true, - "dependencies": { - "node-int64": "^0.4.0" - } - }, - "node_modules/buffer-from": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" - }, - "node_modules/callsites": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", - "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/caniuse-lite": { - "version": "1.0.30001457", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001457.tgz", - "integrity": "sha512-SDIV6bgE1aVbK6XyxdURbUE89zY7+k1BBBaOwYwkNCglXlel/E7mELiHC64HQ+W0xSKlqWhV9Wh7iHxUjMs4fA==", - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/caniuse-lite" - } - ] - }, - "node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/char-regex": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", - "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/ci-info": { - "version": "3.8.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz", - "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/sibiraj-s" - } - ], - "engines": { - "node": ">=8" - } - }, - "node_modules/cjs-module-lexer": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz", - "integrity": "sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA==", - "dev": true - }, - "node_modules/cliui": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", - "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", - "dev": true, - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.1", - "wrap-ansi": "^7.0.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/clone-deep": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", - "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", - "dependencies": { - "is-plain-object": "^2.0.4", - "kind-of": "^6.0.2", - "shallow-clone": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/co": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", - "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", - "dev": true, - "engines": { - "iojs": ">= 1.0.0", - "node": ">= 0.12.0" - } - }, - "node_modules/collect-v8-coverage": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz", - "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==", - "dev": true - }, - "node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" - }, - "node_modules/commondir": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", - "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==" - }, - "node_modules/concat-map": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" - }, - "node_modules/convert-source-map": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", - "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", - "dev": true - }, - "node_modules/core-js-compat": { - "version": "3.28.0", - "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.28.0.tgz", - "integrity": "sha512-myzPgE7QodMg4nnd3K1TDoES/nADRStM8Gpz0D6nhkwbmwEnE0ZGJgoWsvQ722FR8D7xS0n0LV556RcEicjTyg==", - "peer": true, - "dependencies": { - "browserslist": "^4.21.5" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/core-js" - } - }, - "node_modules/cross-spawn": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", - "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", - "dev": true, - "dependencies": { - "path-key": "^3.1.0", - "shebang-command": "^2.0.0", - "which": "^2.0.1" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/debug": { - "version": "4.3.4", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", - "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", - "dependencies": { - "ms": "2.1.2" - }, - "engines": { - "node": ">=6.0" - }, - "peerDependenciesMeta": { - "supports-color": { - "optional": true - } - } - }, - "node_modules/dedent": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", - "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", - "dev": true - }, - "node_modules/deepmerge": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.0.tgz", - "integrity": "sha512-z2wJZXrmeHdvYJp/Ux55wIjqo81G5Bp4c+oELTW+7ar6SogWHajt5a9gO3s3IDaGSAXjDk0vlQKN3rms8ab3og==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/detect-newline": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", - "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/diff-sequences": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.4.3.tgz", - "integrity": "sha512-ofrBgwpPhCD85kMKtE9RYFFq6OC1A89oW2vvgWZNCwxrUpRUILopY7lsYyMDSjc8g6U6aiO0Qubg6r4Wgt5ZnA==", - "dev": true, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/electron-to-chromium": { - "version": "1.4.302", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.302.tgz", - "integrity": "sha512-Uk7C+7aPBryUR1Fwvk9VmipBcN9fVsqBO57jV2ZjTm+IZ6BMNqu7EDVEg2HxCNufk6QcWlFsBkhQyQroB2VWKw==" - }, - "node_modules/emittery": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz", - "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sindresorhus/emittery?sponsor=1" - } - }, - "node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true - }, - "node_modules/error-ex": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", - "dev": true, - "dependencies": { - "is-arrayish": "^0.2.1" - } - }, - "node_modules/escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", - "engines": { - "node": ">=6" - } - }, - "node_modules/escape-string-regexp": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", - "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/esprima": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", - "bin": { - "esparse": "bin/esparse.js", - "esvalidate": "bin/esvalidate.js" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/esutils": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", - "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", - "peer": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/execa": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", - "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", - "dev": true, - "dependencies": { - "cross-spawn": "^7.0.3", - "get-stream": "^6.0.0", - "human-signals": "^2.1.0", - "is-stream": "^2.0.0", - "merge-stream": "^2.0.0", - "npm-run-path": "^4.0.1", - "onetime": "^5.1.2", - "signal-exit": "^3.0.3", - "strip-final-newline": "^2.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sindresorhus/execa?sponsor=1" - } - }, - "node_modules/exit": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", - "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", - "dev": true, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/expect": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/expect/-/expect-29.4.3.tgz", - "integrity": "sha512-uC05+Q7eXECFpgDrHdXA4k2rpMyStAYPItEDLyQDo5Ta7fVkJnNA/4zh/OIVkVVNZ1oOK1PipQoyNjuZ6sz6Dg==", - "dev": true, - "dependencies": { - "@jest/expect-utils": "^29.4.3", - "jest-get-type": "^29.4.3", - "jest-matcher-utils": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-util": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/fast-json-stable-stringify": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", - "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", - "dev": true - }, - "node_modules/fb-watchman": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", - "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==", - "dev": true, - "dependencies": { - "bser": "2.1.1" - } - }, - "node_modules/fill-range": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", - "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", - "dependencies": { - "to-regex-range": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/find-cache-dir": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", - "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", - "dependencies": { - "commondir": "^1.0.1", - "make-dir": "^2.0.0", - "pkg-dir": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/find-cache-dir/node_modules/find-up": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", - "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", - "dependencies": { - "locate-path": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/find-cache-dir/node_modules/locate-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", - "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", - "dependencies": { - "p-locate": "^3.0.0", - "path-exists": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/find-cache-dir/node_modules/make-dir": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", - "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", - "dependencies": { - "pify": "^4.0.1", - "semver": "^5.6.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/find-cache-dir/node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dependencies": { - "p-try": "^2.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/find-cache-dir/node_modules/p-locate": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", - "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", - "dependencies": { - "p-limit": "^2.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/find-cache-dir/node_modules/path-exists": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", - "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", - "engines": { - "node": ">=4" - } - }, - "node_modules/find-cache-dir/node_modules/pkg-dir": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", - "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", - "dependencies": { - "find-up": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/find-cache-dir/node_modules/semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", - "bin": { - "semver": "bin/semver" - } - }, - "node_modules/find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "dev": true, - "dependencies": { - "locate-path": "^5.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/flow-parser": { - "version": "0.200.0", - "resolved": "https://registry.npmjs.org/flow-parser/-/flow-parser-0.200.0.tgz", - "integrity": "sha512-01eYYVlCEO2p6JexhTbMbDNPeDKQZV++SJbaHE/HzypTkV83oJmsJQVjVCGD8FYWiQ3ha9ALD/AHwsFhPwnZJA==", - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/fs.realpath": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" - }, - "node_modules/function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" - }, - "node_modules/gensync": { - "version": "1.0.0-beta.2", - "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", - "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/get-caller-file": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", - "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", - "dev": true, - "engines": { - "node": "6.* || 8.* || >= 10.*" - } - }, - "node_modules/get-package-type": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", - "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", - "dev": true, - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/get-stream": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", - "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/glob": { - "version": "7.2.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", - "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", - "dependencies": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.1.1", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - }, - "engines": { - "node": "*" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, - "node_modules/globals": { - "version": "11.12.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", - "engines": { - "node": ">=4" - } - }, - "node_modules/graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==" - }, - "node_modules/has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dependencies": { - "function-bind": "^1.1.1" - }, - "engines": { - "node": ">= 0.4.0" - } - }, - "node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "engines": { - "node": ">=8" - } - }, - "node_modules/html-escaper": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", - "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", - "dev": true - }, - "node_modules/human-signals": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", - "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", - "dev": true, - "engines": { - "node": ">=10.17.0" - } - }, - "node_modules/import-local": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", - "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", - "dev": true, - "dependencies": { - "pkg-dir": "^4.2.0", - "resolve-cwd": "^3.0.0" - }, - "bin": { - "import-local-fixture": "fixtures/cli.js" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/imurmurhash": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", - "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", - "engines": { - "node": ">=0.8.19" - } - }, - "node_modules/inflight": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", - "dependencies": { - "once": "^1.3.0", - "wrappy": "1" - } - }, - "node_modules/inherits": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", - "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" - }, - "node_modules/is-arrayish": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", - "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", - "dev": true - }, - "node_modules/is-core-module": { - "version": "2.11.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", - "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", - "dependencies": { - "has": "^1.0.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-fullwidth-code-point": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", - "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-generator-fn": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", - "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/is-number": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", - "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", - "engines": { - "node": ">=0.12.0" - } - }, - "node_modules/is-plain-object": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", - "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", - "dependencies": { - "isobject": "^3.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-stream": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", - "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", - "dev": true, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/isexe": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", - "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", - "dev": true - }, - "node_modules/isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/istanbul-lib-coverage": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", - "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/istanbul-lib-instrument": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", - "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", - "dev": true, - "dependencies": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-coverage": "^3.2.0", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/istanbul-lib-report": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", - "dev": true, - "dependencies": { - "istanbul-lib-coverage": "^3.0.0", - "make-dir": "^3.0.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/istanbul-lib-source-maps": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", - "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", - "dev": true, - "dependencies": { - "debug": "^4.1.1", - "istanbul-lib-coverage": "^3.0.0", - "source-map": "^0.6.1" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/istanbul-reports": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", - "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", - "dev": true, - "dependencies": { - "html-escaper": "^2.0.0", - "istanbul-lib-report": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest/-/jest-29.4.3.tgz", - "integrity": "sha512-XvK65feuEFGZT8OO0fB/QAQS+LGHvQpaadkH5p47/j3Ocqq3xf2pK9R+G0GzgfuhXVxEv76qCOOcMb5efLk6PA==", - "dev": true, - "dependencies": { - "@jest/core": "^29.4.3", - "@jest/types": "^29.4.3", - "import-local": "^3.0.2", - "jest-cli": "^29.4.3" - }, - "bin": { - "jest": "bin/jest.js" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "peerDependencies": { - "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" - }, - "peerDependenciesMeta": { - "node-notifier": { - "optional": true - } - } - }, - "node_modules/jest-changed-files": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.4.3.tgz", - "integrity": "sha512-Vn5cLuWuwmi2GNNbokPOEcvrXGSGrqVnPEZV7rC6P7ck07Dyw9RFnvWglnupSh+hGys0ajGtw/bc2ZgweljQoQ==", - "dev": true, - "dependencies": { - "execa": "^5.0.0", - "p-limit": "^3.1.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-circus": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.4.3.tgz", - "integrity": "sha512-Vw/bVvcexmdJ7MLmgdT3ZjkJ3LKu8IlpefYokxiqoZy6OCQ2VAm6Vk3t/qHiAGUXbdbJKJWnc8gH3ypTbB/OBw==", - "dev": true, - "dependencies": { - "@jest/environment": "^29.4.3", - "@jest/expect": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "co": "^4.6.0", - "dedent": "^0.7.0", - "is-generator-fn": "^2.0.0", - "jest-each": "^29.4.3", - "jest-matcher-utils": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-runtime": "^29.4.3", - "jest-snapshot": "^29.4.3", - "jest-util": "^29.4.3", - "p-limit": "^3.1.0", - "pretty-format": "^29.4.3", - "slash": "^3.0.0", - "stack-utils": "^2.0.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-cli": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.4.3.tgz", - "integrity": "sha512-PiiAPuFNfWWolCE6t3ZrDXQc6OsAuM3/tVW0u27UWc1KE+n/HSn5dSE6B2juqN7WP+PP0jAcnKtGmI4u8GMYCg==", - "dev": true, - "dependencies": { - "@jest/core": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/types": "^29.4.3", - "chalk": "^4.0.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "import-local": "^3.0.2", - "jest-config": "^29.4.3", - "jest-util": "^29.4.3", - "jest-validate": "^29.4.3", - "prompts": "^2.0.1", - "yargs": "^17.3.1" - }, - "bin": { - "jest": "bin/jest.js" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "peerDependencies": { - "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" - }, - "peerDependenciesMeta": { - "node-notifier": { - "optional": true - } - } - }, - "node_modules/jest-config": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.4.3.tgz", - "integrity": "sha512-eCIpqhGnIjdUCXGtLhz4gdDoxKSWXKjzNcc5r+0S1GKOp2fwOipx5mRcwa9GB/ArsxJ1jlj2lmlD9bZAsBxaWQ==", - "dev": true, - "dependencies": { - "@babel/core": "^7.11.6", - "@jest/test-sequencer": "^29.4.3", - "@jest/types": "^29.4.3", - "babel-jest": "^29.4.3", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "deepmerge": "^4.2.2", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-circus": "^29.4.3", - "jest-environment-node": "^29.4.3", - "jest-get-type": "^29.4.3", - "jest-regex-util": "^29.4.3", - "jest-resolve": "^29.4.3", - "jest-runner": "^29.4.3", - "jest-util": "^29.4.3", - "jest-validate": "^29.4.3", - "micromatch": "^4.0.4", - "parse-json": "^5.2.0", - "pretty-format": "^29.4.3", - "slash": "^3.0.0", - "strip-json-comments": "^3.1.1" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "peerDependencies": { - "@types/node": "*", - "ts-node": ">=9.0.0" - }, - "peerDependenciesMeta": { - "@types/node": { - "optional": true - }, - "ts-node": { - "optional": true - } - } - }, - "node_modules/jest-diff": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.4.3.tgz", - "integrity": "sha512-YB+ocenx7FZ3T5O9lMVMeLYV4265socJKtkwgk/6YUz/VsEzYDkiMuMhWzZmxm3wDRQvayJu/PjkjjSkjoHsCA==", - "dev": true, - "dependencies": { - "chalk": "^4.0.0", - "diff-sequences": "^29.4.3", - "jest-get-type": "^29.4.3", - "pretty-format": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-docblock": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.4.3.tgz", - "integrity": "sha512-fzdTftThczeSD9nZ3fzA/4KkHtnmllawWrXO69vtI+L9WjEIuXWs4AmyME7lN5hU7dB0sHhuPfcKofRsUb/2Fg==", - "dev": true, - "dependencies": { - "detect-newline": "^3.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-each": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.4.3.tgz", - "integrity": "sha512-1ElHNAnKcbJb/b+L+7j0/w7bDvljw4gTv1wL9fYOczeJrbTbkMGQ5iQPFJ3eFQH19VPTx1IyfePdqSpePKss7Q==", - "dev": true, - "dependencies": { - "@jest/types": "^29.4.3", - "chalk": "^4.0.0", - "jest-get-type": "^29.4.3", - "jest-util": "^29.4.3", - "pretty-format": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-environment-node": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.4.3.tgz", - "integrity": "sha512-gAiEnSKF104fsGDXNkwk49jD/0N0Bqu2K9+aMQXA6avzsA9H3Fiv1PW2D+gzbOSR705bWd2wJZRFEFpV0tXISg==", - "dev": true, - "dependencies": { - "@jest/environment": "^29.4.3", - "@jest/fake-timers": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "jest-mock": "^29.4.3", - "jest-util": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-get-type": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.4.3.tgz", - "integrity": "sha512-J5Xez4nRRMjk8emnTpWrlkyb9pfRQQanDrvWHhsR1+VUfbwxi30eVcZFlcdGInRibU4G5LwHXpI7IRHU0CY+gg==", - "dev": true, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-haste-map": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.4.3.tgz", - "integrity": "sha512-eZIgAS8tvm5IZMtKlR8Y+feEOMfo2pSQkmNbufdbMzMSn9nitgGxF1waM/+LbryO3OkMcKS98SUb+j/cQxp/vQ==", - "dev": true, - "dependencies": { - "@jest/types": "^29.4.3", - "@types/graceful-fs": "^4.1.3", - "@types/node": "*", - "anymatch": "^3.0.3", - "fb-watchman": "^2.0.0", - "graceful-fs": "^4.2.9", - "jest-regex-util": "^29.4.3", - "jest-util": "^29.4.3", - "jest-worker": "^29.4.3", - "micromatch": "^4.0.4", - "walker": "^1.0.8" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "optionalDependencies": { - "fsevents": "^2.3.2" - } - }, - "node_modules/jest-leak-detector": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.4.3.tgz", - "integrity": "sha512-9yw4VC1v2NspMMeV3daQ1yXPNxMgCzwq9BocCwYrRgXe4uaEJPAN0ZK37nFBhcy3cUwEVstFecFLaTHpF7NiGA==", - "dev": true, - "dependencies": { - "jest-get-type": "^29.4.3", - "pretty-format": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-matcher-utils": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.4.3.tgz", - "integrity": "sha512-TTciiXEONycZ03h6R6pYiZlSkvYgT0l8aa49z/DLSGYjex4orMUcafuLXYyyEDWB1RKglq00jzwY00Ei7yFNVg==", - "dev": true, - "dependencies": { - "chalk": "^4.0.0", - "jest-diff": "^29.4.3", - "jest-get-type": "^29.4.3", - "pretty-format": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-message-util": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.4.3.tgz", - "integrity": "sha512-1Y8Zd4ZCN7o/QnWdMmT76If8LuDv23Z1DRovBj/vcSFNlGCJGoO8D1nJDw1AdyAGUk0myDLFGN5RbNeJyCRGCw==", - "dev": true, - "dependencies": { - "@babel/code-frame": "^7.12.13", - "@jest/types": "^29.4.3", - "@types/stack-utils": "^2.0.0", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "micromatch": "^4.0.4", - "pretty-format": "^29.4.3", - "slash": "^3.0.0", - "stack-utils": "^2.0.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-mock": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.4.3.tgz", - "integrity": "sha512-LjFgMg+xed9BdkPMyIJh+r3KeHt1klXPJYBULXVVAkbTaaKjPX1o1uVCAZADMEp/kOxGTwy/Ot8XbvgItOrHEg==", - "dev": true, - "dependencies": { - "@jest/types": "^29.4.3", - "@types/node": "*", - "jest-util": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-pnp-resolver": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", - "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", - "dev": true, - "engines": { - "node": ">=6" - }, - "peerDependencies": { - "jest-resolve": "*" - }, - "peerDependenciesMeta": { - "jest-resolve": { - "optional": true - } - } - }, - "node_modules/jest-regex-util": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.4.3.tgz", - "integrity": "sha512-O4FglZaMmWXbGHSQInfXewIsd1LMn9p3ZXB/6r4FOkyhX2/iP/soMG98jGvk/A3HAN78+5VWcBGO0BJAPRh4kg==", - "dev": true, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-resolve": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.4.3.tgz", - "integrity": "sha512-GPokE1tzguRyT7dkxBim4wSx6E45S3bOQ7ZdKEG+Qj0Oac9+6AwJPCk0TZh5Vu0xzeX4afpb+eDmgbmZFFwpOw==", - "dev": true, - "dependencies": { - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.4.3", - "jest-pnp-resolver": "^1.2.2", - "jest-util": "^29.4.3", - "jest-validate": "^29.4.3", - "resolve": "^1.20.0", - "resolve.exports": "^2.0.0", - "slash": "^3.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-resolve-dependencies": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.4.3.tgz", - "integrity": "sha512-uvKMZAQ3nmXLH7O8WAOhS5l0iWyT3WmnJBdmIHiV5tBbdaDZ1wqtNX04FONGoaFvSOSHBJxnwAVnSn1WHdGVaw==", - "dev": true, - "dependencies": { - "jest-regex-util": "^29.4.3", - "jest-snapshot": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-runner": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.4.3.tgz", - "integrity": "sha512-GWPTEiGmtHZv1KKeWlTX9SIFuK19uLXlRQU43ceOQ2hIfA5yPEJC7AMkvFKpdCHx6pNEdOD+2+8zbniEi3v3gA==", - "dev": true, - "dependencies": { - "@jest/console": "^29.4.3", - "@jest/environment": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "emittery": "^0.13.1", - "graceful-fs": "^4.2.9", - "jest-docblock": "^29.4.3", - "jest-environment-node": "^29.4.3", - "jest-haste-map": "^29.4.3", - "jest-leak-detector": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-resolve": "^29.4.3", - "jest-runtime": "^29.4.3", - "jest-util": "^29.4.3", - "jest-watcher": "^29.4.3", - "jest-worker": "^29.4.3", - "p-limit": "^3.1.0", - "source-map-support": "0.5.13" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-runtime": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.4.3.tgz", - "integrity": "sha512-F5bHvxSH+LvLV24vVB3L8K467dt3y3dio6V3W89dUz9nzvTpqd/HcT9zfYKL2aZPvD63vQFgLvaUX/UpUhrP6Q==", - "dev": true, - "dependencies": { - "@jest/environment": "^29.4.3", - "@jest/fake-timers": "^29.4.3", - "@jest/globals": "^29.4.3", - "@jest/source-map": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "cjs-module-lexer": "^1.0.0", - "collect-v8-coverage": "^1.0.0", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-mock": "^29.4.3", - "jest-regex-util": "^29.4.3", - "jest-resolve": "^29.4.3", - "jest-snapshot": "^29.4.3", - "jest-util": "^29.4.3", - "slash": "^3.0.0", - "strip-bom": "^4.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-snapshot": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.4.3.tgz", - "integrity": "sha512-NGlsqL0jLPDW91dz304QTM/SNO99lpcSYYAjNiX0Ou+sSGgkanKBcSjCfp/pqmiiO1nQaOyLp6XQddAzRcx3Xw==", - "dev": true, - "dependencies": { - "@babel/core": "^7.11.6", - "@babel/generator": "^7.7.2", - "@babel/plugin-syntax-jsx": "^7.7.2", - "@babel/plugin-syntax-typescript": "^7.7.2", - "@babel/traverse": "^7.7.2", - "@babel/types": "^7.3.3", - "@jest/expect-utils": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/babel__traverse": "^7.0.6", - "@types/prettier": "^2.1.5", - "babel-preset-current-node-syntax": "^1.0.0", - "chalk": "^4.0.0", - "expect": "^29.4.3", - "graceful-fs": "^4.2.9", - "jest-diff": "^29.4.3", - "jest-get-type": "^29.4.3", - "jest-haste-map": "^29.4.3", - "jest-matcher-utils": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-util": "^29.4.3", - "natural-compare": "^1.4.0", - "pretty-format": "^29.4.3", - "semver": "^7.3.5" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-snapshot/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/jest-snapshot/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/jest-snapshot/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/jest-util": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.4.3.tgz", - "integrity": "sha512-ToSGORAz4SSSoqxDSylWX8JzkOQR7zoBtNRsA7e+1WUX5F8jrOwaNpuh1YfJHJKDHXLHmObv5eOjejUd+/Ws+Q==", - "dev": true, - "dependencies": { - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "graceful-fs": "^4.2.9", - "picomatch": "^2.2.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-validate": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.4.3.tgz", - "integrity": "sha512-J3u5v7aPQoXPzaar6GndAVhdQcZr/3osWSgTeKg5v574I9ybX/dTyH0AJFb5XgXIB7faVhf+rS7t4p3lL9qFaw==", - "dev": true, - "dependencies": { - "@jest/types": "^29.4.3", - "camelcase": "^6.2.0", - "chalk": "^4.0.0", - "jest-get-type": "^29.4.3", - "leven": "^3.1.0", - "pretty-format": "^29.4.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-validate/node_modules/camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/jest-watcher": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.4.3.tgz", - "integrity": "sha512-zwlXH3DN3iksoIZNk73etl1HzKyi5FuQdYLnkQKm5BW4n8HpoG59xSwpVdFrnh60iRRaRBGw0gcymIxjJENPcA==", - "dev": true, - "dependencies": { - "@jest/test-result": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", - "emittery": "^0.13.1", - "jest-util": "^29.4.3", - "string-length": "^4.0.1" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-worker": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.4.3.tgz", - "integrity": "sha512-GLHN/GTAAMEy5BFdvpUfzr9Dr80zQqBrh0fz1mtRMe05hqP45+HfQltu7oTBfduD0UeZs09d+maFtFYAXFWvAA==", - "dev": true, - "dependencies": { - "@types/node": "*", - "jest-util": "^29.4.3", - "merge-stream": "^2.0.0", - "supports-color": "^8.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-worker/node_modules/supports-color": { - "version": "8.1.1", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", - "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/supports-color?sponsor=1" - } - }, - "node_modules/js-tokens": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", - "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" - }, - "node_modules/js-yaml": { - "version": "3.14.1", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", - "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", - "dev": true, - "dependencies": { - "argparse": "^1.0.7", - "esprima": "^4.0.0" - }, - "bin": { - "js-yaml": "bin/js-yaml.js" - } - }, - "node_modules/jscodeshift": { - "version": "0.14.0", - "resolved": "https://registry.npmjs.org/jscodeshift/-/jscodeshift-0.14.0.tgz", - "integrity": "sha512-7eCC1knD7bLUPuSCwXsMZUH51O8jIcoVyKtI6P0XM0IVzlGjckPy3FIwQlorzbN0Sg79oK+RlohN32Mqf/lrYA==", - "dependencies": { - "@babel/core": "^7.13.16", - "@babel/parser": "^7.13.16", - "@babel/plugin-proposal-class-properties": "^7.13.0", - "@babel/plugin-proposal-nullish-coalescing-operator": "^7.13.8", - "@babel/plugin-proposal-optional-chaining": "^7.13.12", - "@babel/plugin-transform-modules-commonjs": "^7.13.8", - "@babel/preset-flow": "^7.13.13", - "@babel/preset-typescript": "^7.13.0", - "@babel/register": "^7.13.16", - "babel-core": "^7.0.0-bridge.0", - "chalk": "^4.1.2", - "flow-parser": "0.*", - "graceful-fs": "^4.2.4", - "micromatch": "^4.0.4", - "neo-async": "^2.5.0", - "node-dir": "^0.1.17", - "recast": "^0.21.0", - "temp": "^0.8.4", - "write-file-atomic": "^2.3.0" - }, - "bin": { - "jscodeshift": "bin/jscodeshift.js" - }, - "peerDependencies": { - "@babel/preset-env": "^7.1.6" - } - }, - "node_modules/jscodeshift/node_modules/ast-types": { - "version": "0.15.2", - "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.15.2.tgz", - "integrity": "sha512-c27loCv9QkZinsa5ProX751khO9DJl/AcB5c2KNtA6NRvHKS0PgLfcftz72KVq504vB0Gku5s2kUZzDBvQWvHg==", - "dependencies": { - "tslib": "^2.0.1" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/jscodeshift/node_modules/recast": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/recast/-/recast-0.21.5.tgz", - "integrity": "sha512-hjMmLaUXAm1hIuTqOdeYObMslq/q+Xff6QE3Y2P+uoHAg2nmVlLBps2hzh1UJDdMtDTMXOFewK6ky51JQIeECg==", - "dependencies": { - "ast-types": "0.15.2", - "esprima": "~4.0.0", - "source-map": "~0.6.1", - "tslib": "^2.0.1" - }, - "engines": { - "node": ">= 4" - } - }, - "node_modules/jscodeshift/node_modules/write-file-atomic": { - "version": "2.4.3", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.3.tgz", - "integrity": "sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ==", - "dependencies": { - "graceful-fs": "^4.1.11", - "imurmurhash": "^0.1.4", - "signal-exit": "^3.0.2" - } - }, - "node_modules/jsesc": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", - "bin": { - "jsesc": "bin/jsesc" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/json-parse-even-better-errors": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", - "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", - "dev": true - }, - "node_modules/json5": { - "version": "2.2.3", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", - "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", - "bin": { - "json5": "lib/cli.js" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/kind-of": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", - "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/kleur": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", - "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/leven": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", - "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/lines-and-columns": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", - "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", - "dev": true - }, - "node_modules/locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "dev": true, - "dependencies": { - "p-locate": "^4.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/lodash.debounce": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", - "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", - "peer": true - }, - "node_modules/lru-cache": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", - "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", - "dependencies": { - "yallist": "^3.0.2" - } - }, - "node_modules/make-dir": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", - "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", - "dev": true, - "dependencies": { - "semver": "^6.0.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/makeerror": { - "version": "1.0.12", - "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", - "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", - "dev": true, - "dependencies": { - "tmpl": "1.0.5" - } - }, - "node_modules/merge-stream": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", - "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", - "dev": true - }, - "node_modules/micromatch": { - "version": "4.0.5", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", - "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", - "dependencies": { - "braces": "^3.0.2", - "picomatch": "^2.3.1" - }, - "engines": { - "node": ">=8.6" - } - }, - "node_modules/mimic-fn": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", - "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/minimatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", - "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", - "dependencies": { - "brace-expansion": "^1.1.7" - }, - "engines": { - "node": "*" - } - }, - "node_modules/ms": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" - }, - "node_modules/natural-compare": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", - "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", - "dev": true - }, - "node_modules/neo-async": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", - "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==" - }, - "node_modules/node-dir": { - "version": "0.1.17", - "resolved": "https://registry.npmjs.org/node-dir/-/node-dir-0.1.17.tgz", - "integrity": "sha512-tmPX422rYgofd4epzrNoOXiE8XFZYOcCq1vD7MAXCDO+O+zndlA2ztdKKMa+EeuBG5tHETpr4ml4RGgpqDCCAg==", - "dependencies": { - "minimatch": "^3.0.2" - }, - "engines": { - "node": ">= 0.10.5" - } - }, - "node_modules/node-int64": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", - "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==", - "dev": true - }, - "node_modules/node-releases": { - "version": "2.0.10", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.10.tgz", - "integrity": "sha512-5GFldHPXVG/YZmFzJvKK2zDSzPKhEp0+ZR5SVaoSag9fsL5YgHbUHDfnG5494ISANDcK4KwPXAx2xqVEydmd7w==" - }, - "node_modules/normalize-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", - "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/npm-run-path": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", - "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", - "dev": true, - "dependencies": { - "path-key": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/once": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", - "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", - "dependencies": { - "wrappy": "1" - } - }, - "node_modules/onetime": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", - "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", - "dev": true, - "dependencies": { - "mimic-fn": "^2.1.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/p-limit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", - "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", - "dev": true, - "dependencies": { - "yocto-queue": "^0.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "dev": true, - "dependencies": { - "p-limit": "^2.2.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/p-locate/node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dev": true, - "dependencies": { - "p-try": "^2.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/p-try": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", - "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", - "engines": { - "node": ">=6" - } - }, - "node_modules/parse-json": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", - "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", - "dev": true, - "dependencies": { - "@babel/code-frame": "^7.0.0", - "error-ex": "^1.3.1", - "json-parse-even-better-errors": "^2.3.0", - "lines-and-columns": "^1.1.6" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/path-exists": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", - "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/path-is-absolute": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/path-key": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", - "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" - }, - "node_modules/picocolors": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", - "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" - }, - "node_modules/picomatch": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", - "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "engines": { - "node": ">=8.6" - }, - "funding": { - "url": "https://github.com/sponsors/jonschlinkert" - } - }, - "node_modules/pify": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", - "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", - "engines": { - "node": ">=6" - } - }, - "node_modules/pirates": { - "version": "4.0.5", - "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz", - "integrity": "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==", - "engines": { - "node": ">= 6" - } - }, - "node_modules/pkg-dir": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", - "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", - "dev": true, - "dependencies": { - "find-up": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/pretty-format": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.4.3.tgz", - "integrity": "sha512-cvpcHTc42lcsvOOAzd3XuNWTcvk1Jmnzqeu+WsOuiPmxUJTnkbAcFNsRKvEpBEUFVUgy/GTZLulZDcDEi+CIlA==", - "dev": true, - "dependencies": { - "@jest/schemas": "^29.4.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/pretty-format/node_modules/ansi-styles": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", - "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/prompts": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", - "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", - "dev": true, - "dependencies": { - "kleur": "^3.0.3", - "sisteransi": "^1.0.5" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", - "dev": true - }, - "node_modules/recast": { - "version": "0.20.5", - "resolved": "https://registry.npmjs.org/recast/-/recast-0.20.5.tgz", - "integrity": "sha512-E5qICoPoNL4yU0H0NoBDntNB0Q5oMSNh9usFctYniLBluTthi3RsQVBXIJNbApOlvSwW/RGxIuokPcAc59J5fQ==", - "dev": true, - "dependencies": { - "ast-types": "0.14.2", - "esprima": "~4.0.0", - "source-map": "~0.6.1", - "tslib": "^2.0.1" - }, - "engines": { - "node": ">= 4" - } - }, - "node_modules/regenerate": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz", - "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==", - "peer": true - }, - "node_modules/regenerate-unicode-properties": { - "version": "10.1.0", - "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz", - "integrity": "sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ==", - "peer": true, - "dependencies": { - "regenerate": "^1.4.2" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/regenerator-runtime": { - "version": "0.13.11", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", - "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==", - "peer": true - }, - "node_modules/regenerator-transform": { - "version": "0.15.1", - "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.1.tgz", - "integrity": "sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg==", - "peer": true, - "dependencies": { - "@babel/runtime": "^7.8.4" - } - }, - "node_modules/regexpu-core": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.3.1.tgz", - "integrity": "sha512-nCOzW2V/X15XpLsK2rlgdwrysrBq+AauCn+omItIz4R1pIcmeot5zvjdmOBRLzEH/CkC6IxMJVmxDe3QcMuNVQ==", - "peer": true, - "dependencies": { - "@babel/regjsgen": "^0.8.0", - "regenerate": "^1.4.2", - "regenerate-unicode-properties": "^10.1.0", - "regjsparser": "^0.9.1", - "unicode-match-property-ecmascript": "^2.0.0", - "unicode-match-property-value-ecmascript": "^2.1.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/regjsparser": { - "version": "0.9.1", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz", - "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==", - "peer": true, - "dependencies": { - "jsesc": "~0.5.0" - }, - "bin": { - "regjsparser": "bin/parser" - } - }, - "node_modules/regjsparser/node_modules/jsesc": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", - "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==", - "peer": true, - "bin": { - "jsesc": "bin/jsesc" - } - }, - "node_modules/require-directory": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/resolve": { - "version": "1.22.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", - "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", - "dependencies": { - "is-core-module": "^2.9.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - }, - "bin": { - "resolve": "bin/resolve" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/resolve-cwd": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", - "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", - "dev": true, - "dependencies": { - "resolve-from": "^5.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/resolve-from": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", - "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/resolve.exports": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.0.tgz", - "integrity": "sha512-6K/gDlqgQscOlg9fSRpWstA8sYe8rbELsSTNpx+3kTrsVCzvSl0zIvRErM7fdl9ERWDsKnrLnwB+Ne89918XOg==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/rimraf": { - "version": "2.6.3", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", - "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", - "dependencies": { - "glob": "^7.1.3" - }, - "bin": { - "rimraf": "bin.js" - } - }, - "node_modules/semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", - "bin": { - "semver": "bin/semver.js" - } - }, - "node_modules/shallow-clone": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", - "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", - "dependencies": { - "kind-of": "^6.0.2" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/shebang-command": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", - "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", - "dev": true, - "dependencies": { - "shebang-regex": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/shebang-regex": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", - "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/signal-exit": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", - "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" - }, - "node_modules/sisteransi": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", - "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", - "dev": true - }, - "node_modules/slash": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", - "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/source-map-support": { - "version": "0.5.13", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz", - "integrity": "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==", - "dev": true, - "dependencies": { - "buffer-from": "^1.0.0", - "source-map": "^0.6.0" - } - }, - "node_modules/sprintf-js": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", - "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", - "dev": true - }, - "node_modules/stack-utils": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", - "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", - "dev": true, - "dependencies": { - "escape-string-regexp": "^2.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/string-length": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", - "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", - "dev": true, - "dependencies": { - "char-regex": "^1.0.2", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/string-width": { - "version": "4.2.3", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", - "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, - "dependencies": { - "emoji-regex": "^8.0.0", - "is-fullwidth-code-point": "^3.0.0", - "strip-ansi": "^6.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/strip-ansi": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", - "dev": true, - "dependencies": { - "ansi-regex": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/strip-bom": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", - "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/strip-final-newline": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", - "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/strip-json-comments": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", - "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", - "dev": true, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/supports-preserve-symlinks-flag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", - "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/temp": { - "version": "0.8.4", - "resolved": "https://registry.npmjs.org/temp/-/temp-0.8.4.tgz", - "integrity": "sha512-s0ZZzd0BzYv5tLSptZooSjK8oj6C+c19p7Vqta9+6NPOf7r+fxq0cJe6/oN4LTC79sy5NY8ucOJNgwsKCSbfqg==", - "dependencies": { - "rimraf": "~2.6.2" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/test-exclude": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", - "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", - "dev": true, - "dependencies": { - "@istanbuljs/schema": "^0.1.2", - "glob": "^7.1.4", - "minimatch": "^3.0.4" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/tmpl": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", - "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", - "dev": true - }, - "node_modules/to-fast-properties": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", - "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", - "engines": { - "node": ">=4" - } - }, - "node_modules/to-regex-range": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", - "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "dependencies": { - "is-number": "^7.0.0" - }, - "engines": { - "node": ">=8.0" - } - }, - "node_modules/tslib": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz", - "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==" - }, - "node_modules/type-detect": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", - "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/type-fest": { - "version": "0.21.3", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", - "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/unicode-canonical-property-names-ecmascript": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz", - "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==", - "peer": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/unicode-match-property-ecmascript": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz", - "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==", - "peer": true, - "dependencies": { - "unicode-canonical-property-names-ecmascript": "^2.0.0", - "unicode-property-aliases-ecmascript": "^2.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/unicode-match-property-value-ecmascript": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz", - "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==", - "peer": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/unicode-property-aliases-ecmascript": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz", - "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==", - "peer": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/update-browserslist-db": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz", - "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==", - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/browserslist" - } - ], - "dependencies": { - "escalade": "^3.1.1", - "picocolors": "^1.0.0" - }, - "bin": { - "browserslist-lint": "cli.js" - }, - "peerDependencies": { - "browserslist": ">= 4.21.0" - } - }, - "node_modules/v8-to-istanbul": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", - "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==", - "dev": true, - "dependencies": { - "@jridgewell/trace-mapping": "^0.3.12", - "@types/istanbul-lib-coverage": "^2.0.1", - "convert-source-map": "^1.6.0" - }, - "engines": { - "node": ">=10.12.0" - } - }, - "node_modules/v8-to-istanbul/node_modules/convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true - }, - "node_modules/walker": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", - "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", - "dev": true, - "dependencies": { - "makeerror": "1.0.12" - } - }, - "node_modules/which": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", - "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", - "dev": true, - "dependencies": { - "isexe": "^2.0.0" - }, - "bin": { - "node-which": "bin/node-which" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/wrap-ansi?sponsor=1" - } - }, - "node_modules/wrappy": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" - }, - "node_modules/write-file-atomic": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz", - "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==", - "dev": true, - "dependencies": { - "imurmurhash": "^0.1.4", - "signal-exit": "^3.0.7" - }, - "engines": { - "node": "^12.13.0 || ^14.15.0 || >=16.0.0" - } - }, - "node_modules/y18n": { - "version": "5.0.8", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", - "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/yallist": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", - "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" - }, - "node_modules/yargs": { - "version": "17.7.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.0.tgz", - "integrity": "sha512-dwqOPg5trmrre9+v8SUo2q/hAwyKoVfu8OC1xPHKJGNdxAvPl4sKxL4vBnh3bQz/ZvvGAFeA5H3ou2kcOY8sQQ==", - "dev": true, - "dependencies": { - "cliui": "^8.0.1", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.3", - "y18n": "^5.0.5", - "yargs-parser": "^21.1.1" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/yargs-parser": { - "version": "21.1.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", - "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", - "dev": true, - "engines": { - "node": ">=12" - } - }, - "node_modules/yocto-queue": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", - "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - } - }, - "dependencies": { - "@ampproject/remapping": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz", - "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==", - "requires": { - "@jridgewell/gen-mapping": "^0.1.0", - "@jridgewell/trace-mapping": "^0.3.9" - } - }, - "@babel/code-frame": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", - "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", - "requires": { - "@babel/highlight": "^7.18.6" - } - }, - "@babel/compat-data": { - "version": "7.20.14", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.20.14.tgz", - "integrity": "sha512-0YpKHD6ImkWMEINCyDAD0HLLUH/lPCefG8ld9it8DJB2wnApraKuhgYTvTY1z7UFIfBTGy5LwncZ+5HWWGbhFw==" - }, - "@babel/core": { - "version": "7.20.12", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.20.12.tgz", - "integrity": "sha512-XsMfHovsUYHFMdrIHkZphTN/2Hzzi78R08NuHfDBehym2VsPDL6Zn/JAD/JQdnRvbSsbQc4mVaU1m6JgtTEElg==", - "requires": { - "@ampproject/remapping": "^2.1.0", - "@babel/code-frame": "^7.18.6", - "@babel/generator": "^7.20.7", - "@babel/helper-compilation-targets": "^7.20.7", - "@babel/helper-module-transforms": "^7.20.11", - "@babel/helpers": "^7.20.7", - "@babel/parser": "^7.20.7", - "@babel/template": "^7.20.7", - "@babel/traverse": "^7.20.12", - "@babel/types": "^7.20.7", - "convert-source-map": "^1.7.0", - "debug": "^4.1.0", - "gensync": "^1.0.0-beta.2", - "json5": "^2.2.2", - "semver": "^6.3.0" - }, - "dependencies": { - "convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==" - } - } - }, - "@babel/generator": { - "version": "7.21.1", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.21.1.tgz", - "integrity": "sha512-1lT45bAYlQhFn/BHivJs43AiW2rg3/UbLyShGfF3C0KmHvO5fSghWd5kBJy30kpRRucGzXStvnnCFniCR2kXAA==", - "requires": { - "@babel/types": "^7.21.0", - "@jridgewell/gen-mapping": "^0.3.2", - "@jridgewell/trace-mapping": "^0.3.17", - "jsesc": "^2.5.1" - }, - "dependencies": { - "@jridgewell/gen-mapping": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", - "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", - "requires": { - "@jridgewell/set-array": "^1.0.1", - "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" - } - } - } - }, - "@babel/helper-annotate-as-pure": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz", - "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==", - "requires": { - "@babel/types": "^7.18.6" - } - }, - "@babel/helper-builder-binary-assignment-operator-visitor": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz", - "integrity": "sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw==", - "peer": true, - "requires": { - "@babel/helper-explode-assignable-expression": "^7.18.6", - "@babel/types": "^7.18.9" - } - }, - "@babel/helper-compilation-targets": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.7.tgz", - "integrity": "sha512-4tGORmfQcrc+bvrjb5y3dG9Mx1IOZjsHqQVUz7XCNHO+iTmqxWnVg3KRygjGmpRLJGdQSKuvFinbIb0CnZwHAQ==", - "requires": { - "@babel/compat-data": "^7.20.5", - "@babel/helper-validator-option": "^7.18.6", - "browserslist": "^4.21.3", - "lru-cache": "^5.1.1", - "semver": "^6.3.0" - } - }, - "@babel/helper-create-class-features-plugin": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.21.0.tgz", - "integrity": "sha512-Q8wNiMIdwsv5la5SPxNYzzkPnjgC0Sy0i7jLkVOCdllu/xcVNkr3TeZzbHBJrj+XXRqzX5uCyCoV9eu6xUG7KQ==", - "requires": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.21.0", - "@babel/helper-member-expression-to-functions": "^7.21.0", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/helper-replace-supers": "^7.20.7", - "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0", - "@babel/helper-split-export-declaration": "^7.18.6" - } - }, - "@babel/helper-create-regexp-features-plugin": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.21.0.tgz", - "integrity": "sha512-N+LaFW/auRSWdx7SHD/HiARwXQju1vXTW4fKr4u5SgBUTm51OKEjKgj+cs00ggW3kEvNqwErnlwuq7Y3xBe4eg==", - "peer": true, - "requires": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "regexpu-core": "^5.3.1" - } - }, - "@babel/helper-define-polyfill-provider": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.3.tgz", - "integrity": "sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww==", - "peer": true, - "requires": { - "@babel/helper-compilation-targets": "^7.17.7", - "@babel/helper-plugin-utils": "^7.16.7", - "debug": "^4.1.1", - "lodash.debounce": "^4.0.8", - "resolve": "^1.14.2", - "semver": "^6.1.2" - } - }, - "@babel/helper-environment-visitor": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz", - "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==" - }, - "@babel/helper-explode-assignable-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz", - "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==", - "peer": true, - "requires": { - "@babel/types": "^7.18.6" - } - }, - "@babel/helper-function-name": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.21.0.tgz", - "integrity": "sha512-HfK1aMRanKHpxemaY2gqBmL04iAPOPRj7DxtNbiDOrJK+gdwkiNRVpCpUJYbUT+aZyemKN8brqTOxzCaG6ExRg==", - "requires": { - "@babel/template": "^7.20.7", - "@babel/types": "^7.21.0" - } - }, - "@babel/helper-hoist-variables": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", - "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", - "requires": { - "@babel/types": "^7.18.6" - } - }, - "@babel/helper-member-expression-to-functions": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.21.0.tgz", - "integrity": "sha512-Muu8cdZwNN6mRRNG6lAYErJ5X3bRevgYR2O8wN0yn7jJSnGDu6eG59RfT29JHxGUovyfrh6Pj0XzmR7drNVL3Q==", - "requires": { - "@babel/types": "^7.21.0" - } - }, - "@babel/helper-module-imports": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz", - "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==", - "requires": { - "@babel/types": "^7.18.6" - } - }, - "@babel/helper-module-transforms": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.21.2.tgz", - "integrity": "sha512-79yj2AR4U/Oqq/WOV7Lx6hUjau1Zfo4cI+JLAVYeMV5XIlbOhmjEk5ulbTc9fMpmlojzZHkUUxAiK+UKn+hNQQ==", - "requires": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-module-imports": "^7.18.6", - "@babel/helper-simple-access": "^7.20.2", - "@babel/helper-split-export-declaration": "^7.18.6", - "@babel/helper-validator-identifier": "^7.19.1", - "@babel/template": "^7.20.7", - "@babel/traverse": "^7.21.2", - "@babel/types": "^7.21.2" - } - }, - "@babel/helper-optimise-call-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz", - "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==", - "requires": { - "@babel/types": "^7.18.6" - } - }, - "@babel/helper-plugin-utils": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.20.2.tgz", - "integrity": "sha512-8RvlJG2mj4huQ4pZ+rU9lqKi9ZKiRmuvGuM2HlWmkmgOhbs6zEAw6IEiJ5cQqGbDzGZOhwuOQNtZMi/ENLjZoQ==" - }, - "@babel/helper-remap-async-to-generator": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz", - "integrity": "sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==", - "peer": true, - "requires": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-wrap-function": "^7.18.9", - "@babel/types": "^7.18.9" - } - }, - "@babel/helper-replace-supers": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.20.7.tgz", - "integrity": "sha512-vujDMtB6LVfNW13jhlCrp48QNslK6JXi7lQG736HVbHz/mbf4Dc7tIRh1Xf5C0rF7BP8iiSxGMCmY6Ci1ven3A==", - "requires": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-member-expression-to-functions": "^7.20.7", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/template": "^7.20.7", - "@babel/traverse": "^7.20.7", - "@babel/types": "^7.20.7" - } - }, - "@babel/helper-simple-access": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz", - "integrity": "sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==", - "requires": { - "@babel/types": "^7.20.2" - } - }, - "@babel/helper-skip-transparent-expression-wrappers": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz", - "integrity": "sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==", - "requires": { - "@babel/types": "^7.20.0" - } - }, - "@babel/helper-split-export-declaration": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", - "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", - "requires": { - "@babel/types": "^7.18.6" - } - }, - "@babel/helper-string-parser": { - "version": "7.19.4", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.19.4.tgz", - "integrity": "sha512-nHtDoQcuqFmwYNYPz3Rah5ph2p8PFeFCsZk9A/48dPc/rGocJ5J3hAAZ7pb76VWX3fZKu+uEr/FhH5jLx7umrw==" - }, - "@babel/helper-validator-identifier": { - "version": "7.19.1", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", - "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==" - }, - "@babel/helper-validator-option": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.21.0.tgz", - "integrity": "sha512-rmL/B8/f0mKS2baE9ZpyTcTavvEuWhTTW8amjzXNvYG4AwBsqTLikfXsEofsJEfKHf+HQVQbFOHy6o+4cnC/fQ==" - }, - "@babel/helper-wrap-function": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.20.5.tgz", - "integrity": "sha512-bYMxIWK5mh+TgXGVqAtnu5Yn1un+v8DDZtqyzKRLUzrh70Eal2O3aZ7aPYiMADO4uKlkzOiRiZ6GX5q3qxvW9Q==", - "peer": true, - "requires": { - "@babel/helper-function-name": "^7.19.0", - "@babel/template": "^7.18.10", - "@babel/traverse": "^7.20.5", - "@babel/types": "^7.20.5" - } - }, - "@babel/helpers": { - "version": "7.20.13", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.20.13.tgz", - "integrity": "sha512-nzJ0DWCL3gB5RCXbUO3KIMMsBY2Eqbx8mBpKGE/02PgyRQFcPQLbkQ1vyy596mZLaP+dAfD+R4ckASzNVmW3jg==", - "requires": { - "@babel/template": "^7.20.7", - "@babel/traverse": "^7.20.13", - "@babel/types": "^7.20.7" - } - }, - "@babel/highlight": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", - "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", - "requires": { - "@babel/helper-validator-identifier": "^7.18.6", - "chalk": "^2.0.0", - "js-tokens": "^4.0.0" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "requires": { - "color-name": "1.1.3" - } - }, - "color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==" - }, - "escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==" - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==" - }, - "supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "@babel/parser": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.21.2.tgz", - "integrity": "sha512-URpaIJQwEkEC2T9Kn+Ai6Xe/02iNaVCuT/PtoRz3GPVJVDpPd7mLo+VddTbhCRU9TXqW5mSrQfXZyi8kDKOVpQ==" - }, - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz", - "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.20.7.tgz", - "integrity": "sha512-sbr9+wNE5aXMBBFBICk01tt7sBf2Oc9ikRFEcem/ZORup9IMUdNhW7/wVLEbbtlWOsEubJet46mHAL2C8+2jKQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0", - "@babel/plugin-proposal-optional-chaining": "^7.20.7" - } - }, - "@babel/plugin-proposal-async-generator-functions": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.20.7.tgz", - "integrity": "sha512-xMbiLsn/8RK7Wq7VeVytytS2L6qE69bXPB10YCmMdDZbKF4okCqY74pI/jJQ/8U0b/F6NrT2+14b8/P9/3AMGA==", - "peer": true, - "requires": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-remap-async-to-generator": "^7.18.9", - "@babel/plugin-syntax-async-generators": "^7.8.4" - } - }, - "@babel/plugin-proposal-class-properties": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz", - "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==", - "requires": { - "@babel/helper-create-class-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-proposal-class-static-block": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.21.0.tgz", - "integrity": "sha512-XP5G9MWNUskFuP30IfFSEFB0Z6HzLIUcjYM4bYOPHXl7eiJ9HFv8tWj6TXTN5QODiEhDZAeI4hLok2iHFFV4hw==", - "peer": true, - "requires": { - "@babel/helper-create-class-features-plugin": "^7.21.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-class-static-block": "^7.14.5" - } - }, - "@babel/plugin-proposal-dynamic-import": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz", - "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-dynamic-import": "^7.8.3" - } - }, - "@babel/plugin-proposal-export-namespace-from": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz", - "integrity": "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.9", - "@babel/plugin-syntax-export-namespace-from": "^7.8.3" - } - }, - "@babel/plugin-proposal-json-strings": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz", - "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-json-strings": "^7.8.3" - } - }, - "@babel/plugin-proposal-logical-assignment-operators": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.20.7.tgz", - "integrity": "sha512-y7C7cZgpMIjWlKE5T7eJwp+tnRYM89HmRvWM5EQuB5BoHEONjmQ8lSNmBUwOyy/GFRsohJED51YBF79hE1djug==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" - } - }, - "@babel/plugin-proposal-nullish-coalescing-operator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz", - "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==", - "requires": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" - } - }, - "@babel/plugin-proposal-numeric-separator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz", - "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-numeric-separator": "^7.10.4" - } - }, - "@babel/plugin-proposal-object-rest-spread": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.20.7.tgz", - "integrity": "sha512-d2S98yCiLxDVmBmE8UjGcfPvNEUbA1U5q5WxaWFUGRzJSVAZqm5W6MbPct0jxnegUZ0niLeNX+IOzEs7wYg9Dg==", - "peer": true, - "requires": { - "@babel/compat-data": "^7.20.5", - "@babel/helper-compilation-targets": "^7.20.7", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-transform-parameters": "^7.20.7" - } - }, - "@babel/plugin-proposal-optional-catch-binding": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz", - "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" - } - }, - "@babel/plugin-proposal-optional-chaining": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.21.0.tgz", - "integrity": "sha512-p4zeefM72gpmEe2fkUr/OnOXpWEf8nAgk7ZYVqqfFiyIG7oFfVZcCrU64hWn5xp4tQ9LkV4bTIa5rD0KANpKNA==", - "requires": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0", - "@babel/plugin-syntax-optional-chaining": "^7.8.3" - } - }, - "@babel/plugin-proposal-private-methods": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz", - "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==", - "peer": true, - "requires": { - "@babel/helper-create-class-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-proposal-private-property-in-object": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.21.0.tgz", - "integrity": "sha512-ha4zfehbJjc5MmXBlHec1igel5TJXXLDDRbuJ4+XT2TJcyD9/V1919BA8gMvsdHcNMBy4WBUBiRb3nw/EQUtBw==", - "peer": true, - "requires": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-create-class-features-plugin": "^7.21.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-private-property-in-object": "^7.14.5" - } - }, - "@babel/plugin-proposal-unicode-property-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz", - "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==", - "peer": true, - "requires": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-syntax-async-generators": { - "version": "7.8.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", - "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", - "requires": { - "@babel/helper-plugin-utils": "^7.8.0" - } - }, - "@babel/plugin-syntax-bigint": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", - "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.8.0" - } - }, - "@babel/plugin-syntax-class-properties": { - "version": "7.12.13", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", - "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", - "requires": { - "@babel/helper-plugin-utils": "^7.12.13" - } - }, - "@babel/plugin-syntax-class-static-block": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", - "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.14.5" - } - }, - "@babel/plugin-syntax-dynamic-import": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", - "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.8.0" - } - }, - "@babel/plugin-syntax-export-namespace-from": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", - "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.8.3" - } - }, - "@babel/plugin-syntax-flow": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.18.6.tgz", - "integrity": "sha512-LUbR+KNTBWCUAqRG9ex5Gnzu2IOkt8jRJbHHXFT9q+L9zm7M/QQbEqXyw1n1pohYvOyWC8CjeyjrSaIwiYjK7A==", - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-syntax-import-assertions": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz", - "integrity": "sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.19.0" - } - }, - "@babel/plugin-syntax-import-meta": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", - "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.10.4" - } - }, - "@babel/plugin-syntax-json-strings": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", - "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", - "requires": { - "@babel/helper-plugin-utils": "^7.8.0" - } - }, - "@babel/plugin-syntax-jsx": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz", - "integrity": "sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-syntax-logical-assignment-operators": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", - "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", - "requires": { - "@babel/helper-plugin-utils": "^7.10.4" - } - }, - "@babel/plugin-syntax-nullish-coalescing-operator": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", - "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", - "requires": { - "@babel/helper-plugin-utils": "^7.8.0" - } - }, - "@babel/plugin-syntax-numeric-separator": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", - "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", - "requires": { - "@babel/helper-plugin-utils": "^7.10.4" - } - }, - "@babel/plugin-syntax-object-rest-spread": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", - "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", - "requires": { - "@babel/helper-plugin-utils": "^7.8.0" - } - }, - "@babel/plugin-syntax-optional-catch-binding": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", - "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", - "requires": { - "@babel/helper-plugin-utils": "^7.8.0" - } - }, - "@babel/plugin-syntax-optional-chaining": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", - "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", - "requires": { - "@babel/helper-plugin-utils": "^7.8.0" - } - }, - "@babel/plugin-syntax-private-property-in-object": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", - "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.14.5" - } - }, - "@babel/plugin-syntax-top-level-await": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", - "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", - "requires": { - "@babel/helper-plugin-utils": "^7.14.5" - } - }, - "@babel/plugin-syntax-typescript": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.20.0.tgz", - "integrity": "sha512-rd9TkG+u1CExzS4SM1BlMEhMXwFLKVjOAFFCDx9PbX5ycJWDoWMcwdJH9RhkPu1dOgn5TrxLot/Gx6lWFuAUNQ==", - "requires": { - "@babel/helper-plugin-utils": "^7.19.0" - } - }, - "@babel/plugin-transform-arrow-functions": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.20.7.tgz", - "integrity": "sha512-3poA5E7dzDomxj9WXWwuD6A5F3kc7VXwIJO+E+J8qtDtS+pXPAhrgEyh+9GBwBgPq1Z+bB+/JD60lp5jsN7JPQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2" - } - }, - "@babel/plugin-transform-async-to-generator": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.20.7.tgz", - "integrity": "sha512-Uo5gwHPT9vgnSXQxqGtpdufUiWp96gk7yiP4Mp5bm1QMkEmLXBO7PAGYbKoJ6DhAwiNkcHFBol/x5zZZkL/t0Q==", - "peer": true, - "requires": { - "@babel/helper-module-imports": "^7.18.6", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-remap-async-to-generator": "^7.18.9" - } - }, - "@babel/plugin-transform-block-scoped-functions": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz", - "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-block-scoping": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.21.0.tgz", - "integrity": "sha512-Mdrbunoh9SxwFZapeHVrwFmri16+oYotcZysSzhNIVDwIAb1UV+kvnxULSYq9J3/q5MDG+4X6w8QVgD1zhBXNQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2" - } - }, - "@babel/plugin-transform-classes": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.21.0.tgz", - "integrity": "sha512-RZhbYTCEUAe6ntPehC4hlslPWosNHDox+vAs4On/mCLRLfoDVHf6hVEd7kuxr1RnHwJmxFfUM3cZiZRmPxJPXQ==", - "peer": true, - "requires": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-compilation-targets": "^7.20.7", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.21.0", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-replace-supers": "^7.20.7", - "@babel/helper-split-export-declaration": "^7.18.6", - "globals": "^11.1.0" - } - }, - "@babel/plugin-transform-computed-properties": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.20.7.tgz", - "integrity": "sha512-Lz7MvBK6DTjElHAmfu6bfANzKcxpyNPeYBGEafyA6E5HtRpjpZwU+u7Qrgz/2OR0z+5TvKYbPdphfSaAcZBrYQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/template": "^7.20.7" - } - }, - "@babel/plugin-transform-destructuring": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.20.7.tgz", - "integrity": "sha512-Xwg403sRrZb81IVB79ZPqNQME23yhugYVqgTxAhT99h485F4f+GMELFhhOsscDUB7HCswepKeCKLn/GZvUKoBA==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2" - } - }, - "@babel/plugin-transform-dotall-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz", - "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==", - "peer": true, - "requires": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-duplicate-keys": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz", - "integrity": "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.9" - } - }, - "@babel/plugin-transform-exponentiation-operator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz", - "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==", - "peer": true, - "requires": { - "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-flow-strip-types": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.21.0.tgz", - "integrity": "sha512-FlFA2Mj87a6sDkW4gfGrQQqwY/dLlBAyJa2dJEZ+FHXUVHBflO2wyKvg+OOEzXfrKYIa4HWl0mgmbCzt0cMb7w==", - "requires": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-flow": "^7.18.6" - } - }, - "@babel/plugin-transform-for-of": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.21.0.tgz", - "integrity": "sha512-LlUYlydgDkKpIY7mcBWvyPPmMcOphEyYA27Ef4xpbh1IiDNLr0kZsos2nf92vz3IccvJI25QUwp86Eo5s6HmBQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2" - } - }, - "@babel/plugin-transform-function-name": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz", - "integrity": "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==", - "peer": true, - "requires": { - "@babel/helper-compilation-targets": "^7.18.9", - "@babel/helper-function-name": "^7.18.9", - "@babel/helper-plugin-utils": "^7.18.9" - } - }, - "@babel/plugin-transform-literals": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz", - "integrity": "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.9" - } - }, - "@babel/plugin-transform-member-expression-literals": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz", - "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-modules-amd": { - "version": "7.20.11", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.20.11.tgz", - "integrity": "sha512-NuzCt5IIYOW0O30UvqktzHYR2ud5bOWbY0yaxWZ6G+aFzOMJvrs5YHNikrbdaT15+KNO31nPOy5Fim3ku6Zb5g==", - "peer": true, - "requires": { - "@babel/helper-module-transforms": "^7.20.11", - "@babel/helper-plugin-utils": "^7.20.2" - } - }, - "@babel/plugin-transform-modules-commonjs": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.21.2.tgz", - "integrity": "sha512-Cln+Yy04Gxua7iPdj6nOV96smLGjpElir5YwzF0LBPKoPlLDNJePNlrGGaybAJkd0zKRnOVXOgizSqPYMNYkzA==", - "requires": { - "@babel/helper-module-transforms": "^7.21.2", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-simple-access": "^7.20.2" - } - }, - "@babel/plugin-transform-modules-systemjs": { - "version": "7.20.11", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.20.11.tgz", - "integrity": "sha512-vVu5g9BPQKSFEmvt2TA4Da5N+QVS66EX21d8uoOihC+OCpUoGvzVsXeqFdtAEfVa5BILAeFt+U7yVmLbQnAJmw==", - "peer": true, - "requires": { - "@babel/helper-hoist-variables": "^7.18.6", - "@babel/helper-module-transforms": "^7.20.11", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-validator-identifier": "^7.19.1" - } - }, - "@babel/plugin-transform-modules-umd": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz", - "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==", - "peer": true, - "requires": { - "@babel/helper-module-transforms": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-named-capturing-groups-regex": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.20.5.tgz", - "integrity": "sha512-mOW4tTzi5iTLnw+78iEq3gr8Aoq4WNRGpmSlrogqaiCBoR1HFhpU4JkpQFOHfeYx3ReVIFWOQJS4aZBRvuZ6mA==", - "peer": true, - "requires": { - "@babel/helper-create-regexp-features-plugin": "^7.20.5", - "@babel/helper-plugin-utils": "^7.20.2" - } - }, - "@babel/plugin-transform-new-target": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz", - "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-object-super": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz", - "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/helper-replace-supers": "^7.18.6" - } - }, - "@babel/plugin-transform-parameters": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.20.7.tgz", - "integrity": "sha512-WiWBIkeHKVOSYPO0pWkxGPfKeWrCJyD3NJ53+Lrp/QMSZbsVPovrVl2aWZ19D/LTVnaDv5Ap7GJ/B2CTOZdrfA==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2" - } - }, - "@babel/plugin-transform-property-literals": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz", - "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-regenerator": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.20.5.tgz", - "integrity": "sha512-kW/oO7HPBtntbsahzQ0qSE3tFvkFwnbozz3NWFhLGqH75vLEg+sCGngLlhVkePlCs3Jv0dBBHDzCHxNiFAQKCQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2", - "regenerator-transform": "^0.15.1" - } - }, - "@babel/plugin-transform-reserved-words": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz", - "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-shorthand-properties": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz", - "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-spread": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.20.7.tgz", - "integrity": "sha512-ewBbHQ+1U/VnH1fxltbJqDeWBU1oNLG8Dj11uIv3xVf7nrQu0bPGe5Rf716r7K5Qz+SqtAOVswoVunoiBtGhxw==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0" - } - }, - "@babel/plugin-transform-sticky-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz", - "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/plugin-transform-template-literals": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz", - "integrity": "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.9" - } - }, - "@babel/plugin-transform-typeof-symbol": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz", - "integrity": "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.9" - } - }, - "@babel/plugin-transform-typescript": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.21.0.tgz", - "integrity": "sha512-xo///XTPp3mDzTtrqXoBlK9eiAYW3wv9JXglcn/u1bi60RW11dEUxIgA8cbnDhutS1zacjMRmAwxE0gMklLnZg==", - "requires": { - "@babel/helper-create-class-features-plugin": "^7.21.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-typescript": "^7.20.0" - } - }, - "@babel/plugin-transform-unicode-escapes": { - "version": "7.18.10", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.10.tgz", - "integrity": "sha512-kKAdAI+YzPgGY/ftStBFXTI1LZFju38rYThnfMykS+IXy8BVx+res7s2fxf1l8I35DV2T97ezo6+SGrXz6B3iQ==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.18.9" - } - }, - "@babel/plugin-transform-unicode-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz", - "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==", - "peer": true, - "requires": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - } - }, - "@babel/preset-env": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.20.2.tgz", - "integrity": "sha512-1G0efQEWR1EHkKvKHqbG+IN/QdgwfByUpM5V5QroDzGV2t3S/WXNQd693cHiHTlCFMpr9B6FkPFXDA2lQcKoDg==", - "peer": true, - "requires": { - "@babel/compat-data": "^7.20.1", - "@babel/helper-compilation-targets": "^7.20.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-validator-option": "^7.18.6", - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6", - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.9", - "@babel/plugin-proposal-async-generator-functions": "^7.20.1", - "@babel/plugin-proposal-class-properties": "^7.18.6", - "@babel/plugin-proposal-class-static-block": "^7.18.6", - "@babel/plugin-proposal-dynamic-import": "^7.18.6", - "@babel/plugin-proposal-export-namespace-from": "^7.18.9", - "@babel/plugin-proposal-json-strings": "^7.18.6", - "@babel/plugin-proposal-logical-assignment-operators": "^7.18.9", - "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6", - "@babel/plugin-proposal-numeric-separator": "^7.18.6", - "@babel/plugin-proposal-object-rest-spread": "^7.20.2", - "@babel/plugin-proposal-optional-catch-binding": "^7.18.6", - "@babel/plugin-proposal-optional-chaining": "^7.18.9", - "@babel/plugin-proposal-private-methods": "^7.18.6", - "@babel/plugin-proposal-private-property-in-object": "^7.18.6", - "@babel/plugin-proposal-unicode-property-regex": "^7.18.6", - "@babel/plugin-syntax-async-generators": "^7.8.4", - "@babel/plugin-syntax-class-properties": "^7.12.13", - "@babel/plugin-syntax-class-static-block": "^7.14.5", - "@babel/plugin-syntax-dynamic-import": "^7.8.3", - "@babel/plugin-syntax-export-namespace-from": "^7.8.3", - "@babel/plugin-syntax-import-assertions": "^7.20.0", - "@babel/plugin-syntax-json-strings": "^7.8.3", - "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", - "@babel/plugin-syntax-numeric-separator": "^7.10.4", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", - "@babel/plugin-syntax-optional-chaining": "^7.8.3", - "@babel/plugin-syntax-private-property-in-object": "^7.14.5", - "@babel/plugin-syntax-top-level-await": "^7.14.5", - "@babel/plugin-transform-arrow-functions": "^7.18.6", - "@babel/plugin-transform-async-to-generator": "^7.18.6", - "@babel/plugin-transform-block-scoped-functions": "^7.18.6", - "@babel/plugin-transform-block-scoping": "^7.20.2", - "@babel/plugin-transform-classes": "^7.20.2", - "@babel/plugin-transform-computed-properties": "^7.18.9", - "@babel/plugin-transform-destructuring": "^7.20.2", - "@babel/plugin-transform-dotall-regex": "^7.18.6", - "@babel/plugin-transform-duplicate-keys": "^7.18.9", - "@babel/plugin-transform-exponentiation-operator": "^7.18.6", - "@babel/plugin-transform-for-of": "^7.18.8", - "@babel/plugin-transform-function-name": "^7.18.9", - "@babel/plugin-transform-literals": "^7.18.9", - "@babel/plugin-transform-member-expression-literals": "^7.18.6", - "@babel/plugin-transform-modules-amd": "^7.19.6", - "@babel/plugin-transform-modules-commonjs": "^7.19.6", - "@babel/plugin-transform-modules-systemjs": "^7.19.6", - "@babel/plugin-transform-modules-umd": "^7.18.6", - "@babel/plugin-transform-named-capturing-groups-regex": "^7.19.1", - "@babel/plugin-transform-new-target": "^7.18.6", - "@babel/plugin-transform-object-super": "^7.18.6", - "@babel/plugin-transform-parameters": "^7.20.1", - "@babel/plugin-transform-property-literals": "^7.18.6", - "@babel/plugin-transform-regenerator": "^7.18.6", - "@babel/plugin-transform-reserved-words": "^7.18.6", - "@babel/plugin-transform-shorthand-properties": "^7.18.6", - "@babel/plugin-transform-spread": "^7.19.0", - "@babel/plugin-transform-sticky-regex": "^7.18.6", - "@babel/plugin-transform-template-literals": "^7.18.9", - "@babel/plugin-transform-typeof-symbol": "^7.18.9", - "@babel/plugin-transform-unicode-escapes": "^7.18.10", - "@babel/plugin-transform-unicode-regex": "^7.18.6", - "@babel/preset-modules": "^0.1.5", - "@babel/types": "^7.20.2", - "babel-plugin-polyfill-corejs2": "^0.3.3", - "babel-plugin-polyfill-corejs3": "^0.6.0", - "babel-plugin-polyfill-regenerator": "^0.4.1", - "core-js-compat": "^3.25.1", - "semver": "^6.3.0" - } - }, - "@babel/preset-flow": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/preset-flow/-/preset-flow-7.18.6.tgz", - "integrity": "sha512-E7BDhL64W6OUqpuyHnSroLnqyRTcG6ZdOBl1OKI/QK/HJfplqK/S3sq1Cckx7oTodJ5yOXyfw7rEADJ6UjoQDQ==", - "requires": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/helper-validator-option": "^7.18.6", - "@babel/plugin-transform-flow-strip-types": "^7.18.6" - } - }, - "@babel/preset-modules": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz", - "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==", - "peer": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", - "@babel/plugin-transform-dotall-regex": "^7.4.4", - "@babel/types": "^7.4.4", - "esutils": "^2.0.2" - } - }, - "@babel/preset-typescript": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.21.0.tgz", - "integrity": "sha512-myc9mpoVA5m1rF8K8DgLEatOYFDpwC+RkMkjZ0Du6uI62YvDe8uxIEYVs/VCdSJ097nlALiU/yBC7//3nI+hNg==", - "requires": { - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-validator-option": "^7.21.0", - "@babel/plugin-transform-typescript": "^7.21.0" - } - }, - "@babel/register": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/register/-/register-7.21.0.tgz", - "integrity": "sha512-9nKsPmYDi5DidAqJaQooxIhsLJiNMkGr8ypQ8Uic7cIox7UCDsM7HuUGxdGT7mSDTYbqzIdsOWzfBton/YJrMw==", - "requires": { - "clone-deep": "^4.0.1", - "find-cache-dir": "^2.0.0", - "make-dir": "^2.1.0", - "pirates": "^4.0.5", - "source-map-support": "^0.5.16" - }, - "dependencies": { - "make-dir": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", - "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", - "requires": { - "pify": "^4.0.1", - "semver": "^5.6.0" - } - }, - "semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" - }, - "source-map-support": { - "version": "0.5.21", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", - "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", - "requires": { - "buffer-from": "^1.0.0", - "source-map": "^0.6.0" - } - } - } - }, - "@babel/regjsgen": { - "version": "0.8.0", - "resolved": "https://registry.npmjs.org/@babel/regjsgen/-/regjsgen-0.8.0.tgz", - "integrity": "sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA==", - "peer": true - }, - "@babel/runtime": { - "version": "7.21.0", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.21.0.tgz", - "integrity": "sha512-xwII0//EObnq89Ji5AKYQaRYiW/nZ3llSv29d49IuxPhKbtJoLP+9QUUZ4nVragQVtaVGeZrpB+ZtG/Pdy/POw==", - "peer": true, - "requires": { - "regenerator-runtime": "^0.13.11" - } - }, - "@babel/template": { - "version": "7.20.7", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.20.7.tgz", - "integrity": "sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==", - "requires": { - "@babel/code-frame": "^7.18.6", - "@babel/parser": "^7.20.7", - "@babel/types": "^7.20.7" - } - }, - "@babel/traverse": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.21.2.tgz", - "integrity": "sha512-ts5FFU/dSUPS13tv8XiEObDu9K+iagEKME9kAbaP7r0Y9KtZJZ+NGndDvWoRAYNpeWafbpFeki3q9QoMD6gxyw==", - "requires": { - "@babel/code-frame": "^7.18.6", - "@babel/generator": "^7.21.1", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.21.0", - "@babel/helper-hoist-variables": "^7.18.6", - "@babel/helper-split-export-declaration": "^7.18.6", - "@babel/parser": "^7.21.2", - "@babel/types": "^7.21.2", - "debug": "^4.1.0", - "globals": "^11.1.0" - } - }, - "@babel/types": { - "version": "7.21.2", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.21.2.tgz", - "integrity": "sha512-3wRZSs7jiFaB8AjxiiD+VqN5DTG2iRvJGQ+qYFrs/654lg6kGTQWIOFjlBo5RaXuAZjBmP3+OQH4dmhqiiyYxw==", - "requires": { - "@babel/helper-string-parser": "^7.19.4", - "@babel/helper-validator-identifier": "^7.19.1", - "to-fast-properties": "^2.0.0" - } - }, - "@bcoe/v8-coverage": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", - "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", - "dev": true - }, - "@istanbuljs/load-nyc-config": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", - "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", - "dev": true, - "requires": { - "camelcase": "^5.3.1", - "find-up": "^4.1.0", - "get-package-type": "^0.1.0", - "js-yaml": "^3.13.1", - "resolve-from": "^5.0.0" - } - }, - "@istanbuljs/schema": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", - "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", - "dev": true - }, - "@jest/console": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.4.3.tgz", - "integrity": "sha512-W/o/34+wQuXlgqlPYTansOSiBnuxrTv61dEVkA6HNmpcgHLUjfaUbdqt6oVvOzaawwo9IdW9QOtMgQ1ScSZC4A==", - "dev": true, - "requires": { - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "jest-message-util": "^29.4.3", - "jest-util": "^29.4.3", - "slash": "^3.0.0" - } - }, - "@jest/core": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.4.3.tgz", - "integrity": "sha512-56QvBq60fS4SPZCuM7T+7scNrkGIe7Mr6PVIXUpu48ouvRaWOFqRPV91eifvFM0ay2HmfswXiGf97NGUN5KofQ==", - "dev": true, - "requires": { - "@jest/console": "^29.4.3", - "@jest/reporters": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "jest-changed-files": "^29.4.3", - "jest-config": "^29.4.3", - "jest-haste-map": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-regex-util": "^29.4.3", - "jest-resolve": "^29.4.3", - "jest-resolve-dependencies": "^29.4.3", - "jest-runner": "^29.4.3", - "jest-runtime": "^29.4.3", - "jest-snapshot": "^29.4.3", - "jest-util": "^29.4.3", - "jest-validate": "^29.4.3", - "jest-watcher": "^29.4.3", - "micromatch": "^4.0.4", - "pretty-format": "^29.4.3", - "slash": "^3.0.0", - "strip-ansi": "^6.0.0" - } - }, - "@jest/environment": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.4.3.tgz", - "integrity": "sha512-dq5S6408IxIa+lr54zeqce+QgI+CJT4nmmA+1yzFgtcsGK8c/EyiUb9XQOgz3BMKrRDfKseeOaxj2eO8LlD3lA==", - "dev": true, - "requires": { - "@jest/fake-timers": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "jest-mock": "^29.4.3" - } - }, - "@jest/expect": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.4.3.tgz", - "integrity": "sha512-iktRU/YsxEtumI9zsPctYUk7ptpC+AVLLk1Ax3AsA4g1C+8OOnKDkIQBDHtD5hA/+VtgMd5AWI5gNlcAlt2vxQ==", - "dev": true, - "requires": { - "expect": "^29.4.3", - "jest-snapshot": "^29.4.3" - } - }, - "@jest/expect-utils": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.4.3.tgz", - "integrity": "sha512-/6JWbkxHOP8EoS8jeeTd9dTfc9Uawi+43oLKHfp6zzux3U2hqOOVnV3ai4RpDYHOccL6g+5nrxpoc8DmJxtXVQ==", - "dev": true, - "requires": { - "jest-get-type": "^29.4.3" - } - }, - "@jest/fake-timers": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.4.3.tgz", - "integrity": "sha512-4Hote2MGcCTWSD2gwl0dwbCpBRHhE6olYEuTj8FMowdg3oQWNKr2YuxenPQYZ7+PfqPY1k98wKDU4Z+Hvd4Tiw==", - "dev": true, - "requires": { - "@jest/types": "^29.4.3", - "@sinonjs/fake-timers": "^10.0.2", - "@types/node": "*", - "jest-message-util": "^29.4.3", - "jest-mock": "^29.4.3", - "jest-util": "^29.4.3" - } - }, - "@jest/globals": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.4.3.tgz", - "integrity": "sha512-8BQ/5EzfOLG7AaMcDh7yFCbfRLtsc+09E1RQmRBI4D6QQk4m6NSK/MXo+3bJrBN0yU8A2/VIcqhvsOLFmziioA==", - "dev": true, - "requires": { - "@jest/environment": "^29.4.3", - "@jest/expect": "^29.4.3", - "@jest/types": "^29.4.3", - "jest-mock": "^29.4.3" - } - }, - "@jest/reporters": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.4.3.tgz", - "integrity": "sha512-sr2I7BmOjJhyqj9ANC6CTLsL4emMoka7HkQpcoMRlhCbQJjz2zsRzw0BDPiPyEFDXAbxKgGFYuQZiSJ1Y6YoTg==", - "dev": true, - "requires": { - "@bcoe/v8-coverage": "^0.2.3", - "@jest/console": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@jridgewell/trace-mapping": "^0.3.15", - "@types/node": "*", - "chalk": "^4.0.0", - "collect-v8-coverage": "^1.0.0", - "exit": "^0.1.2", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "istanbul-lib-coverage": "^3.0.0", - "istanbul-lib-instrument": "^5.1.0", - "istanbul-lib-report": "^3.0.0", - "istanbul-lib-source-maps": "^4.0.0", - "istanbul-reports": "^3.1.3", - "jest-message-util": "^29.4.3", - "jest-util": "^29.4.3", - "jest-worker": "^29.4.3", - "slash": "^3.0.0", - "string-length": "^4.0.1", - "strip-ansi": "^6.0.0", - "v8-to-istanbul": "^9.0.1" - } - }, - "@jest/schemas": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.4.3.tgz", - "integrity": "sha512-VLYKXQmtmuEz6IxJsrZwzG9NvtkQsWNnWMsKxqWNu3+CnfzJQhp0WDDKWLVV9hLKr0l3SLLFRqcYHjhtyuDVxg==", - "dev": true, - "requires": { - "@sinclair/typebox": "^0.25.16" - } - }, - "@jest/source-map": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.4.3.tgz", - "integrity": "sha512-qyt/mb6rLyd9j1jUts4EQncvS6Yy3PM9HghnNv86QBlV+zdL2inCdK1tuVlL+J+lpiw2BI67qXOrX3UurBqQ1w==", - "dev": true, - "requires": { - "@jridgewell/trace-mapping": "^0.3.15", - "callsites": "^3.0.0", - "graceful-fs": "^4.2.9" - } - }, - "@jest/test-result": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.4.3.tgz", - "integrity": "sha512-Oi4u9NfBolMq9MASPwuWTlC5WvmNRwI4S8YrQg5R5Gi47DYlBe3sh7ILTqi/LGrK1XUE4XY9KZcQJTH1WJCLLA==", - "dev": true, - "requires": { - "@jest/console": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/istanbul-lib-coverage": "^2.0.0", - "collect-v8-coverage": "^1.0.0" - } - }, - "@jest/test-sequencer": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.4.3.tgz", - "integrity": "sha512-yi/t2nES4GB4G0mjLc0RInCq/cNr9dNwJxcGg8sslajua5Kb4kmozAc+qPLzplhBgfw1vLItbjyHzUN92UXicw==", - "dev": true, - "requires": { - "@jest/test-result": "^29.4.3", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.4.3", - "slash": "^3.0.0" - } - }, - "@jest/transform": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.4.3.tgz", - "integrity": "sha512-8u0+fBGWolDshsFgPQJESkDa72da/EVwvL+II0trN2DR66wMwiQ9/CihaGfHdlLGFzbBZwMykFtxuwFdZqlKwg==", - "dev": true, - "requires": { - "@babel/core": "^7.11.6", - "@jest/types": "^29.4.3", - "@jridgewell/trace-mapping": "^0.3.15", - "babel-plugin-istanbul": "^6.1.1", - "chalk": "^4.0.0", - "convert-source-map": "^2.0.0", - "fast-json-stable-stringify": "^2.1.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.4.3", - "jest-regex-util": "^29.4.3", - "jest-util": "^29.4.3", - "micromatch": "^4.0.4", - "pirates": "^4.0.4", - "slash": "^3.0.0", - "write-file-atomic": "^4.0.2" - } - }, - "@jest/types": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.4.3.tgz", - "integrity": "sha512-bPYfw8V65v17m2Od1cv44FH+SiKW7w2Xu7trhcdTLUmSv85rfKsP+qXSjO4KGJr4dtPSzl/gvslZBXctf1qGEA==", - "dev": true, - "requires": { - "@jest/schemas": "^29.4.3", - "@types/istanbul-lib-coverage": "^2.0.0", - "@types/istanbul-reports": "^3.0.0", - "@types/node": "*", - "@types/yargs": "^17.0.8", - "chalk": "^4.0.0" - } - }, - "@jridgewell/gen-mapping": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", - "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==", - "requires": { - "@jridgewell/set-array": "^1.0.0", - "@jridgewell/sourcemap-codec": "^1.4.10" - } - }, - "@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==" - }, - "@jridgewell/set-array": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==" - }, - "@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" - }, - "@jridgewell/trace-mapping": { - "version": "0.3.17", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz", - "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==", - "requires": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" - } - }, - "@sinclair/typebox": { - "version": "0.25.23", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.25.23.tgz", - "integrity": "sha512-VEB8ygeP42CFLWyAJhN5OklpxUliqdNEUcXb4xZ/CINqtYGTjL5ukluKdKzQ0iWdUxyQ7B0539PAUhHKrCNWSQ==", - "dev": true - }, - "@sinonjs/commons": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-2.0.0.tgz", - "integrity": "sha512-uLa0j859mMrg2slwQYdO/AkrOfmH+X6LTVmNTS9CqexuE2IvVORIkSpJLqePAbEnKJ77aMmCwr1NUZ57120Xcg==", - "dev": true, - "requires": { - "type-detect": "4.0.8" - } - }, - "@sinonjs/fake-timers": { - "version": "10.0.2", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.0.2.tgz", - "integrity": "sha512-SwUDyjWnah1AaNl7kxsa7cfLhlTYoiyhDAIgyh+El30YvXs/o7OLXpYH88Zdhyx9JExKrmHDJ+10bwIcY80Jmw==", - "dev": true, - "requires": { - "@sinonjs/commons": "^2.0.0" - } - }, - "@types/babel__core": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.0.tgz", - "integrity": "sha512-+n8dL/9GWblDO0iU6eZAwEIJVr5DWigtle+Q6HLOrh/pdbXOhOtqzq8VPPE2zvNJzSKY4vH/z3iT3tn0A3ypiQ==", - "dev": true, - "requires": { - "@babel/parser": "^7.20.7", - "@babel/types": "^7.20.7", - "@types/babel__generator": "*", - "@types/babel__template": "*", - "@types/babel__traverse": "*" - } - }, - "@types/babel__generator": { - "version": "7.6.4", - "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", - "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", - "dev": true, - "requires": { - "@babel/types": "^7.0.0" - } - }, - "@types/babel__template": { - "version": "7.4.1", - "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", - "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", - "dev": true, - "requires": { - "@babel/parser": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@types/babel__traverse": { - "version": "7.18.3", - "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.18.3.tgz", - "integrity": "sha512-1kbcJ40lLB7MHsj39U4Sh1uTd2E7rLEa79kmDpI6cy+XiXsteB3POdQomoq4FxszMrO3ZYchkhYJw7A2862b3w==", - "dev": true, - "requires": { - "@babel/types": "^7.3.0" - } - }, - "@types/graceful-fs": { - "version": "4.1.6", - "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.6.tgz", - "integrity": "sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw==", - "dev": true, - "requires": { - "@types/node": "*" - } - }, - "@types/istanbul-lib-coverage": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", - "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", - "dev": true - }, - "@types/istanbul-lib-report": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", - "dev": true, - "requires": { - "@types/istanbul-lib-coverage": "*" - } - }, - "@types/istanbul-reports": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", - "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", - "dev": true, - "requires": { - "@types/istanbul-lib-report": "*" - } - }, - "@types/jscodeshift": { - "version": "0.11.6", - "resolved": "https://registry.npmjs.org/@types/jscodeshift/-/jscodeshift-0.11.6.tgz", - "integrity": "sha512-3lJ4DajWkk4MZ1F7q+1C7jE0z0xOtbu0VU/Kg3wdPq2DUvJjySSlu3B5Q/bICrTxugLhONBO7inRUWsymOID/A==", - "dev": true, - "requires": { - "ast-types": "^0.14.1", - "recast": "^0.20.3" - } - }, - "@types/node": { - "version": "18.14.0", - "resolved": "https://registry.npmjs.org/@types/node/-/node-18.14.0.tgz", - "integrity": "sha512-5EWrvLmglK+imbCJY0+INViFWUHg1AHel1sq4ZVSfdcNqGy9Edv3UB9IIzzg+xPaUcAgZYcfVs2fBcwDeZzU0A==", - "dev": true - }, - "@types/prettier": { - "version": "2.7.2", - "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.7.2.tgz", - "integrity": "sha512-KufADq8uQqo1pYKVIYzfKbJfBAc0sOeXqGbFaSpv8MRmC/zXgowNZmFcbngndGk922QDmOASEXUZCaY48gs4cg==", - "dev": true - }, - "@types/stack-utils": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", - "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", - "dev": true - }, - "@types/yargs": { - "version": "17.0.22", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.22.tgz", - "integrity": "sha512-pet5WJ9U8yPVRhkwuEIp5ktAeAqRZOq4UdAyWLWzxbtpyXnzbtLdKiXAjJzi/KLmPGS9wk86lUFWZFN6sISo4g==", - "dev": true, - "requires": { - "@types/yargs-parser": "*" - } - }, - "@types/yargs-parser": { - "version": "21.0.0", - "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", - "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==", - "dev": true - }, - "ansi-escapes": { - "version": "4.3.2", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", - "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", - "dev": true, - "requires": { - "type-fest": "^0.21.3" - } - }, - "ansi-regex": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true - }, - "ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "requires": { - "color-convert": "^2.0.1" - } - }, - "anymatch": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", - "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", - "dev": true, - "requires": { - "normalize-path": "^3.0.0", - "picomatch": "^2.0.4" - } - }, - "argparse": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", - "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", - "dev": true, - "requires": { - "sprintf-js": "~1.0.2" - } - }, - "ast-types": { - "version": "0.14.2", - "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.14.2.tgz", - "integrity": "sha512-O0yuUDnZeQDL+ncNGlJ78BiO4jnYI3bvMsD5prT0/nsgijG/LpNBIr63gTjVTNsiGkgQhiyCShTgxt8oXOrklA==", - "dev": true, - "requires": { - "tslib": "^2.0.1" - } - }, - "babel-core": { - "version": "7.0.0-bridge.0", - "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-7.0.0-bridge.0.tgz", - "integrity": "sha512-poPX9mZH/5CSanm50Q+1toVci6pv5KSRv/5TWCwtzQS5XEwn40BcCrgIeMFWP9CKKIniKXNxoIOnOq4VVlGXhg==", - "requires": {} - }, - "babel-jest": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.4.3.tgz", - "integrity": "sha512-o45Wyn32svZE+LnMVWv/Z4x0SwtLbh4FyGcYtR20kIWd+rdrDZ9Fzq8Ml3MYLD+mZvEdzCjZsCnYZ2jpJyQ+Nw==", - "dev": true, - "requires": { - "@jest/transform": "^29.4.3", - "@types/babel__core": "^7.1.14", - "babel-plugin-istanbul": "^6.1.1", - "babel-preset-jest": "^29.4.3", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "slash": "^3.0.0" - } - }, - "babel-plugin-istanbul": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", - "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@istanbuljs/load-nyc-config": "^1.0.0", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-instrument": "^5.0.4", - "test-exclude": "^6.0.0" - } - }, - "babel-plugin-jest-hoist": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.4.3.tgz", - "integrity": "sha512-mB6q2q3oahKphy5V7CpnNqZOCkxxZ9aokf1eh82Dy3jQmg4xvM1tGrh5y6BQUJh4a3Pj9+eLfwvAZ7VNKg7H8Q==", - "dev": true, - "requires": { - "@babel/template": "^7.3.3", - "@babel/types": "^7.3.3", - "@types/babel__core": "^7.1.14", - "@types/babel__traverse": "^7.0.6" - } - }, - "babel-plugin-polyfill-corejs2": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.3.tgz", - "integrity": "sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q==", - "peer": true, - "requires": { - "@babel/compat-data": "^7.17.7", - "@babel/helper-define-polyfill-provider": "^0.3.3", - "semver": "^6.1.1" - } - }, - "babel-plugin-polyfill-corejs3": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.6.0.tgz", - "integrity": "sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA==", - "peer": true, - "requires": { - "@babel/helper-define-polyfill-provider": "^0.3.3", - "core-js-compat": "^3.25.1" - } - }, - "babel-plugin-polyfill-regenerator": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.4.1.tgz", - "integrity": "sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw==", - "peer": true, - "requires": { - "@babel/helper-define-polyfill-provider": "^0.3.3" - } - }, - "babel-preset-current-node-syntax": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", - "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", - "dev": true, - "requires": { - "@babel/plugin-syntax-async-generators": "^7.8.4", - "@babel/plugin-syntax-bigint": "^7.8.3", - "@babel/plugin-syntax-class-properties": "^7.8.3", - "@babel/plugin-syntax-import-meta": "^7.8.3", - "@babel/plugin-syntax-json-strings": "^7.8.3", - "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", - "@babel/plugin-syntax-numeric-separator": "^7.8.3", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", - "@babel/plugin-syntax-optional-chaining": "^7.8.3", - "@babel/plugin-syntax-top-level-await": "^7.8.3" - } - }, - "babel-preset-jest": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.4.3.tgz", - "integrity": "sha512-gWx6COtSuma6n9bw+8/F+2PCXrIgxV/D1TJFnp6OyBK2cxPWg0K9p/sriNYeifKjpUkMViWQ09DSWtzJQRETsw==", - "dev": true, - "requires": { - "babel-plugin-jest-hoist": "^29.4.3", - "babel-preset-current-node-syntax": "^1.0.0" - } - }, - "balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" - }, - "brace-expansion": { - "version": "1.1.11", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", - "requires": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "braces": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", - "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", - "requires": { - "fill-range": "^7.0.1" - } - }, - "browserslist": { - "version": "4.21.5", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.5.tgz", - "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==", - "requires": { - "caniuse-lite": "^1.0.30001449", - "electron-to-chromium": "^1.4.284", - "node-releases": "^2.0.8", - "update-browserslist-db": "^1.0.10" - } - }, - "bser": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", - "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", - "dev": true, - "requires": { - "node-int64": "^0.4.0" - } - }, - "buffer-from": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" - }, - "callsites": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", - "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", - "dev": true - }, - "camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true - }, - "caniuse-lite": { - "version": "1.0.30001457", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001457.tgz", - "integrity": "sha512-SDIV6bgE1aVbK6XyxdURbUE89zY7+k1BBBaOwYwkNCglXlel/E7mELiHC64HQ+W0xSKlqWhV9Wh7iHxUjMs4fA==" - }, - "chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "requires": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - } - }, - "char-regex": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", - "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", - "dev": true - }, - "ci-info": { - "version": "3.8.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz", - "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==", - "dev": true - }, - "cjs-module-lexer": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz", - "integrity": "sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA==", - "dev": true - }, - "cliui": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", - "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", - "dev": true, - "requires": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.1", - "wrap-ansi": "^7.0.0" - } - }, - "clone-deep": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", - "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", - "requires": { - "is-plain-object": "^2.0.4", - "kind-of": "^6.0.2", - "shallow-clone": "^3.0.0" - } - }, - "co": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", - "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", - "dev": true - }, - "collect-v8-coverage": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz", - "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==", - "dev": true - }, - "color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "requires": { - "color-name": "~1.1.4" - } - }, - "color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" - }, - "commondir": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", - "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==" - }, - "concat-map": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" - }, - "convert-source-map": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", - "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", - "dev": true - }, - "core-js-compat": { - "version": "3.28.0", - "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.28.0.tgz", - "integrity": "sha512-myzPgE7QodMg4nnd3K1TDoES/nADRStM8Gpz0D6nhkwbmwEnE0ZGJgoWsvQ722FR8D7xS0n0LV556RcEicjTyg==", - "peer": true, - "requires": { - "browserslist": "^4.21.5" - } - }, - "cross-spawn": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", - "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", - "dev": true, - "requires": { - "path-key": "^3.1.0", - "shebang-command": "^2.0.0", - "which": "^2.0.1" - } - }, - "debug": { - "version": "4.3.4", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", - "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", - "requires": { - "ms": "2.1.2" - } - }, - "dedent": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", - "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", - "dev": true - }, - "deepmerge": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.0.tgz", - "integrity": "sha512-z2wJZXrmeHdvYJp/Ux55wIjqo81G5Bp4c+oELTW+7ar6SogWHajt5a9gO3s3IDaGSAXjDk0vlQKN3rms8ab3og==", - "dev": true - }, - "detect-newline": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", - "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", - "dev": true - }, - "diff-sequences": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.4.3.tgz", - "integrity": "sha512-ofrBgwpPhCD85kMKtE9RYFFq6OC1A89oW2vvgWZNCwxrUpRUILopY7lsYyMDSjc8g6U6aiO0Qubg6r4Wgt5ZnA==", - "dev": true - }, - "electron-to-chromium": { - "version": "1.4.302", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.302.tgz", - "integrity": "sha512-Uk7C+7aPBryUR1Fwvk9VmipBcN9fVsqBO57jV2ZjTm+IZ6BMNqu7EDVEg2HxCNufk6QcWlFsBkhQyQroB2VWKw==" - }, - "emittery": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz", - "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==", - "dev": true - }, - "emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true - }, - "error-ex": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", - "dev": true, - "requires": { - "is-arrayish": "^0.2.1" - } - }, - "escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==" - }, - "escape-string-regexp": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", - "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", - "dev": true - }, - "esprima": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" - }, - "esutils": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", - "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", - "peer": true - }, - "execa": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", - "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", - "dev": true, - "requires": { - "cross-spawn": "^7.0.3", - "get-stream": "^6.0.0", - "human-signals": "^2.1.0", - "is-stream": "^2.0.0", - "merge-stream": "^2.0.0", - "npm-run-path": "^4.0.1", - "onetime": "^5.1.2", - "signal-exit": "^3.0.3", - "strip-final-newline": "^2.0.0" - } - }, - "exit": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", - "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", - "dev": true - }, - "expect": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/expect/-/expect-29.4.3.tgz", - "integrity": "sha512-uC05+Q7eXECFpgDrHdXA4k2rpMyStAYPItEDLyQDo5Ta7fVkJnNA/4zh/OIVkVVNZ1oOK1PipQoyNjuZ6sz6Dg==", - "dev": true, - "requires": { - "@jest/expect-utils": "^29.4.3", - "jest-get-type": "^29.4.3", - "jest-matcher-utils": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-util": "^29.4.3" - } - }, - "fast-json-stable-stringify": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", - "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", - "dev": true - }, - "fb-watchman": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", - "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==", - "dev": true, - "requires": { - "bser": "2.1.1" - } - }, - "fill-range": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", - "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", - "requires": { - "to-regex-range": "^5.0.1" - } - }, - "find-cache-dir": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", - "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", - "requires": { - "commondir": "^1.0.1", - "make-dir": "^2.0.0", - "pkg-dir": "^3.0.0" - }, - "dependencies": { - "find-up": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", - "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", - "requires": { - "locate-path": "^3.0.0" - } - }, - "locate-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", - "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", - "requires": { - "p-locate": "^3.0.0", - "path-exists": "^3.0.0" - } - }, - "make-dir": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", - "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", - "requires": { - "pify": "^4.0.1", - "semver": "^5.6.0" - } - }, - "p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "requires": { - "p-try": "^2.0.0" - } - }, - "p-locate": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", - "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", - "requires": { - "p-limit": "^2.0.0" - } - }, - "path-exists": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", - "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==" - }, - "pkg-dir": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", - "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", - "requires": { - "find-up": "^3.0.0" - } - }, - "semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" - } - } - }, - "find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "dev": true, - "requires": { - "locate-path": "^5.0.0", - "path-exists": "^4.0.0" - } - }, - "flow-parser": { - "version": "0.200.0", - "resolved": "https://registry.npmjs.org/flow-parser/-/flow-parser-0.200.0.tgz", - "integrity": "sha512-01eYYVlCEO2p6JexhTbMbDNPeDKQZV++SJbaHE/HzypTkV83oJmsJQVjVCGD8FYWiQ3ha9ALD/AHwsFhPwnZJA==" - }, - "fs.realpath": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" - }, - "function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" - }, - "gensync": { - "version": "1.0.0-beta.2", - "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", - "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==" - }, - "get-caller-file": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", - "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", - "dev": true - }, - "get-package-type": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", - "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", - "dev": true - }, - "get-stream": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", - "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", - "dev": true - }, - "glob": { - "version": "7.2.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", - "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", - "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.1.1", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - } - }, - "globals": { - "version": "11.12.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==" - }, - "graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==" - }, - "has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "requires": { - "function-bind": "^1.1.1" - } - }, - "has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" - }, - "html-escaper": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", - "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", - "dev": true - }, - "human-signals": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", - "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", - "dev": true - }, - "import-local": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", - "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", - "dev": true, - "requires": { - "pkg-dir": "^4.2.0", - "resolve-cwd": "^3.0.0" - } - }, - "imurmurhash": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", - "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==" - }, - "inflight": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", - "requires": { - "once": "^1.3.0", - "wrappy": "1" - } - }, - "inherits": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", - "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" - }, - "is-arrayish": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", - "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", - "dev": true - }, - "is-core-module": { - "version": "2.11.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", - "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", - "requires": { - "has": "^1.0.3" - } - }, - "is-fullwidth-code-point": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", - "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true - }, - "is-generator-fn": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", - "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", - "dev": true - }, - "is-number": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", - "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" - }, - "is-plain-object": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", - "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", - "requires": { - "isobject": "^3.0.1" - } - }, - "is-stream": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", - "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", - "dev": true - }, - "isexe": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", - "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", - "dev": true - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==" - }, - "istanbul-lib-coverage": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", - "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", - "dev": true - }, - "istanbul-lib-instrument": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", - "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", - "dev": true, - "requires": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-coverage": "^3.2.0", - "semver": "^6.3.0" - } - }, - "istanbul-lib-report": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", - "dev": true, - "requires": { - "istanbul-lib-coverage": "^3.0.0", - "make-dir": "^3.0.0", - "supports-color": "^7.1.0" - } - }, - "istanbul-lib-source-maps": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", - "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", - "dev": true, - "requires": { - "debug": "^4.1.1", - "istanbul-lib-coverage": "^3.0.0", - "source-map": "^0.6.1" - } - }, - "istanbul-reports": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", - "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", - "dev": true, - "requires": { - "html-escaper": "^2.0.0", - "istanbul-lib-report": "^3.0.0" - } - }, - "jest": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest/-/jest-29.4.3.tgz", - "integrity": "sha512-XvK65feuEFGZT8OO0fB/QAQS+LGHvQpaadkH5p47/j3Ocqq3xf2pK9R+G0GzgfuhXVxEv76qCOOcMb5efLk6PA==", - "dev": true, - "requires": { - "@jest/core": "^29.4.3", - "@jest/types": "^29.4.3", - "import-local": "^3.0.2", - "jest-cli": "^29.4.3" - } - }, - "jest-changed-files": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.4.3.tgz", - "integrity": "sha512-Vn5cLuWuwmi2GNNbokPOEcvrXGSGrqVnPEZV7rC6P7ck07Dyw9RFnvWglnupSh+hGys0ajGtw/bc2ZgweljQoQ==", - "dev": true, - "requires": { - "execa": "^5.0.0", - "p-limit": "^3.1.0" - } - }, - "jest-circus": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.4.3.tgz", - "integrity": "sha512-Vw/bVvcexmdJ7MLmgdT3ZjkJ3LKu8IlpefYokxiqoZy6OCQ2VAm6Vk3t/qHiAGUXbdbJKJWnc8gH3ypTbB/OBw==", - "dev": true, - "requires": { - "@jest/environment": "^29.4.3", - "@jest/expect": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "co": "^4.6.0", - "dedent": "^0.7.0", - "is-generator-fn": "^2.0.0", - "jest-each": "^29.4.3", - "jest-matcher-utils": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-runtime": "^29.4.3", - "jest-snapshot": "^29.4.3", - "jest-util": "^29.4.3", - "p-limit": "^3.1.0", - "pretty-format": "^29.4.3", - "slash": "^3.0.0", - "stack-utils": "^2.0.3" - } - }, - "jest-cli": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.4.3.tgz", - "integrity": "sha512-PiiAPuFNfWWolCE6t3ZrDXQc6OsAuM3/tVW0u27UWc1KE+n/HSn5dSE6B2juqN7WP+PP0jAcnKtGmI4u8GMYCg==", - "dev": true, - "requires": { - "@jest/core": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/types": "^29.4.3", - "chalk": "^4.0.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "import-local": "^3.0.2", - "jest-config": "^29.4.3", - "jest-util": "^29.4.3", - "jest-validate": "^29.4.3", - "prompts": "^2.0.1", - "yargs": "^17.3.1" - } - }, - "jest-config": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.4.3.tgz", - "integrity": "sha512-eCIpqhGnIjdUCXGtLhz4gdDoxKSWXKjzNcc5r+0S1GKOp2fwOipx5mRcwa9GB/ArsxJ1jlj2lmlD9bZAsBxaWQ==", - "dev": true, - "requires": { - "@babel/core": "^7.11.6", - "@jest/test-sequencer": "^29.4.3", - "@jest/types": "^29.4.3", - "babel-jest": "^29.4.3", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "deepmerge": "^4.2.2", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-circus": "^29.4.3", - "jest-environment-node": "^29.4.3", - "jest-get-type": "^29.4.3", - "jest-regex-util": "^29.4.3", - "jest-resolve": "^29.4.3", - "jest-runner": "^29.4.3", - "jest-util": "^29.4.3", - "jest-validate": "^29.4.3", - "micromatch": "^4.0.4", - "parse-json": "^5.2.0", - "pretty-format": "^29.4.3", - "slash": "^3.0.0", - "strip-json-comments": "^3.1.1" - } - }, - "jest-diff": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.4.3.tgz", - "integrity": "sha512-YB+ocenx7FZ3T5O9lMVMeLYV4265socJKtkwgk/6YUz/VsEzYDkiMuMhWzZmxm3wDRQvayJu/PjkjjSkjoHsCA==", - "dev": true, - "requires": { - "chalk": "^4.0.0", - "diff-sequences": "^29.4.3", - "jest-get-type": "^29.4.3", - "pretty-format": "^29.4.3" - } - }, - "jest-docblock": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.4.3.tgz", - "integrity": "sha512-fzdTftThczeSD9nZ3fzA/4KkHtnmllawWrXO69vtI+L9WjEIuXWs4AmyME7lN5hU7dB0sHhuPfcKofRsUb/2Fg==", - "dev": true, - "requires": { - "detect-newline": "^3.0.0" - } - }, - "jest-each": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.4.3.tgz", - "integrity": "sha512-1ElHNAnKcbJb/b+L+7j0/w7bDvljw4gTv1wL9fYOczeJrbTbkMGQ5iQPFJ3eFQH19VPTx1IyfePdqSpePKss7Q==", - "dev": true, - "requires": { - "@jest/types": "^29.4.3", - "chalk": "^4.0.0", - "jest-get-type": "^29.4.3", - "jest-util": "^29.4.3", - "pretty-format": "^29.4.3" - } - }, - "jest-environment-node": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.4.3.tgz", - "integrity": "sha512-gAiEnSKF104fsGDXNkwk49jD/0N0Bqu2K9+aMQXA6avzsA9H3Fiv1PW2D+gzbOSR705bWd2wJZRFEFpV0tXISg==", - "dev": true, - "requires": { - "@jest/environment": "^29.4.3", - "@jest/fake-timers": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "jest-mock": "^29.4.3", - "jest-util": "^29.4.3" - } - }, - "jest-get-type": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.4.3.tgz", - "integrity": "sha512-J5Xez4nRRMjk8emnTpWrlkyb9pfRQQanDrvWHhsR1+VUfbwxi30eVcZFlcdGInRibU4G5LwHXpI7IRHU0CY+gg==", - "dev": true - }, - "jest-haste-map": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.4.3.tgz", - "integrity": "sha512-eZIgAS8tvm5IZMtKlR8Y+feEOMfo2pSQkmNbufdbMzMSn9nitgGxF1waM/+LbryO3OkMcKS98SUb+j/cQxp/vQ==", - "dev": true, - "requires": { - "@jest/types": "^29.4.3", - "@types/graceful-fs": "^4.1.3", - "@types/node": "*", - "anymatch": "^3.0.3", - "fb-watchman": "^2.0.0", - "fsevents": "^2.3.2", - "graceful-fs": "^4.2.9", - "jest-regex-util": "^29.4.3", - "jest-util": "^29.4.3", - "jest-worker": "^29.4.3", - "micromatch": "^4.0.4", - "walker": "^1.0.8" - } - }, - "jest-leak-detector": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.4.3.tgz", - "integrity": "sha512-9yw4VC1v2NspMMeV3daQ1yXPNxMgCzwq9BocCwYrRgXe4uaEJPAN0ZK37nFBhcy3cUwEVstFecFLaTHpF7NiGA==", - "dev": true, - "requires": { - "jest-get-type": "^29.4.3", - "pretty-format": "^29.4.3" - } - }, - "jest-matcher-utils": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.4.3.tgz", - "integrity": "sha512-TTciiXEONycZ03h6R6pYiZlSkvYgT0l8aa49z/DLSGYjex4orMUcafuLXYyyEDWB1RKglq00jzwY00Ei7yFNVg==", - "dev": true, - "requires": { - "chalk": "^4.0.0", - "jest-diff": "^29.4.3", - "jest-get-type": "^29.4.3", - "pretty-format": "^29.4.3" - } - }, - "jest-message-util": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.4.3.tgz", - "integrity": "sha512-1Y8Zd4ZCN7o/QnWdMmT76If8LuDv23Z1DRovBj/vcSFNlGCJGoO8D1nJDw1AdyAGUk0myDLFGN5RbNeJyCRGCw==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.12.13", - "@jest/types": "^29.4.3", - "@types/stack-utils": "^2.0.0", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "micromatch": "^4.0.4", - "pretty-format": "^29.4.3", - "slash": "^3.0.0", - "stack-utils": "^2.0.3" - } - }, - "jest-mock": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.4.3.tgz", - "integrity": "sha512-LjFgMg+xed9BdkPMyIJh+r3KeHt1klXPJYBULXVVAkbTaaKjPX1o1uVCAZADMEp/kOxGTwy/Ot8XbvgItOrHEg==", - "dev": true, - "requires": { - "@jest/types": "^29.4.3", - "@types/node": "*", - "jest-util": "^29.4.3" - } - }, - "jest-pnp-resolver": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", - "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", - "dev": true, - "requires": {} - }, - "jest-regex-util": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.4.3.tgz", - "integrity": "sha512-O4FglZaMmWXbGHSQInfXewIsd1LMn9p3ZXB/6r4FOkyhX2/iP/soMG98jGvk/A3HAN78+5VWcBGO0BJAPRh4kg==", - "dev": true - }, - "jest-resolve": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.4.3.tgz", - "integrity": "sha512-GPokE1tzguRyT7dkxBim4wSx6E45S3bOQ7ZdKEG+Qj0Oac9+6AwJPCk0TZh5Vu0xzeX4afpb+eDmgbmZFFwpOw==", - "dev": true, - "requires": { - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.4.3", - "jest-pnp-resolver": "^1.2.2", - "jest-util": "^29.4.3", - "jest-validate": "^29.4.3", - "resolve": "^1.20.0", - "resolve.exports": "^2.0.0", - "slash": "^3.0.0" - } - }, - "jest-resolve-dependencies": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.4.3.tgz", - "integrity": "sha512-uvKMZAQ3nmXLH7O8WAOhS5l0iWyT3WmnJBdmIHiV5tBbdaDZ1wqtNX04FONGoaFvSOSHBJxnwAVnSn1WHdGVaw==", - "dev": true, - "requires": { - "jest-regex-util": "^29.4.3", - "jest-snapshot": "^29.4.3" - } - }, - "jest-runner": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.4.3.tgz", - "integrity": "sha512-GWPTEiGmtHZv1KKeWlTX9SIFuK19uLXlRQU43ceOQ2hIfA5yPEJC7AMkvFKpdCHx6pNEdOD+2+8zbniEi3v3gA==", - "dev": true, - "requires": { - "@jest/console": "^29.4.3", - "@jest/environment": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "emittery": "^0.13.1", - "graceful-fs": "^4.2.9", - "jest-docblock": "^29.4.3", - "jest-environment-node": "^29.4.3", - "jest-haste-map": "^29.4.3", - "jest-leak-detector": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-resolve": "^29.4.3", - "jest-runtime": "^29.4.3", - "jest-util": "^29.4.3", - "jest-watcher": "^29.4.3", - "jest-worker": "^29.4.3", - "p-limit": "^3.1.0", - "source-map-support": "0.5.13" - } - }, - "jest-runtime": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.4.3.tgz", - "integrity": "sha512-F5bHvxSH+LvLV24vVB3L8K467dt3y3dio6V3W89dUz9nzvTpqd/HcT9zfYKL2aZPvD63vQFgLvaUX/UpUhrP6Q==", - "dev": true, - "requires": { - "@jest/environment": "^29.4.3", - "@jest/fake-timers": "^29.4.3", - "@jest/globals": "^29.4.3", - "@jest/source-map": "^29.4.3", - "@jest/test-result": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "cjs-module-lexer": "^1.0.0", - "collect-v8-coverage": "^1.0.0", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-mock": "^29.4.3", - "jest-regex-util": "^29.4.3", - "jest-resolve": "^29.4.3", - "jest-snapshot": "^29.4.3", - "jest-util": "^29.4.3", - "slash": "^3.0.0", - "strip-bom": "^4.0.0" - } - }, - "jest-snapshot": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.4.3.tgz", - "integrity": "sha512-NGlsqL0jLPDW91dz304QTM/SNO99lpcSYYAjNiX0Ou+sSGgkanKBcSjCfp/pqmiiO1nQaOyLp6XQddAzRcx3Xw==", - "dev": true, - "requires": { - "@babel/core": "^7.11.6", - "@babel/generator": "^7.7.2", - "@babel/plugin-syntax-jsx": "^7.7.2", - "@babel/plugin-syntax-typescript": "^7.7.2", - "@babel/traverse": "^7.7.2", - "@babel/types": "^7.3.3", - "@jest/expect-utils": "^29.4.3", - "@jest/transform": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/babel__traverse": "^7.0.6", - "@types/prettier": "^2.1.5", - "babel-preset-current-node-syntax": "^1.0.0", - "chalk": "^4.0.0", - "expect": "^29.4.3", - "graceful-fs": "^4.2.9", - "jest-diff": "^29.4.3", - "jest-get-type": "^29.4.3", - "jest-haste-map": "^29.4.3", - "jest-matcher-utils": "^29.4.3", - "jest-message-util": "^29.4.3", - "jest-util": "^29.4.3", - "natural-compare": "^1.4.0", - "pretty-format": "^29.4.3", - "semver": "^7.3.5" - }, - "dependencies": { - "lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "requires": { - "yallist": "^4.0.0" - } - }, - "semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "requires": { - "lru-cache": "^6.0.0" - } - }, - "yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - } - } - }, - "jest-util": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.4.3.tgz", - "integrity": "sha512-ToSGORAz4SSSoqxDSylWX8JzkOQR7zoBtNRsA7e+1WUX5F8jrOwaNpuh1YfJHJKDHXLHmObv5eOjejUd+/Ws+Q==", - "dev": true, - "requires": { - "@jest/types": "^29.4.3", - "@types/node": "*", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "graceful-fs": "^4.2.9", - "picomatch": "^2.2.3" - } - }, - "jest-validate": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.4.3.tgz", - "integrity": "sha512-J3u5v7aPQoXPzaar6GndAVhdQcZr/3osWSgTeKg5v574I9ybX/dTyH0AJFb5XgXIB7faVhf+rS7t4p3lL9qFaw==", - "dev": true, - "requires": { - "@jest/types": "^29.4.3", - "camelcase": "^6.2.0", - "chalk": "^4.0.0", - "jest-get-type": "^29.4.3", - "leven": "^3.1.0", - "pretty-format": "^29.4.3" - }, - "dependencies": { - "camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true - } - } - }, - "jest-watcher": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.4.3.tgz", - "integrity": "sha512-zwlXH3DN3iksoIZNk73etl1HzKyi5FuQdYLnkQKm5BW4n8HpoG59xSwpVdFrnh60iRRaRBGw0gcymIxjJENPcA==", - "dev": true, - "requires": { - "@jest/test-result": "^29.4.3", - "@jest/types": "^29.4.3", - "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", - "emittery": "^0.13.1", - "jest-util": "^29.4.3", - "string-length": "^4.0.1" - } - }, - "jest-worker": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.4.3.tgz", - "integrity": "sha512-GLHN/GTAAMEy5BFdvpUfzr9Dr80zQqBrh0fz1mtRMe05hqP45+HfQltu7oTBfduD0UeZs09d+maFtFYAXFWvAA==", - "dev": true, - "requires": { - "@types/node": "*", - "jest-util": "^29.4.3", - "merge-stream": "^2.0.0", - "supports-color": "^8.0.0" - }, - "dependencies": { - "supports-color": { - "version": "8.1.1", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", - "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", - "dev": true, - "requires": { - "has-flag": "^4.0.0" - } - } - } - }, - "js-tokens": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", - "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" - }, - "js-yaml": { - "version": "3.14.1", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", - "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", - "dev": true, - "requires": { - "argparse": "^1.0.7", - "esprima": "^4.0.0" - } - }, - "jscodeshift": { - "version": "0.14.0", - "resolved": "https://registry.npmjs.org/jscodeshift/-/jscodeshift-0.14.0.tgz", - "integrity": "sha512-7eCC1knD7bLUPuSCwXsMZUH51O8jIcoVyKtI6P0XM0IVzlGjckPy3FIwQlorzbN0Sg79oK+RlohN32Mqf/lrYA==", - "requires": { - "@babel/core": "^7.13.16", - "@babel/parser": "^7.13.16", - "@babel/plugin-proposal-class-properties": "^7.13.0", - "@babel/plugin-proposal-nullish-coalescing-operator": "^7.13.8", - "@babel/plugin-proposal-optional-chaining": "^7.13.12", - "@babel/plugin-transform-modules-commonjs": "^7.13.8", - "@babel/preset-flow": "^7.13.13", - "@babel/preset-typescript": "^7.13.0", - "@babel/register": "^7.13.16", - "babel-core": "^7.0.0-bridge.0", - "chalk": "^4.1.2", - "flow-parser": "0.*", - "graceful-fs": "^4.2.4", - "micromatch": "^4.0.4", - "neo-async": "^2.5.0", - "node-dir": "^0.1.17", - "recast": "^0.21.0", - "temp": "^0.8.4", - "write-file-atomic": "^2.3.0" - }, - "dependencies": { - "ast-types": { - "version": "0.15.2", - "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.15.2.tgz", - "integrity": "sha512-c27loCv9QkZinsa5ProX751khO9DJl/AcB5c2KNtA6NRvHKS0PgLfcftz72KVq504vB0Gku5s2kUZzDBvQWvHg==", - "requires": { - "tslib": "^2.0.1" - } - }, - "recast": { - "version": "0.21.5", - "resolved": "https://registry.npmjs.org/recast/-/recast-0.21.5.tgz", - "integrity": "sha512-hjMmLaUXAm1hIuTqOdeYObMslq/q+Xff6QE3Y2P+uoHAg2nmVlLBps2hzh1UJDdMtDTMXOFewK6ky51JQIeECg==", - "requires": { - "ast-types": "0.15.2", - "esprima": "~4.0.0", - "source-map": "~0.6.1", - "tslib": "^2.0.1" - } - }, - "write-file-atomic": { - "version": "2.4.3", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.3.tgz", - "integrity": "sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ==", - "requires": { - "graceful-fs": "^4.1.11", - "imurmurhash": "^0.1.4", - "signal-exit": "^3.0.2" - } - } - } - }, - "jsesc": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==" - }, - "json-parse-even-better-errors": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", - "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", - "dev": true - }, - "json5": { - "version": "2.2.3", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", - "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==" - }, - "kind-of": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", - "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" - }, - "kleur": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", - "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", - "dev": true - }, - "leven": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", - "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", - "dev": true - }, - "lines-and-columns": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", - "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", - "dev": true - }, - "locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "dev": true, - "requires": { - "p-locate": "^4.1.0" - } - }, - "lodash.debounce": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", - "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", - "peer": true - }, - "lru-cache": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", - "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", - "requires": { - "yallist": "^3.0.2" - } - }, - "make-dir": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", - "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", - "dev": true, - "requires": { - "semver": "^6.0.0" - } - }, - "makeerror": { - "version": "1.0.12", - "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", - "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", - "dev": true, - "requires": { - "tmpl": "1.0.5" - } - }, - "merge-stream": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", - "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", - "dev": true - }, - "micromatch": { - "version": "4.0.5", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", - "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", - "requires": { - "braces": "^3.0.2", - "picomatch": "^2.3.1" - } - }, - "mimic-fn": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", - "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", - "dev": true - }, - "minimatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", - "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", - "requires": { - "brace-expansion": "^1.1.7" - } - }, - "ms": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" - }, - "natural-compare": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", - "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", - "dev": true - }, - "neo-async": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", - "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==" - }, - "node-dir": { - "version": "0.1.17", - "resolved": "https://registry.npmjs.org/node-dir/-/node-dir-0.1.17.tgz", - "integrity": "sha512-tmPX422rYgofd4epzrNoOXiE8XFZYOcCq1vD7MAXCDO+O+zndlA2ztdKKMa+EeuBG5tHETpr4ml4RGgpqDCCAg==", - "requires": { - "minimatch": "^3.0.2" - } - }, - "node-int64": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", - "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==", - "dev": true - }, - "node-releases": { - "version": "2.0.10", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.10.tgz", - "integrity": "sha512-5GFldHPXVG/YZmFzJvKK2zDSzPKhEp0+ZR5SVaoSag9fsL5YgHbUHDfnG5494ISANDcK4KwPXAx2xqVEydmd7w==" - }, - "normalize-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", - "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "dev": true - }, - "npm-run-path": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", - "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", - "dev": true, - "requires": { - "path-key": "^3.0.0" - } - }, - "once": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", - "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", - "requires": { - "wrappy": "1" - } - }, - "onetime": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", - "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", - "dev": true, - "requires": { - "mimic-fn": "^2.1.0" - } - }, - "p-limit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", - "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", - "dev": true, - "requires": { - "yocto-queue": "^0.1.0" - } - }, - "p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "dev": true, - "requires": { - "p-limit": "^2.2.0" - }, - "dependencies": { - "p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dev": true, - "requires": { - "p-try": "^2.0.0" - } - } - } - }, - "p-try": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", - "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" - }, - "parse-json": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", - "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.0.0", - "error-ex": "^1.3.1", - "json-parse-even-better-errors": "^2.3.0", - "lines-and-columns": "^1.1.6" - } - }, - "path-exists": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", - "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", - "dev": true - }, - "path-is-absolute": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==" - }, - "path-key": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", - "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", - "dev": true - }, - "path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" - }, - "picocolors": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", - "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" - }, - "picomatch": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", - "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==" - }, - "pify": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", - "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==" - }, - "pirates": { - "version": "4.0.5", - "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz", - "integrity": "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==" - }, - "pkg-dir": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", - "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", - "dev": true, - "requires": { - "find-up": "^4.0.0" - } - }, - "pretty-format": { - "version": "29.4.3", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.4.3.tgz", - "integrity": "sha512-cvpcHTc42lcsvOOAzd3XuNWTcvk1Jmnzqeu+WsOuiPmxUJTnkbAcFNsRKvEpBEUFVUgy/GTZLulZDcDEi+CIlA==", - "dev": true, - "requires": { - "@jest/schemas": "^29.4.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" - }, - "dependencies": { - "ansi-styles": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", - "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", - "dev": true - } - } - }, - "prompts": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", - "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", - "dev": true, - "requires": { - "kleur": "^3.0.3", - "sisteransi": "^1.0.5" - } - }, - "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", - "dev": true - }, - "recast": { - "version": "0.20.5", - "resolved": "https://registry.npmjs.org/recast/-/recast-0.20.5.tgz", - "integrity": "sha512-E5qICoPoNL4yU0H0NoBDntNB0Q5oMSNh9usFctYniLBluTthi3RsQVBXIJNbApOlvSwW/RGxIuokPcAc59J5fQ==", - "dev": true, - "requires": { - "ast-types": "0.14.2", - "esprima": "~4.0.0", - "source-map": "~0.6.1", - "tslib": "^2.0.1" - } - }, - "regenerate": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz", - "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==", - "peer": true - }, - "regenerate-unicode-properties": { - "version": "10.1.0", - "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz", - "integrity": "sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ==", - "peer": true, - "requires": { - "regenerate": "^1.4.2" - } - }, - "regenerator-runtime": { - "version": "0.13.11", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", - "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==", - "peer": true - }, - "regenerator-transform": { - "version": "0.15.1", - "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.1.tgz", - "integrity": "sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg==", - "peer": true, - "requires": { - "@babel/runtime": "^7.8.4" - } - }, - "regexpu-core": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.3.1.tgz", - "integrity": "sha512-nCOzW2V/X15XpLsK2rlgdwrysrBq+AauCn+omItIz4R1pIcmeot5zvjdmOBRLzEH/CkC6IxMJVmxDe3QcMuNVQ==", - "peer": true, - "requires": { - "@babel/regjsgen": "^0.8.0", - "regenerate": "^1.4.2", - "regenerate-unicode-properties": "^10.1.0", - "regjsparser": "^0.9.1", - "unicode-match-property-ecmascript": "^2.0.0", - "unicode-match-property-value-ecmascript": "^2.1.0" - } - }, - "regjsparser": { - "version": "0.9.1", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz", - "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==", - "peer": true, - "requires": { - "jsesc": "~0.5.0" - }, - "dependencies": { - "jsesc": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", - "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==", - "peer": true - } - } - }, - "require-directory": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", - "dev": true - }, - "resolve": { - "version": "1.22.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", - "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", - "requires": { - "is-core-module": "^2.9.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - } - }, - "resolve-cwd": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", - "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", - "dev": true, - "requires": { - "resolve-from": "^5.0.0" - } - }, - "resolve-from": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", - "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", - "dev": true - }, - "resolve.exports": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.0.tgz", - "integrity": "sha512-6K/gDlqgQscOlg9fSRpWstA8sYe8rbELsSTNpx+3kTrsVCzvSl0zIvRErM7fdl9ERWDsKnrLnwB+Ne89918XOg==", - "dev": true - }, - "rimraf": { - "version": "2.6.3", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", - "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", - "requires": { - "glob": "^7.1.3" - } - }, - "semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" - }, - "shallow-clone": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", - "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", - "requires": { - "kind-of": "^6.0.2" - } - }, - "shebang-command": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", - "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", - "dev": true, - "requires": { - "shebang-regex": "^3.0.0" - } - }, - "shebang-regex": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", - "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", - "dev": true - }, - "signal-exit": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", - "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" - }, - "sisteransi": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", - "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", - "dev": true - }, - "slash": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", - "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", - "dev": true - }, - "source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" - }, - "source-map-support": { - "version": "0.5.13", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz", - "integrity": "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==", - "dev": true, - "requires": { - "buffer-from": "^1.0.0", - "source-map": "^0.6.0" - } - }, - "sprintf-js": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", - "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", - "dev": true - }, - "stack-utils": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", - "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", - "dev": true, - "requires": { - "escape-string-regexp": "^2.0.0" - } - }, - "string-length": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", - "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", - "dev": true, - "requires": { - "char-regex": "^1.0.2", - "strip-ansi": "^6.0.0" - } - }, - "string-width": { - "version": "4.2.3", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", - "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, - "requires": { - "emoji-regex": "^8.0.0", - "is-fullwidth-code-point": "^3.0.0", - "strip-ansi": "^6.0.1" - } - }, - "strip-ansi": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", - "dev": true, - "requires": { - "ansi-regex": "^5.0.1" - } - }, - "strip-bom": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", - "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", - "dev": true - }, - "strip-final-newline": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", - "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", - "dev": true - }, - "strip-json-comments": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", - "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", - "dev": true - }, - "supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "requires": { - "has-flag": "^4.0.0" - } - }, - "supports-preserve-symlinks-flag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", - "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==" - }, - "temp": { - "version": "0.8.4", - "resolved": "https://registry.npmjs.org/temp/-/temp-0.8.4.tgz", - "integrity": "sha512-s0ZZzd0BzYv5tLSptZooSjK8oj6C+c19p7Vqta9+6NPOf7r+fxq0cJe6/oN4LTC79sy5NY8ucOJNgwsKCSbfqg==", - "requires": { - "rimraf": "~2.6.2" - } - }, - "test-exclude": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", - "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", - "dev": true, - "requires": { - "@istanbuljs/schema": "^0.1.2", - "glob": "^7.1.4", - "minimatch": "^3.0.4" - } - }, - "tmpl": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", - "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", - "dev": true - }, - "to-fast-properties": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", - "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==" - }, - "to-regex-range": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", - "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "requires": { - "is-number": "^7.0.0" - } - }, - "tslib": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz", - "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==" - }, - "type-detect": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", - "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", - "dev": true - }, - "type-fest": { - "version": "0.21.3", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", - "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", - "dev": true - }, - "unicode-canonical-property-names-ecmascript": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz", - "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==", - "peer": true - }, - "unicode-match-property-ecmascript": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz", - "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==", - "peer": true, - "requires": { - "unicode-canonical-property-names-ecmascript": "^2.0.0", - "unicode-property-aliases-ecmascript": "^2.0.0" - } - }, - "unicode-match-property-value-ecmascript": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz", - "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==", - "peer": true - }, - "unicode-property-aliases-ecmascript": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz", - "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==", - "peer": true - }, - "update-browserslist-db": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz", - "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==", - "requires": { - "escalade": "^3.1.1", - "picocolors": "^1.0.0" - } - }, - "v8-to-istanbul": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", - "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==", - "dev": true, - "requires": { - "@jridgewell/trace-mapping": "^0.3.12", - "@types/istanbul-lib-coverage": "^2.0.1", - "convert-source-map": "^1.6.0" - }, - "dependencies": { - "convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true - } - } - }, - "walker": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", - "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", - "dev": true, - "requires": { - "makeerror": "1.0.12" - } - }, - "which": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", - "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", - "dev": true, - "requires": { - "isexe": "^2.0.0" - } - }, - "wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "requires": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - } - }, - "wrappy": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" - }, - "write-file-atomic": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz", - "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==", - "dev": true, - "requires": { - "imurmurhash": "^0.1.4", - "signal-exit": "^3.0.7" - } - }, - "y18n": { - "version": "5.0.8", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", - "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", - "dev": true - }, - "yallist": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", - "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" - }, - "yargs": { - "version": "17.7.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.0.tgz", - "integrity": "sha512-dwqOPg5trmrre9+v8SUo2q/hAwyKoVfu8OC1xPHKJGNdxAvPl4sKxL4vBnh3bQz/ZvvGAFeA5H3ou2kcOY8sQQ==", - "dev": true, - "requires": { - "cliui": "^8.0.1", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.3", - "y18n": "^5.0.5", - "yargs-parser": "^21.1.1" - } - }, - "yargs-parser": { - "version": "21.1.1", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", - "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", - "dev": true - }, - "yocto-queue": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", - "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", - "dev": true - } - } -} diff --git a/api/codemods/migrate-cjs-to-esm/package.json b/api/codemods/migrate-cjs-to-esm/package.json deleted file mode 100644 index 92e6aa2e4a9..00000000000 --- a/api/codemods/migrate-cjs-to-esm/package.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "name": "migrate-cjs-to-esm", - "type": "commonjs", - "scripts": { - "test": "jest" - }, - "devDependencies": { - "@types/jscodeshift": "^0.11.6", - "jest": "^29.4.3" - }, - "dependencies": { - "jscodeshift": "^0.14.0" - } -} diff --git a/api/codemods/migrate-cjs-to-esm/transforms/execute.js b/api/codemods/migrate-cjs-to-esm/transforms/execute.js deleted file mode 100644 index 681f5637148..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/execute.js +++ /dev/null @@ -1,17 +0,0 @@ -// eslint-disable-next-line eslint-comments/disable-enable-pair -/* eslint-disable no-undef */ -const codemods = []; - -const transformScripts = (fileInfo, api, options) => { - return codemods.reduce((input, script) => { - return script( - { - source: input, - }, - api, - options - ); - }, fileInfo.source); -}; - -module.exports = transformScripts; diff --git a/api/codemods/migrate-cjs-to-esm/transforms/prepare.js b/api/codemods/migrate-cjs-to-esm/transforms/prepare.js deleted file mode 100644 index ca1746734ef..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/prepare.js +++ /dev/null @@ -1,19 +0,0 @@ -// eslint-disable-next-line eslint-comments/disable-enable-pair -/* eslint-disable no-undef */ -const codemods = [ - require('./src/add-file-extension-to-import'), -]; - -const transformScripts = (fileInfo, api, options) => { - return codemods.reduce((input, script) => { - return script( - { - source: input, - }, - api, - options - ); - }, fileInfo.source); -}; - -module.exports = transformScripts; diff --git a/api/codemods/migrate-cjs-to-esm/transforms/src/add-file-extension-to-import.js b/api/codemods/migrate-cjs-to-esm/transforms/src/add-file-extension-to-import.js deleted file mode 100644 index 47b477924b7..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/src/add-file-extension-to-import.js +++ /dev/null @@ -1,33 +0,0 @@ -// eslint-disable-next-line eslint-comments/disable-enable-pair -/* eslint-disable no-undef */ -const util = require('util'); - -function transformer(file, api, _options) { - const j = api.jscodeshift; - - // ------------------------------------------------------------------ SEARCH - const nodes = j(file.source) - .find(j.CallExpression, { - callee: { - type: 'Identifier', - name: 'require', - }, - }) - .filter((path) => { - return ( - path.node.arguments[0].value.startsWith('.') && - !path.node.arguments[0].value.endsWith('.js') && - !path.node.arguments[0].value.endsWith('.json') - ); - }); - - // ----------------------------------------------------------------- REPLACE - return nodes - .replaceWith((path) => { - const sourcePath = path.node.arguments.pop(); - return j.callExpression(j.identifier('require'), [j.literal(`${sourcePath.value}.js`)]); - }) - .toSource({ quote: 'single' }); -} - -module.exports = transformer; diff --git a/api/codemods/migrate-cjs-to-esm/transforms/src/utils/filters.js b/api/codemods/migrate-cjs-to-esm/transforms/src/utils/filters.js deleted file mode 100644 index 6a1a8b94d9f..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/src/utils/filters.js +++ /dev/null @@ -1,7 +0,0 @@ -const j = require('jscodeshift'); - -const isTopNode = (path) => j.Program.check(path.parent.value); - -const isNotTopNode = (path) => !j.Program.check(path.parent.value); - -module.exports = { isTopNode, isNotTopNode }; diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/add-file-extension-to-import-on-local-file.input.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/add-file-extension-to-import-on-local-file.input.js deleted file mode 100644 index b4685947eac..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/add-file-extension-to-import-on-local-file.input.js +++ /dev/null @@ -1,2 +0,0 @@ -const { foo } = require('./bar'); -const { fooz } = require('../baz'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/add-file-extension-to-import-on-local-file.output.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/add-file-extension-to-import-on-local-file.output.js deleted file mode 100644 index 46f3d4c1e62..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/add-file-extension-to-import-on-local-file.output.js +++ /dev/null @@ -1,2 +0,0 @@ -const { foo } = require('./bar.js'); -const { fooz } = require('../baz.js'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-if-it-already-exists.input.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-if-it-already-exists.input.js deleted file mode 100644 index 52e2ac95737..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-if-it-already-exists.input.js +++ /dev/null @@ -1,3 +0,0 @@ -const bar = require('./bar.js'); -const packageJson = require('./package.json'); -const translations = require('./translation/en.json'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-if-it-already-exists.output.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-if-it-already-exists.output.js deleted file mode 100644 index 52e2ac95737..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-if-it-already-exists.output.js +++ /dev/null @@ -1,3 +0,0 @@ -const bar = require('./bar.js'); -const packageJson = require('./package.json'); -const translations = require('./translation/en.json'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-esm-file.input.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-esm-file.input.js deleted file mode 100644 index bee419c512a..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-esm-file.input.js +++ /dev/null @@ -1 +0,0 @@ -import { foo } from 'bar'; diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-esm-file.output.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-esm-file.output.js deleted file mode 100644 index bee419c512a..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-esm-file.output.js +++ /dev/null @@ -1 +0,0 @@ -import { foo } from 'bar'; diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-fs-root-local-file.input.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-fs-root-local-file.input.js deleted file mode 100644 index 8e663b3005f..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-fs-root-local-file.input.js +++ /dev/null @@ -1 +0,0 @@ -const { foobar } = require('/bar'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-fs-root-local-file.output.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-fs-root-local-file.output.js deleted file mode 100644 index 8e663b3005f..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-fs-root-local-file.output.js +++ /dev/null @@ -1 +0,0 @@ -const { foobar } = require('/bar'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-library.input.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-library.input.js deleted file mode 100644 index 60b900fba8d..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-library.input.js +++ /dev/null @@ -1 +0,0 @@ -const { foo } = require('bar'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-library.output.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-library.output.js deleted file mode 100644 index 60b900fba8d..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testfixtures__/add-file-extension-to-import/do-not-add-file-extension-to-import-on-library.output.js +++ /dev/null @@ -1 +0,0 @@ -const { foo } = require('bar'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__tests__/add-file-extension-to-import-test.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__tests__/add-file-extension-to-import-test.js deleted file mode 100644 index e6b98534f11..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__tests__/add-file-extension-to-import-test.js +++ /dev/null @@ -1,2 +0,0 @@ -const { defineTests } = require('../__testutils__/defineTests'); -defineTests(__dirname, 'add-file-extension-to-import'); diff --git a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testutils__/defineTests.js b/api/codemods/migrate-cjs-to-esm/transforms/tests/__testutils__/defineTests.js deleted file mode 100644 index 0c4cf622bc5..00000000000 --- a/api/codemods/migrate-cjs-to-esm/transforms/tests/__testutils__/defineTests.js +++ /dev/null @@ -1,26 +0,0 @@ -const { defineTest } = require('jscodeshift/dist/testUtils'); -const fs = require('fs'); -const path = require('path'); - -module.exports = { - defineTests(dirName, transformName) { - const inputFileSuffixRegex = /\.input\.js$/i; - const testFileNames = fs - .readdirSync(path.resolve(dirName, '../__testfixtures__', transformName)) - .filter((fileName) => inputFileSuffixRegex.test(fileName)) - .map((fileName) => fileName.replace(inputFileSuffixRegex, '')); - - const transformPath = `../src/${transformName}`; - - testFileNames.forEach((testFileName) => { - defineTest( - dirName, - transformPath, - { - silent: true, - }, - `${transformName}/${testFileName}` - ); - }); - }, -}; diff --git a/api/db/batch-processing.js b/api/db/batch-processing.js index 07de6b6b267..2a8d387120e 100644 --- a/api/db/batch-processing.js +++ b/api/db/batch-processing.js @@ -1,5 +1,5 @@ const BATCH_SIZE = 10; -const logger = require('../lib/infrastructure/logger'); +import { logger } from '../lib/infrastructure/logger.js'; function batch(knex, elementsToUpdate, treatment) { function _innerTreatment(knex, remainingElementsToUpdate, countOfBatches, batchesDone) { @@ -32,6 +32,4 @@ function batch(knex, elementsToUpdate, treatment) { return Promise.resolve().then(() => _innerTreatment(knex, elementsToUpdate, numberOfTotalBatches, 0)); } -module.exports = { - batch, -}; +export { batch }; diff --git a/api/db/constants.js b/api/db/constants.js index 729f828ae82..b2f41c04078 100644 --- a/api/db/constants.js +++ b/api/db/constants.js @@ -16,4 +16,6 @@ const keys = { PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_EXPERT: 'PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_EXPERT', }; -module.exports.badges = { keys }; +const badges = { keys }; + +export { badges }; diff --git a/api/db/database-builder/database-buffer.js b/api/db/database-builder/database-buffer.js index eeccae9c901..ee0d2bdb632 100644 --- a/api/db/database-builder/database-buffer.js +++ b/api/db/database-builder/database-buffer.js @@ -1,6 +1,5 @@ const INITIAL_ID = 100000; - -module.exports = { +const databaseBuffer = { objectsToInsert: [], nextId: INITIAL_ID, @@ -18,3 +17,5 @@ module.exports = { this.objectsToInsert = []; }, }; + +export { databaseBuffer }; diff --git a/api/db/database-builder/database-builder.js b/api/db/database-builder/database-builder.js index 480ca2b458f..5c68e7e9e09 100644 --- a/api/db/database-builder/database-builder.js +++ b/api/db/database-builder/database-builder.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const factory = require('./factory/index'); -const databaseBuffer = require('./database-buffer'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import * as factory from './factory/index.js'; +import { databaseBuffer } from './database-buffer.js'; -module.exports = class DatabaseBuilder { +class DatabaseBuilder { constructor({ knex, emptyFirst = true }) { this.knex = knex; this.databaseBuffer = databaseBuffer; @@ -178,4 +178,6 @@ module.exports = class DatabaseBuilder { table.isDirty = false; }); } -}; +} + +export { DatabaseBuilder }; diff --git a/api/db/database-builder/factory/build-account-recovery-demand.js b/api/db/database-builder/factory/build-account-recovery-demand.js index 4c0303fa510..306cb3a5e0a 100644 --- a/api/db/database-builder/factory/build-account-recovery-demand.js +++ b/api/db/database-builder/factory/build-account-recovery-demand.js @@ -1,8 +1,8 @@ -const databaseBuffer = require('../database-buffer'); -const buildOrganizationLearner = require('./build-organization-learner'); -const buildUser = require('./build-user'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildOrganizationLearner } from './build-organization-learner.js'; +import { buildUser } from './build-user.js'; -module.exports = function buildAccountRecoveryDemand({ +const buildAccountRecoveryDemand = function ({ id = databaseBuffer.getNextId(), userId, firstName, @@ -62,3 +62,5 @@ module.exports = function buildAccountRecoveryDemand({ updatedAt, }; }; + +export { buildAccountRecoveryDemand }; diff --git a/api/db/database-builder/factory/build-answer.js b/api/db/database-builder/factory/build-answer.js index a2c2993cc0f..4722aa32e69 100644 --- a/api/db/database-builder/factory/build-answer.js +++ b/api/db/database-builder/factory/build-answer.js @@ -1,8 +1,8 @@ -const buildAssessment = require('./build-assessment'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildAssessment } from './build-assessment.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildAnswer({ +const buildAnswer = function ({ id = databaseBuffer.getNextId(), value = 'Some value for answer', result = 'Some result for answer', @@ -33,3 +33,5 @@ module.exports = function buildAnswer({ values, }); }; + +export { buildAnswer }; diff --git a/api/db/database-builder/factory/build-answered-not-completed-certification-assessment.js b/api/db/database-builder/factory/build-answered-not-completed-certification-assessment.js index 8ba36f104d3..38ad35586f9 100644 --- a/api/db/database-builder/factory/build-answered-not-completed-certification-assessment.js +++ b/api/db/database-builder/factory/build-answered-not-completed-certification-assessment.js @@ -1,10 +1,10 @@ -const buildCertificationCourse = require('./build-certification-course'); -const buildAssessment = require('./build-assessment'); -const Assessment = require('../../../lib/domain/models/Assessment'); -const buildCertificationChallenge = require('./build-certification-challenge'); -const buildAnswer = require('./build-answer'); +import { buildCertificationCourse } from './build-certification-course.js'; +import { buildAssessment } from './build-assessment.js'; +import { Assessment } from '../../../lib/domain/models/Assessment.js'; +import { buildCertificationChallenge } from './build-certification-challenge.js'; +import { buildAnswer } from './build-answer.js'; -module.exports = function buildAnsweredNotCompletedCertificationAssessment({ +const buildAnsweredNotCompletedCertificationAssessment = function ({ certifiableUserId, competenceIdSkillIdPairs, limitDate, @@ -29,3 +29,5 @@ module.exports = function buildAnsweredNotCompletedCertificationAssessment({ return certificationAssessment; }; + +export { buildAnsweredNotCompletedCertificationAssessment }; diff --git a/api/db/database-builder/factory/build-assessment-campaign-for-skills.js b/api/db/database-builder/factory/build-assessment-campaign-for-skills.js index 11a21232e46..3ff746d2217 100644 --- a/api/db/database-builder/factory/build-assessment-campaign-for-skills.js +++ b/api/db/database-builder/factory/build-assessment-campaign-for-skills.js @@ -1,11 +1,13 @@ -const buildCampaign = require('./build-campaign'); -const buildCampaignSkill = require('./build-campaign-skill'); -const CampaignTypes = require('../../../lib/domain/models/CampaignTypes'); +import { buildCampaign } from './build-campaign.js'; +import { buildCampaignSkill } from './build-campaign-skill.js'; +import { CampaignTypes } from '../../../lib/domain/models/CampaignTypes.js'; -module.exports = function buildAssessmentCampaignForSkills(attributes, skillSet) { +const buildAssessmentCampaignForSkills = function (attributes, skillSet) { attributes.type = CampaignTypes.ASSESSMENT; const campaign = buildCampaign(attributes); skillSet.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill.id })); return campaign; }; + +export { buildAssessmentCampaignForSkills }; diff --git a/api/db/database-builder/factory/build-assessment-campaign.js b/api/db/database-builder/factory/build-assessment-campaign.js index 4bebd179b63..47b68b66b48 100644 --- a/api/db/database-builder/factory/build-assessment-campaign.js +++ b/api/db/database-builder/factory/build-assessment-campaign.js @@ -1,8 +1,10 @@ -const buildAssessmentCampaignForSkills = require('./build-assessment-campaign-for-skills'); -const CampaignTypes = require('../../../lib/domain/models/CampaignTypes'); +import { buildAssessmentCampaignForSkills } from './build-assessment-campaign-for-skills.js'; +import { CampaignTypes } from '../../../lib/domain/models/CampaignTypes.js'; -module.exports = function buildAssessmentCampaign(attributes, skills = [{ id: 'skill', name: 'skillName' }]) { +const buildAssessmentCampaign = function (attributes, skills = [{ id: 'skill', name: 'skillName' }]) { attributes.type = CampaignTypes.ASSESSMENT; return buildAssessmentCampaignForSkills(attributes, skills); }; + +export { buildAssessmentCampaign }; diff --git a/api/db/database-builder/factory/build-assessment-from-participation.js b/api/db/database-builder/factory/build-assessment-from-participation.js index 771fddb87d3..348578327dd 100644 --- a/api/db/database-builder/factory/build-assessment-from-participation.js +++ b/api/db/database-builder/factory/build-assessment-from-participation.js @@ -1,9 +1,9 @@ -const buildAssessment = require('./build-assessment'); -const buildUser = require('./build-user'); -const buildCampaignParticipation = require('./build-campaign-participation'); -const buildOrganizationLearner = require('./build-organization-learner'); +import { buildAssessment } from './build-assessment.js'; +import { buildUser } from './build-user.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import { buildOrganizationLearner } from './build-organization-learner.js'; -module.exports = function buildAssessmentFromParticipation(campaignParticipation, organizationLearner, user) { +const buildAssessmentFromParticipation = function (campaignParticipation, organizationLearner, user) { const userId = buildUser(user).id; const organizationLearnerId = buildOrganizationLearner(organizationLearner).id; const campaignParticipationId = buildCampaignParticipation({ @@ -14,3 +14,5 @@ module.exports = function buildAssessmentFromParticipation(campaignParticipation return buildAssessment({ userId, campaignParticipationId }); }; + +export { buildAssessmentFromParticipation }; diff --git a/api/db/database-builder/factory/build-assessment-result.js b/api/db/database-builder/factory/build-assessment-result.js index c554a0cc1d0..69848dc19fa 100644 --- a/api/db/database-builder/factory/build-assessment-result.js +++ b/api/db/database-builder/factory/build-assessment-result.js @@ -1,9 +1,9 @@ -const buildAssessment = require('./build-assessment'); -const buildCertificationCourseLastAssessmentResult = require('./build-certification-course-last-assessment-result'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); -const AssessmentResult = require('../../../lib/domain/models/AssessmentResult'); -const _ = require('lodash'); +import { buildAssessment } from './build-assessment.js'; +import { buildCertificationCourseLastAssessmentResult } from './build-certification-course-last-assessment-result.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; +import { AssessmentResult } from '../../../lib/domain/models/AssessmentResult.js'; +import _ from 'lodash'; function buildAssessmentResult({ id = databaseBuffer.getNextId(), @@ -43,7 +43,7 @@ function buildAssessmentResult({ }); } -module.exports = buildAssessmentResult; +export { buildAssessmentResult }; buildAssessmentResult.last = function ({ certificationCourseId, diff --git a/api/db/database-builder/factory/build-assessment.js b/api/db/database-builder/factory/build-assessment.js index 5f4b70aa621..ccd91704384 100644 --- a/api/db/database-builder/factory/build-assessment.js +++ b/api/db/database-builder/factory/build-assessment.js @@ -1,10 +1,10 @@ -const buildCertificationCourse = require('./build-certification-course'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); -const Assessment = require('../../../lib/domain/models/Assessment'); -const _ = require('lodash'); +import { buildCertificationCourse } from './build-certification-course.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; +import { Assessment } from '../../../lib/domain/models/Assessment.js'; +import _ from 'lodash'; -module.exports = function buildAssessment({ +const buildAssessment = function ({ id = databaseBuffer.getNextId(), courseId = 'recDefaultCourseId', certificationCourseId, @@ -53,3 +53,5 @@ module.exports = function buildAssessment({ values, }); }; + +export { buildAssessment }; diff --git a/api/db/database-builder/factory/build-authentication-method.js b/api/db/database-builder/factory/build-authentication-method.js index e3585df77e1..48c7471613e 100644 --- a/api/db/database-builder/factory/build-authentication-method.js +++ b/api/db/database-builder/factory/build-authentication-method.js @@ -1,9 +1,10 @@ -const isUndefined = require('lodash/isUndefined'); -const databaseBuffer = require('../database-buffer'); -const buildUser = require('./build-user'); -const AuthenticationMethod = require('../../../lib/domain/models/AuthenticationMethod'); -const OidcIdentityProviders = require('../../../lib/domain/constants/oidc-identity-providers'); -const encrypt = require('../../../lib/domain/services/encryption-service'); +import lodash from 'lodash'; +const { isUndefined } = lodash; +import { databaseBuffer } from '../database-buffer.js'; +import { buildUser } from './build-user.js'; +import { AuthenticationMethod } from '../../../lib/domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../../lib/domain/constants/oidc-identity-providers.js'; +import * as encrypt from '../../../lib/domain/services/encryption-service.js'; const buildAuthenticationMethod = {}; @@ -166,4 +167,4 @@ buildAuthenticationMethod.withIdentityProvider = function ({ }); }; -module.exports = buildAuthenticationMethod; +export { buildAuthenticationMethod }; diff --git a/api/db/database-builder/factory/build-badge-acquisition.js b/api/db/database-builder/factory/build-badge-acquisition.js index f5a59b8adc1..31bb8b1505a 100644 --- a/api/db/database-builder/factory/build-badge-acquisition.js +++ b/api/db/database-builder/factory/build-badge-acquisition.js @@ -1,7 +1,7 @@ -const databaseBuffer = require('../database-buffer'); -const buildCampaignParticipation = require('./build-campaign-participation'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; -module.exports = function buildBadgeAcquisition({ +const buildBadgeAcquisition = function ({ id = databaseBuffer.getNextId(), badgeId, userId, @@ -19,3 +19,5 @@ module.exports = function buildBadgeAcquisition({ }, }); }; + +export { buildBadgeAcquisition }; diff --git a/api/db/database-builder/factory/build-badge-criterion.js b/api/db/database-builder/factory/build-badge-criterion.js index f79e4d3c018..188e4d1048c 100644 --- a/api/db/database-builder/factory/build-badge-criterion.js +++ b/api/db/database-builder/factory/build-badge-criterion.js @@ -1,5 +1,5 @@ -const BadgeCriterion = require('../../../lib/domain/models/BadgeCriterion'); -const databaseBuffer = require('../database-buffer'); +import { BadgeCriterion } from '../../../lib/domain/models/BadgeCriterion.js'; +import { databaseBuffer } from '../database-buffer.js'; const buildBadgeCriterion = function ({ id = databaseBuffer.getNextId(), @@ -60,4 +60,4 @@ buildBadgeCriterion.scopeCappedTubes = function ({ id, threshold, badgeId, cappe }); }; -module.exports = buildBadgeCriterion; +export { buildBadgeCriterion }; diff --git a/api/db/database-builder/factory/build-badge.js b/api/db/database-builder/factory/build-badge.js index d46485b5377..c88420c56b6 100644 --- a/api/db/database-builder/factory/build-badge.js +++ b/api/db/database-builder/factory/build-badge.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); -const buildTargetProfile = require('./build-target-profile'); -const _ = require('lodash'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildTargetProfile } from './build-target-profile.js'; +import _ from 'lodash'; function buildBadge({ id = databaseBuffer.getNextId(), @@ -78,4 +78,4 @@ buildBadge.notCertifiable = function ({ }); }; -module.exports = buildBadge; +export { buildBadge }; diff --git a/api/db/database-builder/factory/build-campaign-participation-elements-for-overview.js b/api/db/database-builder/factory/build-campaign-participation-elements-for-overview.js index 9f05a41516b..0abc35fc1ec 100644 --- a/api/db/database-builder/factory/build-campaign-participation-elements-for-overview.js +++ b/api/db/database-builder/factory/build-campaign-participation-elements-for-overview.js @@ -1,10 +1,10 @@ -const Assessment = require('../../../lib/domain/models/Assessment'); -const buildAssessment = require('./build-assessment'); -const buildOrganization = require('./build-organization'); -const buildCampaignParticipation = require('./build-campaign-participation'); -const buildCampaign = require('./build-campaign'); +import { Assessment } from '../../../lib/domain/models/Assessment.js'; +import { buildAssessment } from './build-assessment.js'; +import { buildOrganization } from './build-organization.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import { buildCampaign } from './build-campaign.js'; -module.exports = function buildCampaignParticipationElementsForOverview({ +const buildCampaignParticipationElementsForOverview = function ({ userId, index, lastAssessmentState, @@ -52,3 +52,5 @@ module.exports = function buildCampaignParticipationElementsForOverview({ organization, }; }; + +export { buildCampaignParticipationElementsForOverview }; diff --git a/api/db/database-builder/factory/build-campaign-participation-with-organization-learner.js b/api/db/database-builder/factory/build-campaign-participation-with-organization-learner.js index 9b935f220c4..bf8a2166f94 100644 --- a/api/db/database-builder/factory/build-campaign-participation-with-organization-learner.js +++ b/api/db/database-builder/factory/build-campaign-participation-with-organization-learner.js @@ -1,8 +1,12 @@ -const buildAssessment = require('./build-assessment'); -const buildCampaignParticipation = require('./build-campaign-participation'); -const buildOrganizationLearnerWithUser = require('./build-organization-learner-with-user'); +import { buildAssessment } from './build-assessment.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import { buildOrganizationLearnerWithUser } from './build-organization-learner-with-user.js'; -module.exports = (organizationLearner, campaignParticipation, withAssessment) => { +const buildCampaignParticipationWithOrganizationLearner = ( + organizationLearner, + campaignParticipation, + withAssessment +) => { const { userId, id: organizationLearnerId } = buildOrganizationLearnerWithUser(organizationLearner); const campaignParticipationCreated = buildCampaignParticipation({ userId, @@ -14,3 +18,5 @@ module.exports = (organizationLearner, campaignParticipation, withAssessment) => } return campaignParticipationCreated; }; + +export { buildCampaignParticipationWithOrganizationLearner }; diff --git a/api/db/database-builder/factory/build-campaign-participation-with-user.js b/api/db/database-builder/factory/build-campaign-participation-with-user.js index 89e938a057f..90822925e4e 100644 --- a/api/db/database-builder/factory/build-campaign-participation-with-user.js +++ b/api/db/database-builder/factory/build-campaign-participation-with-user.js @@ -1,8 +1,8 @@ -const buildAssessment = require('./build-assessment'); -const buildCampaignParticipation = require('./build-campaign-participation'); -const buildUser = require('./build-user'); +import { buildAssessment } from './build-assessment.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import { buildUser } from './build-user.js'; -module.exports = (user, campaignParticipation, withAssessment) => { +const buildCampaignParticipationWithUser = (user, campaignParticipation, withAssessment) => { const { id: userId } = buildUser(user); const campaignParticipationCreated = buildCampaignParticipation({ userId, ...campaignParticipation }); if (withAssessment) { @@ -10,3 +10,5 @@ module.exports = (user, campaignParticipation, withAssessment) => { } return campaignParticipationCreated; }; + +export { buildCampaignParticipationWithUser }; diff --git a/api/db/database-builder/factory/build-campaign-participation.js b/api/db/database-builder/factory/build-campaign-participation.js index f9d6fde2ac7..97462e38f8f 100644 --- a/api/db/database-builder/factory/build-campaign-participation.js +++ b/api/db/database-builder/factory/build-campaign-participation.js @@ -1,13 +1,13 @@ -const buildCampaign = require('./build-campaign'); -const buildUser = require('./build-user'); -const buildOrganizationLearner = require('./build-organization-learner'); -const databaseBuffer = require('../database-buffer'); -const CampaignParticipationStatuses = require('../../../lib/domain/models/CampaignParticipationStatuses'); -const _ = require('lodash'); +import { buildCampaign } from './build-campaign.js'; +import { buildUser } from './build-user.js'; +import { buildOrganizationLearner } from './build-organization-learner.js'; +import { databaseBuffer } from '../database-buffer.js'; +import { CampaignParticipationStatuses } from '../../../lib/domain/models/CampaignParticipationStatuses.js'; +import _ from 'lodash'; const { SHARED } = CampaignParticipationStatuses; -module.exports = function buildCampaignParticipation({ +const buildCampaignParticipation = function ({ id = databaseBuffer.getNextId(), campaignId, createdAt = new Date('2020-01-01'), @@ -70,3 +70,5 @@ module.exports = function buildCampaignParticipation({ isCertifiable, }; }; + +export { buildCampaignParticipation }; diff --git a/api/db/database-builder/factory/build-campaign-skill.js b/api/db/database-builder/factory/build-campaign-skill.js index c755036c49e..1a74d52d08e 100644 --- a/api/db/database-builder/factory/build-campaign-skill.js +++ b/api/db/database-builder/factory/build-campaign-skill.js @@ -1,8 +1,8 @@ -const buildCampaign = require('./build-campaign'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildCampaign } from './build-campaign.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildCampaignSkill({ campaignId, skillId = 'recSKI456' } = {}) { +const buildCampaignSkill = function ({ campaignId, skillId = 'recSKI456' } = {}) { campaignId = _.isUndefined(campaignId) ? buildCampaign().id : campaignId; const values = { @@ -14,3 +14,5 @@ module.exports = function buildCampaignSkill({ campaignId, skillId = 'recSKI456' values, }); }; + +export { buildCampaignSkill }; diff --git a/api/db/database-builder/factory/build-campaign.js b/api/db/database-builder/factory/build-campaign.js index 09e1dea19a1..d6decc4cded 100644 --- a/api/db/database-builder/factory/build-campaign.js +++ b/api/db/database-builder/factory/build-campaign.js @@ -1,12 +1,12 @@ -const buildOrganization = require('./build-organization'); -const buildTargetProfile = require('./build-target-profile'); -const buildUser = require('./build-user'); -const CampaignTypes = require('../../../lib/domain/models/CampaignTypes'); -const Assessment = require('../../../lib/domain/models/Assessment'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildOrganization } from './build-organization.js'; +import { buildTargetProfile } from './build-target-profile.js'; +import { buildUser } from './build-user.js'; +import { CampaignTypes } from '../../../lib/domain/models/CampaignTypes.js'; +import { Assessment } from '../../../lib/domain/models/Assessment.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildCampaign({ +const buildCampaign = function ({ id = databaseBuffer.getNextId(), name = 'Name', code, @@ -72,3 +72,5 @@ module.exports = function buildCampaign({ values, }); }; + +export { buildCampaign }; diff --git a/api/db/database-builder/factory/build-certifiable-user.js b/api/db/database-builder/factory/build-certifiable-user.js index c2d975952a5..5d814fe2e64 100644 --- a/api/db/database-builder/factory/build-certifiable-user.js +++ b/api/db/database-builder/factory/build-certifiable-user.js @@ -1,9 +1,9 @@ -const buildUser = require('./build-user'); -const buildAssessment = require('./build-assessment'); -const buildAnswer = require('./build-answer'); -const buildKnowledgeElement = require('./build-knowledge-element'); +import { buildUser } from './build-user.js'; +import { buildAssessment } from './build-assessment.js'; +import { buildAnswer } from './build-answer.js'; +import { buildKnowledgeElement } from './build-knowledge-element.js'; -module.exports = function buildCertifiableUser({ competencesAssociatedSkillsAndChallenges, limitDate }) { +const buildCertifiableUser = function ({ competencesAssociatedSkillsAndChallenges, limitDate }) { const certifiableUser = buildUser(); const assessmentId = buildAssessment({ userId: certifiableUser.id }).id; const commonUserIdAssessmentIdAndEarnedPixForAllKEs = { userId: certifiableUser.id, assessmentId, earnedPix: 4 }; @@ -20,3 +20,5 @@ module.exports = function buildCertifiableUser({ competencesAssociatedSkillsAndC return certifiableUser; }; + +export { buildCertifiableUser }; diff --git a/api/db/database-builder/factory/build-certification-candidate.js b/api/db/database-builder/factory/build-certification-candidate.js index 50fad4dd7e5..c2cf6bed909 100644 --- a/api/db/database-builder/factory/build-certification-candidate.js +++ b/api/db/database-builder/factory/build-certification-candidate.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const buildSession = require('./build-session'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); +import _ from 'lodash'; +import { buildSession } from './build-session.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildCertificationCandidate({ +const buildCertificationCandidate = function ({ id = databaseBuffer.getNextId(), firstName = 'first-name', lastName = 'last-name', @@ -82,3 +82,5 @@ module.exports = function buildCertificationCandidate({ prepaymentCode, }; }; + +export { buildCertificationCandidate }; diff --git a/api/db/database-builder/factory/build-certification-center-invitation.js b/api/db/database-builder/factory/build-certification-center-invitation.js index ebf39a299d5..82d8fa17ae1 100644 --- a/api/db/database-builder/factory/build-certification-center-invitation.js +++ b/api/db/database-builder/factory/build-certification-center-invitation.js @@ -1,8 +1,8 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; const TABLE_NAME = 'certification-center-invitations'; -module.exports = function buildCertificationCenterInvitation({ +const buildCertificationCenterInvitation = function ({ id = databaseBuffer.getNextId(), certificationCenterId, email = 'anemail@example.net', @@ -26,3 +26,5 @@ module.exports = function buildCertificationCenterInvitation({ values, }); }; + +export { buildCertificationCenterInvitation }; diff --git a/api/db/database-builder/factory/build-certification-center-membership.js b/api/db/database-builder/factory/build-certification-center-membership.js index 6d991c404d6..1ab9c912a97 100644 --- a/api/db/database-builder/factory/build-certification-center-membership.js +++ b/api/db/database-builder/factory/build-certification-center-membership.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const databaseBuffer = require('../database-buffer'); -const buildCertificationCenter = require('./build-certification-center'); -const buildUser = require('./build-user'); +import _ from 'lodash'; +import { databaseBuffer } from '../database-buffer.js'; +import { buildCertificationCenter } from './build-certification-center.js'; +import { buildUser } from './build-user.js'; -module.exports = function buildCertificationCenterMembership({ +const buildCertificationCenterMembership = function ({ id = databaseBuffer.getNextId(), userId, updatedByUserId, @@ -29,3 +29,5 @@ module.exports = function buildCertificationCenterMembership({ values, }); }; + +export { buildCertificationCenterMembership }; diff --git a/api/db/database-builder/factory/build-certification-center.js b/api/db/database-builder/factory/build-certification-center.js index c3a388170b7..437c6c2aeef 100644 --- a/api/db/database-builder/factory/build-certification-center.js +++ b/api/db/database-builder/factory/build-certification-center.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildCertificationCenter({ +const buildCertificationCenter = function ({ id = databaseBuffer.getNextId(), name = 'some name', type = 'SUP', @@ -21,3 +21,5 @@ module.exports = function buildCertificationCenter({ values, }); }; + +export { buildCertificationCenter }; diff --git a/api/db/database-builder/factory/build-certification-challenge.js b/api/db/database-builder/factory/build-certification-challenge.js index 05fa872365f..b18b068f008 100644 --- a/api/db/database-builder/factory/build-certification-challenge.js +++ b/api/db/database-builder/factory/build-certification-challenge.js @@ -1,8 +1,8 @@ -const buildCertificationCourse = require('./build-certification-course'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildCertificationCourse } from './build-certification-course.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildCertificationChallenge({ +const buildCertificationChallenge = function ({ id = databaseBuffer.getNextId(), associatedSkillName = '@twi8', associatedSkillId = 'recSKIL123', @@ -35,3 +35,5 @@ module.exports = function buildCertificationChallenge({ values, }); }; + +export { buildCertificationChallenge }; diff --git a/api/db/database-builder/factory/build-certification-course-last-assessment-result.js b/api/db/database-builder/factory/build-certification-course-last-assessment-result.js index 1291d523855..213eb474e2d 100644 --- a/api/db/database-builder/factory/build-certification-course-last-assessment-result.js +++ b/api/db/database-builder/factory/build-certification-course-last-assessment-result.js @@ -1,9 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildCertificationCourseLastAssessmentResult({ - certificationCourseId, - lastAssessmentResultId, -} = {}) { +const buildCertificationCourseLastAssessmentResult = function ({ certificationCourseId, lastAssessmentResultId } = {}) { const values = { certificationCourseId, lastAssessmentResultId, @@ -13,3 +10,5 @@ module.exports = function buildCertificationCourseLastAssessmentResult({ values, }); }; + +export { buildCertificationCourseLastAssessmentResult }; diff --git a/api/db/database-builder/factory/build-certification-course.js b/api/db/database-builder/factory/build-certification-course.js index 387085c73fd..1fb3f7a782a 100644 --- a/api/db/database-builder/factory/build-certification-course.js +++ b/api/db/database-builder/factory/build-certification-course.js @@ -1,9 +1,9 @@ -const buildSession = require('./build-session'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildSession } from './build-session.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildCertificationCourse({ +const buildCertificationCourse = function ({ id = databaseBuffer.getNextId(), lastName = 'last-name', firstName = 'first-name', @@ -64,3 +64,5 @@ module.exports = function buildCertificationCourse({ values, }); }; + +export { buildCertificationCourse }; diff --git a/api/db/database-builder/factory/build-certification-cpf-city.js b/api/db/database-builder/factory/build-certification-cpf-city.js index 5f5ad13ba50..57f089af738 100644 --- a/api/db/database-builder/factory/build-certification-cpf-city.js +++ b/api/db/database-builder/factory/build-certification-cpf-city.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildCertificationCpfCity({ +const buildCertificationCpfCity = function ({ id = databaseBuffer.getNextId(), name = 'PARIS 19', postalCode = '75019', @@ -20,3 +20,5 @@ module.exports = function buildCertificationCpfCity({ values, }); }; + +export { buildCertificationCpfCity }; diff --git a/api/db/database-builder/factory/build-certification-cpf-country.js b/api/db/database-builder/factory/build-certification-cpf-country.js index d1ddadfa1d0..a5e7981c787 100644 --- a/api/db/database-builder/factory/build-certification-cpf-country.js +++ b/api/db/database-builder/factory/build-certification-cpf-country.js @@ -1,7 +1,7 @@ -const databaseBuffer = require('../database-buffer'); -const { normalizeAndSortChars } = require('../../../lib/infrastructure/utils/string-utils'); +import { databaseBuffer } from '../database-buffer.js'; +import { normalizeAndSortChars } from '../../../lib/infrastructure/utils/string-utils.js'; -module.exports = function buildCertificationCpfCountry({ +const buildCertificationCpfCountry = function ({ id = databaseBuffer.getNextId(), code = '99123', commonName = 'FILÉKISTANIE', @@ -22,3 +22,5 @@ module.exports = function buildCertificationCpfCountry({ values, }); }; + +export { buildCertificationCpfCountry }; diff --git a/api/db/database-builder/factory/build-certification-issue-report.js b/api/db/database-builder/factory/build-certification-issue-report.js index 090083b9f10..fce4e3bd059 100644 --- a/api/db/database-builder/factory/build-certification-issue-report.js +++ b/api/db/database-builder/factory/build-certification-issue-report.js @@ -1,9 +1,9 @@ -const buildCertificationCourse = require('./build-certification-course'); -const buildIssueReportCategory = require('./build-issue-report-category'); -const _ = require('lodash'); -const databaseBuffer = require('../database-buffer'); +import { buildCertificationCourse } from './build-certification-course.js'; +import { buildIssueReportCategory } from './build-issue-report-category.js'; +import _ from 'lodash'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildCertificationIssueReport({ +const buildCertificationIssueReport = function ({ id = databaseBuffer.getNextId(), certificationCourseId, categoryId, @@ -35,3 +35,5 @@ module.exports = function buildCertificationIssueReport({ values, }); }; + +export { buildCertificationIssueReport }; diff --git a/api/db/database-builder/factory/build-certification-report.js b/api/db/database-builder/factory/build-certification-report.js index 3aa278f3aa2..e57ed01c634 100644 --- a/api/db/database-builder/factory/build-certification-report.js +++ b/api/db/database-builder/factory/build-certification-report.js @@ -1,8 +1,8 @@ -const buildCertificationCourse = require('./build-certification-course'); -const CertificationReport = require('../../../lib/domain/models/CertificationReport'); -const _ = require('lodash'); +import { buildCertificationCourse } from './build-certification-course.js'; +import { CertificationReport } from '../../../lib/domain/models/CertificationReport.js'; +import _ from 'lodash'; -module.exports = function buildCertificationReport({ +const buildCertificationReport = function ({ firstName = 'Bobby', lastName = 'Lapointe', isCompleted = true, @@ -28,3 +28,5 @@ module.exports = function buildCertificationReport({ }; return values; }; + +export { buildCertificationReport }; diff --git a/api/db/database-builder/factory/build-competence-evaluation.js b/api/db/database-builder/factory/build-competence-evaluation.js index 0435e43c3e9..9a0ed8a03f0 100644 --- a/api/db/database-builder/factory/build-competence-evaluation.js +++ b/api/db/database-builder/factory/build-competence-evaluation.js @@ -1,10 +1,10 @@ -const buildAssessment = require('./build-assessment'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); -const CompetenceEvaluation = require('../../../lib/domain/models/CompetenceEvaluation'); -const _ = require('lodash'); +import { buildAssessment } from './build-assessment.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; +import { CompetenceEvaluation } from '../../../lib/domain/models/CompetenceEvaluation.js'; +import _ from 'lodash'; -module.exports = function buildCompetenceEvaluation({ +const buildCompetenceEvaluation = function ({ id = databaseBuffer.getNextId(), assessmentId, competenceId = 'recABC123', @@ -31,3 +31,5 @@ module.exports = function buildCompetenceEvaluation({ values, }); }; + +export { buildCompetenceEvaluation }; diff --git a/api/db/database-builder/factory/build-competence-mark.js b/api/db/database-builder/factory/build-competence-mark.js index aabfd3ce2b4..fd100615716 100644 --- a/api/db/database-builder/factory/build-competence-mark.js +++ b/api/db/database-builder/factory/build-competence-mark.js @@ -1,8 +1,8 @@ -const buildAssessmentResult = require('./build-assessment-result'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildAssessmentResult } from './build-assessment-result.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildCompetenceMark({ +const buildCompetenceMark = function ({ id = databaseBuffer.getNextId(), level = 5, score = 42, @@ -29,3 +29,5 @@ module.exports = function buildCompetenceMark({ values, }); }; + +export { buildCompetenceMark }; diff --git a/api/db/database-builder/factory/build-complementary-certification-badge.js b/api/db/database-builder/factory/build-complementary-certification-badge.js index e92d3d6d93f..220f85ad194 100644 --- a/api/db/database-builder/factory/build-complementary-certification-badge.js +++ b/api/db/database-builder/factory/build-complementary-certification-badge.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const buildBadge = require('./build-badge'); -const buildComplementaryCertification = require('./build-complementary-certification'); -const databaseBuffer = require('../database-buffer'); +import _ from 'lodash'; +import { buildBadge } from './build-badge.js'; +import { buildComplementaryCertification } from './build-complementary-certification.js'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildComplementaryCertificationBadge({ +const buildComplementaryCertificationBadge = function ({ id = databaseBuffer.getNextId(), level = 1, complementaryCertificationId, @@ -37,3 +37,5 @@ module.exports = function buildComplementaryCertificationBadge({ values, }); }; + +export { buildComplementaryCertificationBadge }; diff --git a/api/db/database-builder/factory/build-complementary-certification-course-result.js b/api/db/database-builder/factory/build-complementary-certification-course-result.js index 33298a6d073..b69049a6409 100644 --- a/api/db/database-builder/factory/build-complementary-certification-course-result.js +++ b/api/db/database-builder/factory/build-complementary-certification-course-result.js @@ -1,11 +1,11 @@ -const databaseBuffer = require('../database-buffer'); -const buildComplementaryCertificationCourse = require('./build-complementary-certification-course'); -const buildComplementaryCertification = require('./build-complementary-certification'); -const buildCertificationCourse = require('./build-certification-course'); -const _ = require('lodash'); -const ComplementaryCertificationCourseResult = require('../../../lib/domain/models/ComplementaryCertificationCourseResult'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildComplementaryCertificationCourse } from './build-complementary-certification-course.js'; +import { buildComplementaryCertification } from './build-complementary-certification.js'; +import { buildCertificationCourse } from './build-certification-course.js'; +import _ from 'lodash'; +import { ComplementaryCertificationCourseResult } from '../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; -module.exports = function buildComplementaryCertificationCourseResult({ +const buildComplementaryCertificationCourseResult = function ({ complementaryCertificationCourseId, partnerKey, source = ComplementaryCertificationCourseResult.sources.PIX, @@ -20,6 +20,8 @@ module.exports = function buildComplementaryCertificationCourseResult({ }); }; +export { buildComplementaryCertificationCourseResult }; + function _buildComplementaryCertificationCourse() { const { id: complementaryCertificationId } = buildComplementaryCertification(); const { id: certificationCourseId } = buildCertificationCourse(); diff --git a/api/db/database-builder/factory/build-complementary-certification-course.js b/api/db/database-builder/factory/build-complementary-certification-course.js index c2ecfab9706..6f2128f72ba 100644 --- a/api/db/database-builder/factory/build-complementary-certification-course.js +++ b/api/db/database-builder/factory/build-complementary-certification-course.js @@ -1,8 +1,8 @@ -const buildComplementaryCertification = require('./build-complementary-certification'); -const buildComplementaryCertificationBadge = require('./build-complementary-certification-badge'); -const databaseBuffer = require('../database-buffer'); +import { buildComplementaryCertification } from './build-complementary-certification.js'; +import { buildComplementaryCertificationBadge } from './build-complementary-certification-badge.js'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildComplementaryCertificationCourse({ +const buildComplementaryCertificationCourse = function ({ id = databaseBuffer.getNextId(), complementaryCertificationId, certificationCourseId, @@ -28,3 +28,5 @@ module.exports = function buildComplementaryCertificationCourse({ values, }); }; + +export { buildComplementaryCertificationCourse }; diff --git a/api/db/database-builder/factory/build-complementary-certification-habilitation.js b/api/db/database-builder/factory/build-complementary-certification-habilitation.js index b5f34f88ec5..9d54f664f81 100644 --- a/api/db/database-builder/factory/build-complementary-certification-habilitation.js +++ b/api/db/database-builder/factory/build-complementary-certification-habilitation.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const buildCertificationCenter = require('./build-certification-center'); -const buildComplementaryCertification = require('./build-complementary-certification'); -const databaseBuffer = require('../database-buffer'); +import _ from 'lodash'; +import { buildCertificationCenter } from './build-certification-center.js'; +import { buildComplementaryCertification } from './build-complementary-certification.js'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildComplementaryCertificationHabilitation({ +const buildComplementaryCertificationHabilitation = function ({ id = databaseBuffer.getNextId(), certificationCenterId, complementaryCertificationId, @@ -25,3 +25,5 @@ module.exports = function buildComplementaryCertificationHabilitation({ values, }); }; + +export { buildComplementaryCertificationHabilitation }; diff --git a/api/db/database-builder/factory/build-complementary-certification-subscription.js b/api/db/database-builder/factory/build-complementary-certification-subscription.js index e0bbacc6a33..b5e8b2f2e2a 100644 --- a/api/db/database-builder/factory/build-complementary-certification-subscription.js +++ b/api/db/database-builder/factory/build-complementary-certification-subscription.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const buildCertificationCandidate = require('./build-certification-candidate'); -const buildComplementaryCertification = require('./build-complementary-certification'); -const databaseBuffer = require('../database-buffer'); +import _ from 'lodash'; +import { buildCertificationCandidate } from './build-certification-candidate.js'; +import { buildComplementaryCertification } from './build-complementary-certification.js'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildComplementaryCertificationSubscription({ +const buildComplementaryCertificationSubscription = function ({ certificationCandidateId, complementaryCertificationId, createdAt = new Date('2020-01-01'), @@ -25,3 +25,5 @@ module.exports = function buildComplementaryCertificationSubscription({ values, }); }; + +export { buildComplementaryCertificationSubscription }; diff --git a/api/db/database-builder/factory/build-complementary-certification.js b/api/db/database-builder/factory/build-complementary-certification.js index f96f353c009..651a18c0fae 100644 --- a/api/db/database-builder/factory/build-complementary-certification.js +++ b/api/db/database-builder/factory/build-complementary-certification.js @@ -1,5 +1,5 @@ -const ComplementaryCertification = require('../../../lib/domain/models/ComplementaryCertification'); -const databaseBuffer = require('../database-buffer'); +import { ComplementaryCertification } from '../../../lib/domain/models/ComplementaryCertification.js'; +import { databaseBuffer } from '../database-buffer.js'; function buildComplementaryCertification({ id = databaseBuffer.getNextId(), @@ -50,4 +50,4 @@ buildComplementaryCertification.clea = function ({ }); }; -module.exports = buildComplementaryCertification; +export { buildComplementaryCertification }; diff --git a/api/db/database-builder/factory/build-correct-answer-and-knowledge-element.js b/api/db/database-builder/factory/build-correct-answer-and-knowledge-element.js index 639dc161f9f..c16199178dc 100644 --- a/api/db/database-builder/factory/build-correct-answer-and-knowledge-element.js +++ b/api/db/database-builder/factory/build-correct-answer-and-knowledge-element.js @@ -1,6 +1,6 @@ -const buildAssessment = require('./build-assessment'); -const buildAnswer = require('./build-answer'); -const buildKnowledgeElement = require('./build-knowledge-element'); +import { buildAssessment } from './build-assessment.js'; +import { buildAnswer } from './build-answer.js'; +import { buildKnowledgeElement } from './build-knowledge-element.js'; const buildCorrectAnswerAndKnowledgeElement = async function ({ userId, @@ -26,4 +26,4 @@ const buildCorrectAnswerAndKnowledgeElement = async function ({ }); }; -module.exports = buildCorrectAnswerAndKnowledgeElement; +export { buildCorrectAnswerAndKnowledgeElement }; diff --git a/api/db/database-builder/factory/build-correct-answers-and-knowledge-elements-for-learning-content.js b/api/db/database-builder/factory/build-correct-answers-and-knowledge-elements-for-learning-content.js index 1aaf5d38334..e07bb2feb60 100644 --- a/api/db/database-builder/factory/build-correct-answers-and-knowledge-elements-for-learning-content.js +++ b/api/db/database-builder/factory/build-correct-answers-and-knowledge-elements-for-learning-content.js @@ -1,5 +1,5 @@ -const buildCorrectAnswerAndKnowledgeElement = require('./build-correct-answer-and-knowledge-element'); -const _ = require('lodash'); +import { buildCorrectAnswerAndKnowledgeElement } from './build-correct-answer-and-knowledge-element.js'; +import _ from 'lodash'; const buildCorrectAnswersAndKnowledgeElementsForLearningContent = function ({ learningContent, @@ -57,4 +57,4 @@ buildCorrectAnswersAndKnowledgeElementsForLearningContent.fromAreas = function ( }); }; -module.exports = buildCorrectAnswersAndKnowledgeElementsForLearningContent; +export { buildCorrectAnswersAndKnowledgeElementsForLearningContent }; diff --git a/api/db/database-builder/factory/build-data-protection-officer.js b/api/db/database-builder/factory/build-data-protection-officer.js index eab1755200e..db5f1e4d624 100644 --- a/api/db/database-builder/factory/build-data-protection-officer.js +++ b/api/db/database-builder/factory/build-data-protection-officer.js @@ -1,4 +1,4 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; const TABLE_NAME = 'data-protection-officers'; @@ -52,7 +52,7 @@ function buildOrganizationDataProtectionOfficer({ }); } -module.exports = { - withCertificationCenterId: buildCertificationCenterDataProtectionOfficer, - withOrganizationId: buildOrganizationDataProtectionOfficer, +export { + buildCertificationCenterDataProtectionOfficer as withCertificationCenterId, + buildOrganizationDataProtectionOfficer as withOrganizationId, }; diff --git a/api/db/database-builder/factory/build-feature.js b/api/db/database-builder/factory/build-feature.js index 6f678f50c09..f5dee6959f4 100644 --- a/api/db/database-builder/factory/build-feature.js +++ b/api/db/database-builder/factory/build-feature.js @@ -1,4 +1,4 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; const buildFeature = function buildFeature({ id = databaseBuffer.getNextId(), key, description } = {}) { const values = { @@ -13,4 +13,4 @@ const buildFeature = function buildFeature({ id = databaseBuffer.getNextId(), ke }); }; -module.exports = buildFeature; +export { buildFeature }; diff --git a/api/db/database-builder/factory/build-finalized-session.js b/api/db/database-builder/factory/build-finalized-session.js index 8c10b2de523..4f5964f2aa7 100644 --- a/api/db/database-builder/factory/build-finalized-session.js +++ b/api/db/database-builder/factory/build-finalized-session.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildFinalizedSession({ +const buildFinalizedSession = function ({ sessionId = databaseBuffer.getNextId(), certificationCenterName = 'Centre de certif PIX', finalizedAt = new Date('2020-01-01'), @@ -26,3 +26,5 @@ module.exports = function buildFinalizedSession({ values, }); }; + +export { buildFinalizedSession }; diff --git a/api/db/database-builder/factory/build-flash-assessment-result.js b/api/db/database-builder/factory/build-flash-assessment-result.js index 1ee2160ca8e..7a25cd15e08 100644 --- a/api/db/database-builder/factory/build-flash-assessment-result.js +++ b/api/db/database-builder/factory/build-flash-assessment-result.js @@ -1,7 +1,7 @@ -const databaseBuffer = require('../database-buffer'); -const buildAnswer = require('./build-answer'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildAnswer } from './build-answer.js'; -module.exports = function buildFlashAssessmentResult({ +const buildFlashAssessmentResult = function ({ id = databaseBuffer.getNextId(), answerId, assessmentId, @@ -21,3 +21,5 @@ module.exports = function buildFlashAssessmentResult({ }, }); }; + +export { buildFlashAssessmentResult }; diff --git a/api/db/database-builder/factory/build-issue-report-category.js b/api/db/database-builder/factory/build-issue-report-category.js index f93589d4758..196b15c8283 100644 --- a/api/db/database-builder/factory/build-issue-report-category.js +++ b/api/db/database-builder/factory/build-issue-report-category.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildIssueReportCategory({ +const buildIssueReportCategory = function ({ id = databaseBuffer.getNextId(), name = 'Some problem', isDeprecated = false, @@ -19,3 +19,5 @@ module.exports = function buildIssueReportCategory({ values, }); }; + +export { buildIssueReportCategory }; diff --git a/api/db/database-builder/factory/build-knowledge-element-snapshot.js b/api/db/database-builder/factory/build-knowledge-element-snapshot.js index e1cdfbf8d97..76263471078 100644 --- a/api/db/database-builder/factory/build-knowledge-element-snapshot.js +++ b/api/db/database-builder/factory/build-knowledge-element-snapshot.js @@ -1,9 +1,9 @@ -const buildKnowledgeElement = require('./build-knowledge-element'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildKnowledgeElement } from './build-knowledge-element.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildKnowledgeElementSnapshot({ +const buildKnowledgeElementSnapshot = function ({ id = databaseBuffer.getNextId(), userId, snappedAt = new Date('2020-01-01'), @@ -30,3 +30,5 @@ module.exports = function buildKnowledgeElementSnapshot({ values, }); }; + +export { buildKnowledgeElementSnapshot }; diff --git a/api/db/database-builder/factory/build-knowledge-element.js b/api/db/database-builder/factory/build-knowledge-element.js index c105e3a457d..e067c0c99fc 100644 --- a/api/db/database-builder/factory/build-knowledge-element.js +++ b/api/db/database-builder/factory/build-knowledge-element.js @@ -1,11 +1,11 @@ -const buildAnswer = require('./build-answer'); -const buildAssessment = require('./build-assessment'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); -const KnowledgeElement = require('../../../lib/domain/models/KnowledgeElement'); -const _ = require('lodash'); +import { buildAnswer } from './build-answer.js'; +import { buildAssessment } from './build-assessment.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; +import { KnowledgeElement } from '../../../lib/domain/models/KnowledgeElement.js'; +import _ from 'lodash'; -module.exports = function buildKnowledgeElement({ +const buildKnowledgeElement = function ({ id = databaseBuffer.getNextId(), source = KnowledgeElement.SourceType.DIRECT, status = KnowledgeElement.StatusType.VALIDATED, @@ -39,3 +39,5 @@ module.exports = function buildKnowledgeElement({ values, }); }; + +export { buildKnowledgeElement }; diff --git a/api/db/database-builder/factory/build-membership.js b/api/db/database-builder/factory/build-membership.js index 49b2d1aa961..0c6761f39f5 100644 --- a/api/db/database-builder/factory/build-membership.js +++ b/api/db/database-builder/factory/build-membership.js @@ -1,10 +1,10 @@ -const databaseBuffer = require('../database-buffer'); -const buildUser = require('./build-user'); -const buildOrganization = require('./build-organization'); -const Membership = require('../../../lib/domain/models/Membership'); -const _ = require('lodash'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildUser } from './build-user.js'; +import { buildOrganization } from './build-organization.js'; +import { Membership } from '../../../lib/domain/models/Membership.js'; +import _ from 'lodash'; -module.exports = function buildMembership({ +const buildMembership = function ({ id = databaseBuffer.getNextId(), organizationRole = Membership.roles.MEMBER, organizationId, @@ -30,3 +30,5 @@ module.exports = function buildMembership({ values, }); }; + +export { buildMembership }; diff --git a/api/db/database-builder/factory/build-organization-feature.js b/api/db/database-builder/factory/build-organization-feature.js index 5f3b87a0d56..59063b5164c 100644 --- a/api/db/database-builder/factory/build-organization-feature.js +++ b/api/db/database-builder/factory/build-organization-feature.js @@ -1,4 +1,4 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; const buildOrganizationFeature = function buildOrganizationFeature({ id = databaseBuffer.getNextId(), @@ -17,4 +17,4 @@ const buildOrganizationFeature = function buildOrganizationFeature({ }); }; -module.exports = buildOrganizationFeature; +export { buildOrganizationFeature }; diff --git a/api/db/database-builder/factory/build-organization-invitation.js b/api/db/database-builder/factory/build-organization-invitation.js index 2d644cd006e..472dc7e2985 100644 --- a/api/db/database-builder/factory/build-organization-invitation.js +++ b/api/db/database-builder/factory/build-organization-invitation.js @@ -1,9 +1,9 @@ -const databaseBuffer = require('../database-buffer'); -const buildOrganization = require('./build-organization'); -const OrganizationInvitation = require('../../../lib/domain/models/OrganizationInvitation'); -const _ = require('lodash'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildOrganization } from './build-organization.js'; +import { OrganizationInvitation } from '../../../lib/domain/models/OrganizationInvitation.js'; +import _ from 'lodash'; -module.exports = function buildOrganizationInvitation({ +const buildOrganizationInvitation = function ({ id = databaseBuffer.getNextId(), organizationId, email = 'some.mail@example.net', @@ -30,3 +30,5 @@ module.exports = function buildOrganizationInvitation({ values, }); }; + +export { buildOrganizationInvitation }; diff --git a/api/db/database-builder/factory/build-organization-learner-with-user.js b/api/db/database-builder/factory/build-organization-learner-with-user.js index 164c6a092b8..c2127b5a4e3 100644 --- a/api/db/database-builder/factory/build-organization-learner-with-user.js +++ b/api/db/database-builder/factory/build-organization-learner-with-user.js @@ -1,9 +1,9 @@ -const buildOrganization = require('./build-organization'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildOrganization } from './build-organization.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildOrganizationLearnerWithUser({ +const buildOrganizationLearnerWithUser = function ({ id = databaseBuffer.getNextId(), firstName = 'first-name', preferredLastName = 'pref-last-name', @@ -56,3 +56,5 @@ module.exports = function buildOrganizationLearnerWithUser({ values, }); }; + +export { buildOrganizationLearnerWithUser }; diff --git a/api/db/database-builder/factory/build-organization-learner.js b/api/db/database-builder/factory/build-organization-learner.js index f535b90068b..74df7efb744 100644 --- a/api/db/database-builder/factory/build-organization-learner.js +++ b/api/db/database-builder/factory/build-organization-learner.js @@ -1,9 +1,9 @@ -const buildOrganization = require('./build-organization'); -const buildUser = require('./build-user'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildOrganization } from './build-organization.js'; +import { buildUser } from './build-user.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildOrganizationLearner({ +const buildOrganizationLearner = function ({ id = databaseBuffer.getNextId(), firstName = 'first-name', preferredLastName = 'pref-last-name', @@ -74,3 +74,5 @@ module.exports = function buildOrganizationLearner({ values, }); }; + +export { buildOrganizationLearner }; diff --git a/api/db/database-builder/factory/build-organization-place.js b/api/db/database-builder/factory/build-organization-place.js index 1b2a6760c97..49b3c5ab4a2 100644 --- a/api/db/database-builder/factory/build-organization-place.js +++ b/api/db/database-builder/factory/build-organization-place.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); -const buildOrganization = require('./build-organization'); -const buildUser = require('./build-user'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildOrganization } from './build-organization.js'; +import { buildUser } from './build-user.js'; const buildOrganizationPlace = function buildOrganizationPlace({ id = databaseBuffer.getNextId(), @@ -38,4 +38,4 @@ const buildOrganizationPlace = function buildOrganizationPlace({ }); }; -module.exports = buildOrganizationPlace; +export { buildOrganizationPlace }; diff --git a/api/db/database-builder/factory/build-organization-tag.js b/api/db/database-builder/factory/build-organization-tag.js index 40bd4ebf875..124d0dc7b0b 100644 --- a/api/db/database-builder/factory/build-organization-tag.js +++ b/api/db/database-builder/factory/build-organization-tag.js @@ -1,9 +1,9 @@ -const databaseBuffer = require('../database-buffer'); -const buildOrganization = require('./build-organization'); -const buildTag = require('./build-tag'); -const _ = require('lodash'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildOrganization } from './build-organization.js'; +import { buildTag } from './build-tag.js'; +import _ from 'lodash'; -module.exports = function buildOrganizationTag({ id = databaseBuffer.getNextId(), organizationId, tagId } = {}) { +const buildOrganizationTag = function ({ id = databaseBuffer.getNextId(), organizationId, tagId } = {}) { tagId = _.isUndefined(tagId) ? buildTag().id : tagId; organizationId = _.isUndefined(organizationId) ? buildOrganization().id : organizationId; @@ -17,3 +17,5 @@ module.exports = function buildOrganizationTag({ id = databaseBuffer.getNextId() values, }); }; + +export { buildOrganizationTag }; diff --git a/api/db/database-builder/factory/build-organization.js b/api/db/database-builder/factory/build-organization.js index d53d200a8bb..6f8a56106d0 100644 --- a/api/db/database-builder/factory/build-organization.js +++ b/api/db/database-builder/factory/build-organization.js @@ -1,4 +1,4 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; const buildOrganization = function buildOrganization({ id = databaseBuffer.getNextId(), @@ -49,4 +49,4 @@ const buildOrganization = function buildOrganization({ }); }; -module.exports = buildOrganization; +export { buildOrganization }; diff --git a/api/db/database-builder/factory/build-pix-admin-role.js b/api/db/database-builder/factory/build-pix-admin-role.js index 202d21f5d02..017eb964f2c 100644 --- a/api/db/database-builder/factory/build-pix-admin-role.js +++ b/api/db/database-builder/factory/build-pix-admin-role.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildPixAdminRole({ +const buildPixAdminRole = function ({ id = databaseBuffer.getNextId(), userId, role, @@ -13,3 +13,5 @@ module.exports = function buildPixAdminRole({ values: { id, userId, role, createdAt, updatedAt, disabledAt }, }); }; + +export { buildPixAdminRole }; diff --git a/api/db/database-builder/factory/build-reset-password-demand.js b/api/db/database-builder/factory/build-reset-password-demand.js index 69e689e5c2c..387a426dc6d 100644 --- a/api/db/database-builder/factory/build-reset-password-demand.js +++ b/api/db/database-builder/factory/build-reset-password-demand.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildResetPasswordDemand({ +const buildResetPasswordDemand = function ({ id = databaseBuffer.getNextId(), email = 'example@example.net', temporaryKey = 'ABCD12345', @@ -17,3 +17,5 @@ module.exports = function buildResetPasswordDemand({ values, }); }; + +export { buildResetPasswordDemand }; diff --git a/api/db/database-builder/factory/build-session.js b/api/db/database-builder/factory/build-session.js index 7a49571ff04..2d3e42fa437 100644 --- a/api/db/database-builder/factory/build-session.js +++ b/api/db/database-builder/factory/build-session.js @@ -1,8 +1,8 @@ -const buildCertificationCenter = require('./build-certification-center'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildCertificationCenter } from './build-certification-center.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildSession({ +const buildSession = function ({ id = databaseBuffer.getNextId(), accessCode = 'FMKP39', address = '3 rue des églantines', @@ -60,3 +60,5 @@ module.exports = function buildSession({ values, }); }; + +export { buildSession }; diff --git a/api/db/database-builder/factory/build-skill-set.js b/api/db/database-builder/factory/build-skill-set.js index abf56495714..6c2d911a25e 100644 --- a/api/db/database-builder/factory/build-skill-set.js +++ b/api/db/database-builder/factory/build-skill-set.js @@ -1,12 +1,7 @@ -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildSkillSet({ - id = databaseBuffer.getNextId(), - name = 'name', - skillIds = [], - badgeId, -} = {}) { +const buildSkillSet = function ({ id = databaseBuffer.getNextId(), name = 'name', skillIds = [], badgeId } = {}) { if (_.isEmpty(skillIds)) { skillIds = ['recABC123', 'recDEF456']; } @@ -23,3 +18,5 @@ module.exports = function buildSkillSet({ values, }); }; + +export { buildSkillSet }; diff --git a/api/db/database-builder/factory/build-stage.js b/api/db/database-builder/factory/build-stage.js index a0c7bf34ae5..350e42014f2 100644 --- a/api/db/database-builder/factory/build-stage.js +++ b/api/db/database-builder/factory/build-stage.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); -const buildTargetProfile = require('./build-target-profile'); +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; +import { buildTargetProfile } from './build-target-profile.js'; function buildStage({ id = databaseBuffer.getNextId(), @@ -96,4 +96,4 @@ buildStage.firstSkill = function ({ }); }; -module.exports = buildStage; +export { buildStage }; diff --git a/api/db/database-builder/factory/build-supervisor-access.js b/api/db/database-builder/factory/build-supervisor-access.js index 60e388ec178..9abfdfd1607 100644 --- a/api/db/database-builder/factory/build-supervisor-access.js +++ b/api/db/database-builder/factory/build-supervisor-access.js @@ -1,9 +1,9 @@ -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); -const buildUser = require('./build-user'); -const buildSession = require('./build-session'); +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; +import { buildUser } from './build-user.js'; +import { buildSession } from './build-session.js'; -module.exports = function buildSupervisorAccess({ +const buildSupervisorAccess = function ({ id = databaseBuffer.getNextId(), sessionId, userId, @@ -22,3 +22,5 @@ module.exports = function buildSupervisorAccess({ values, }); }; + +export { buildSupervisorAccess }; diff --git a/api/db/database-builder/factory/build-tag.js b/api/db/database-builder/factory/build-tag.js index 0855aa95335..49174712295 100644 --- a/api/db/database-builder/factory/build-tag.js +++ b/api/db/database-builder/factory/build-tag.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildTag({ id = databaseBuffer.getNextId(), name = 'Tag' } = {}) { +const buildTag = function ({ id = databaseBuffer.getNextId(), name = 'Tag' } = {}) { const values = { id, name, @@ -10,3 +10,5 @@ module.exports = function buildTag({ id = databaseBuffer.getNextId(), name = 'Ta values, }); }; + +export { buildTag }; diff --git a/api/db/database-builder/factory/build-target-profile-share.js b/api/db/database-builder/factory/build-target-profile-share.js index 099e80d82d8..f0bfebbf383 100644 --- a/api/db/database-builder/factory/build-target-profile-share.js +++ b/api/db/database-builder/factory/build-target-profile-share.js @@ -1,9 +1,9 @@ -const buildOrganization = require('./build-organization'); -const buildTargetProfile = require('./build-target-profile'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildOrganization } from './build-organization.js'; +import { buildTargetProfile } from './build-target-profile.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildTargetProfileShare({ +const buildTargetProfileShare = function ({ id = databaseBuffer.getNextId(), targetProfileId, organizationId, @@ -23,3 +23,5 @@ module.exports = function buildTargetProfileShare({ values, }); }; + +export { buildTargetProfileShare }; diff --git a/api/db/database-builder/factory/build-target-profile-skill.js b/api/db/database-builder/factory/build-target-profile-skill.js index c2d38f710b2..e0c328848e4 100644 --- a/api/db/database-builder/factory/build-target-profile-skill.js +++ b/api/db/database-builder/factory/build-target-profile-skill.js @@ -1,8 +1,8 @@ -const buildTargetProfile = require('./build-target-profile'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildTargetProfile } from './build-target-profile.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildTargetProfileSkill({ +const buildTargetProfileSkill = function ({ id = databaseBuffer.getNextId(), targetProfileId, skillId = 'recSKI456', @@ -19,3 +19,5 @@ module.exports = function buildTargetProfileSkill({ values, }); }; + +export { buildTargetProfileSkill }; diff --git a/api/db/database-builder/factory/build-target-profile-training.js b/api/db/database-builder/factory/build-target-profile-training.js index 138b9a39294..aece2bd3de5 100644 --- a/api/db/database-builder/factory/build-target-profile-training.js +++ b/api/db/database-builder/factory/build-target-profile-training.js @@ -1,10 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildTargetProfileTraining({ - id = databaseBuffer.getNextId(), - trainingId, - targetProfileId, -} = {}) { +const buildTargetProfileTraining = function ({ id = databaseBuffer.getNextId(), trainingId, targetProfileId } = {}) { const values = { id, trainingId, @@ -15,3 +11,5 @@ module.exports = function buildTargetProfileTraining({ values, }); }; + +export { buildTargetProfileTraining }; diff --git a/api/db/database-builder/factory/build-target-profile-tube.js b/api/db/database-builder/factory/build-target-profile-tube.js index 0d4e2f68f7c..d90d815d968 100644 --- a/api/db/database-builder/factory/build-target-profile-tube.js +++ b/api/db/database-builder/factory/build-target-profile-tube.js @@ -1,7 +1,7 @@ -const buildTargetProfile = require('./build-target-profile'); -const databaseBuffer = require('../database-buffer'); +import { buildTargetProfile } from './build-target-profile.js'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildTargetProfileTube({ +const buildTargetProfileTube = function ({ id = databaseBuffer.getNextId(), targetProfileId = buildTargetProfile().id, tubeId = 'tubeId1', @@ -18,3 +18,5 @@ module.exports = function buildTargetProfileTube({ values, }); }; + +export { buildTargetProfileTube }; diff --git a/api/db/database-builder/factory/build-target-profile.js b/api/db/database-builder/factory/build-target-profile.js index 0f31833eb27..a91d5b1de55 100644 --- a/api/db/database-builder/factory/build-target-profile.js +++ b/api/db/database-builder/factory/build-target-profile.js @@ -1,8 +1,8 @@ -const buildOrganization = require('./build-organization'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildOrganization } from './build-organization.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; -module.exports = function buildTargetProfile({ +const buildTargetProfile = function ({ id = databaseBuffer.getNextId(), name = 'Remplir un tableur', imageUrl = 'https://images.pix.fr/profil-cible/Illu_GEN.svg', @@ -37,3 +37,5 @@ module.exports = function buildTargetProfile({ values, }); }; + +export { buildTargetProfile }; diff --git a/api/db/database-builder/factory/build-training-trigger-tube.js b/api/db/database-builder/factory/build-training-trigger-tube.js index 56b036f29f6..714117f6440 100644 --- a/api/db/database-builder/factory/build-training-trigger-tube.js +++ b/api/db/database-builder/factory/build-training-trigger-tube.js @@ -1,7 +1,7 @@ -const buildTrainingTrigger = require('./build-training-trigger'); -const databaseBuffer = require('../database-buffer'); +import { buildTrainingTrigger } from './build-training-trigger.js'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildTrainingTriggerTube({ +const buildTrainingTriggerTube = function ({ id = databaseBuffer.getNextId(), trainingTriggerId = buildTrainingTrigger().id, tubeId = 'tubeId1', @@ -18,3 +18,5 @@ module.exports = function buildTrainingTriggerTube({ values, }); }; + +export { buildTrainingTriggerTube }; diff --git a/api/db/database-builder/factory/build-training-trigger.js b/api/db/database-builder/factory/build-training-trigger.js index ac3f4710760..8c46bb02a6b 100644 --- a/api/db/database-builder/factory/build-training-trigger.js +++ b/api/db/database-builder/factory/build-training-trigger.js @@ -1,7 +1,7 @@ -const buildTraining = require('./build-training'); -const databaseBuffer = require('../database-buffer'); +import { buildTraining } from './build-training.js'; +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildTrainingTrigger({ +const buildTrainingTrigger = function ({ id = databaseBuffer.getNextId(), trainingId = buildTraining().id, threshold = 80, @@ -22,3 +22,5 @@ module.exports = function buildTrainingTrigger({ values, }); }; + +export { buildTrainingTrigger }; diff --git a/api/db/database-builder/factory/build-training.js b/api/db/database-builder/factory/build-training.js index f3ea438d22e..5c4fd5f49be 100644 --- a/api/db/database-builder/factory/build-training.js +++ b/api/db/database-builder/factory/build-training.js @@ -1,4 +1,4 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; function buildTraining({ id = databaseBuffer.getNextId(), @@ -30,4 +30,4 @@ function buildTraining({ }); } -module.exports = buildTraining; +export { buildTraining }; diff --git a/api/db/database-builder/factory/build-tutorial-evaluation.js b/api/db/database-builder/factory/build-tutorial-evaluation.js index ec605d83900..86c8a415173 100644 --- a/api/db/database-builder/factory/build-tutorial-evaluation.js +++ b/api/db/database-builder/factory/build-tutorial-evaluation.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildTutorialEvaluation({ +const buildTutorialEvaluation = function ({ id = databaseBuffer.getNextId(), tutorialId, userId, @@ -18,3 +18,5 @@ module.exports = function buildTutorialEvaluation({ }, }); }; + +export { buildTutorialEvaluation }; diff --git a/api/db/database-builder/factory/build-user-login.js b/api/db/database-builder/factory/build-user-login.js index 64e34e7a372..d6baa8c8025 100644 --- a/api/db/database-builder/factory/build-user-login.js +++ b/api/db/database-builder/factory/build-user-login.js @@ -1,5 +1,5 @@ -const databaseBuffer = require('../database-buffer'); -const buildUser = require('./build-user'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildUser } from './build-user.js'; function buildUserLogin({ id = databaseBuffer.getNextId(), @@ -28,4 +28,4 @@ function buildUserLogin({ values, }); } -module.exports = buildUserLogin; +export { buildUserLogin }; diff --git a/api/db/database-builder/factory/build-user-orga-settings.js b/api/db/database-builder/factory/build-user-orga-settings.js index 8137d1cf7e1..86d4f9e262f 100644 --- a/api/db/database-builder/factory/build-user-orga-settings.js +++ b/api/db/database-builder/factory/build-user-orga-settings.js @@ -1,13 +1,9 @@ -const databaseBuffer = require('../database-buffer'); -const buildUser = require('./build-user'); -const buildOrganization = require('./build-organization'); -const _ = require('lodash'); +import { databaseBuffer } from '../database-buffer.js'; +import { buildUser } from './build-user.js'; +import { buildOrganization } from './build-organization.js'; +import _ from 'lodash'; -module.exports = function buildUserOrgaSettings({ - id = databaseBuffer.getNextId(), - currentOrganizationId, - userId, -} = {}) { +const buildUserOrgaSettings = function ({ id = databaseBuffer.getNextId(), currentOrganizationId, userId } = {}) { userId = _.isUndefined(userId) ? buildUser().id : userId; currentOrganizationId = _.isUndefined(currentOrganizationId) ? buildOrganization().id : currentOrganizationId; @@ -21,3 +17,5 @@ module.exports = function buildUserOrgaSettings({ values, }); }; + +export { buildUserOrgaSettings }; diff --git a/api/db/database-builder/factory/build-user-recommended-training.js b/api/db/database-builder/factory/build-user-recommended-training.js index a3205b4887b..09386137351 100644 --- a/api/db/database-builder/factory/build-user-recommended-training.js +++ b/api/db/database-builder/factory/build-user-recommended-training.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildUserRecommendedTraining({ +const buildUserRecommendedTraining = function ({ id = databaseBuffer.getNextId(), userId, trainingId, @@ -13,3 +13,5 @@ module.exports = function buildUserRecommendedTraining({ values: { id, userId, trainingId, campaignParticipationId, createdAt, updatedAt }, }); }; + +export { buildUserRecommendedTraining }; diff --git a/api/db/database-builder/factory/build-user-saved-tutorial.js b/api/db/database-builder/factory/build-user-saved-tutorial.js index c72816a9532..42a4a7b8135 100644 --- a/api/db/database-builder/factory/build-user-saved-tutorial.js +++ b/api/db/database-builder/factory/build-user-saved-tutorial.js @@ -1,6 +1,6 @@ -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; -module.exports = function buildUserSavedTutorial({ +const buildUserSavedTutorial = function ({ id = databaseBuffer.getNextId(), tutorialId, userId, @@ -12,3 +12,5 @@ module.exports = function buildUserSavedTutorial({ values: { id, userId, tutorialId, skillId, createdAt }, }); }; + +export { buildUserSavedTutorial }; diff --git a/api/db/database-builder/factory/build-user.js b/api/db/database-builder/factory/build-user.js index f35dfafd8c6..3ec3c241ff8 100644 --- a/api/db/database-builder/factory/build-user.js +++ b/api/db/database-builder/factory/build-user.js @@ -1,21 +1,21 @@ -const isNil = require('lodash/isNil'); -const isUndefined = require('lodash/isUndefined'); +import lodash from 'lodash'; +const { isUndefined, isNil } = lodash; -const databaseBuffer = require('../database-buffer'); +import { databaseBuffer } from '../database-buffer.js'; +import { AuthenticationMethod } from '../../../lib/domain/models/AuthenticationMethod.js'; +import { Membership } from '../../../lib/domain/models/Membership.js'; -const AuthenticationMethod = require('../../../lib/domain/models/AuthenticationMethod'); -const Membership = require('../../../lib/domain/models/Membership'); +import * as encrypt from '../../../lib/domain/services/encryption-service.js'; -const encrypt = require('../../../lib/domain/services/encryption-service'); +import { buildPixAdminRole } from './build-pix-admin-role.js'; +import { buildOrganization } from './build-organization.js'; +import { buildMembership } from './build-membership.js'; +import { buildCertificationCenter } from './build-certification-center.js'; +import { buildCertificationCenterMembership } from './build-certification-center-membership.js'; +import { DEFAULT_PASSWORD } from '../../seeds/data/users-builder.js'; +import { PIX_ADMIN } from '../../../lib/domain/constants.js'; -const buildPixAdminRole = require('./build-pix-admin-role'); -const buildOrganization = require('./build-organization'); -const buildMembership = require('./build-membership'); -const buildCertificationCenter = require('./build-certification-center'); -const buildCertificationCenterMembership = require('./build-certification-center-membership'); - -const { DEFAULT_PASSWORD } = require('../../seeds/data/users-builder'); -const { ROLES } = require('../../../lib/domain/constants').PIX_ADMIN; +const { ROLES } = PIX_ADMIN; function _buildPixAuthenticationMethod({ id = databaseBuffer.getNextId(), @@ -402,4 +402,4 @@ buildUser.withCertificationCenterMembership = function buildUserWithCertificatio return user; }; -module.exports = buildUser; +export { buildUser }; diff --git a/api/db/database-builder/factory/campaign-participation-overview-factory.js b/api/db/database-builder/factory/campaign-participation-overview-factory.js index 64a05da6614..c1bd7eb009a 100644 --- a/api/db/database-builder/factory/campaign-participation-overview-factory.js +++ b/api/db/database-builder/factory/campaign-participation-overview-factory.js @@ -1,169 +1,169 @@ -const buildAssessment = require('./build-assessment'); -const buildCampaign = require('./build-campaign'); -const buildCampaignParticipation = require('./build-campaign-participation'); -const buildCampaignSkill = require('./build-campaign-skill'); -const buildUser = require('./build-user'); -const Assessment = require('../../../lib/domain/models/Assessment'); -const CampaignParticipationStatuses = require('../../../lib/domain/models/CampaignParticipationStatuses'); +import { buildAssessment } from './build-assessment.js'; +import { buildCampaign } from './build-campaign.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import { buildCampaignSkill } from './build-campaign-skill.js'; +import { buildUser } from './build-user.js'; +import { Assessment } from '../../../lib/domain/models/Assessment.js'; +import { CampaignParticipationStatuses } from '../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED, SHARED, TO_SHARE } = CampaignParticipationStatuses; -module.exports = { - build({ +const build = function ({ + userId, + createdAt, + sharedAt, + assessmentCreatedAt, + assessmentState, + campaignId, + deletedAt, + deletedBy, + id, +} = {}) { + const status = assessmentState === Assessment.states.COMPLETED ? TO_SHARE : STARTED; + + const campaignParticipation = buildCampaignParticipation({ userId, - createdAt, - sharedAt, - assessmentCreatedAt, - assessmentState, campaignId, + createdAt: createdAt, + sharedAt: sharedAt, + status: sharedAt ? SHARED : status, deletedAt, deletedBy, + }); + + buildAssessment({ id, - } = {}) { - const status = assessmentState === Assessment.states.COMPLETED ? TO_SHARE : STARTED; - - const campaignParticipation = buildCampaignParticipation({ - userId, - campaignId, - createdAt: createdAt, - sharedAt: sharedAt, - status: sharedAt ? SHARED : status, - deletedAt, - deletedBy, - }); - - buildAssessment({ - id, - userId, - campaignParticipationId: campaignParticipation.id, - state: assessmentState, - createdAt: assessmentCreatedAt, - }); - - return campaignParticipation; - }, - - buildOnGoing({ userId, createdAt, assessmentCreatedAt, campaignSkills } = {}) { - const campaign = buildCampaign(); - campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); - - const campaignParticipation = buildCampaignParticipation({ - userId, - createdAt: createdAt, - sharedAt: null, - status: STARTED, - campaignId: campaign.id, - }); - - buildAssessment({ - userId, - campaignParticipationId: campaignParticipation.id, - state: Assessment.states.STARTED, - createdAt: assessmentCreatedAt, - }); - - return campaignParticipation; - }, - - buildToShare({ userId, createdAt, assessmentCreatedAt, campaignSkills } = {}) { - const campaign = buildCampaign(); - campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); - - const campaignParticipation = buildCampaignParticipation({ - userId, - createdAt: createdAt, - sharedAt: null, - status: TO_SHARE, - campaignId: campaign.id, - }); - - buildAssessment({ - userId, - campaignParticipationId: campaignParticipation.id, - state: Assessment.states.COMPLETED, - createdAt: assessmentCreatedAt, - }); - - return campaignParticipation; - }, - - buildEnded({ userId, createdAt, sharedAt, assessmentCreatedAt, campaignSkills } = {}) { - const campaign = buildCampaign(); - campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); - - const campaignParticipation = buildCampaignParticipation({ - userId, - createdAt: createdAt, - sharedAt: sharedAt || createdAt, - campaignId: campaign.id, - }); - - buildAssessment({ - userId, - campaignParticipationId: campaignParticipation.id, - state: Assessment.states.COMPLETED, - createdAt: assessmentCreatedAt, - }); - - return campaignParticipation; - }, - - buildArchived({ userId, - createdAt, - sharedAt, - assessmentCreatedAt, - campaignArchivedAt = new Date('1998-07-01'), - campaignSkills, - } = {}) { - const campaign = buildCampaign({ archivedAt: campaignArchivedAt }); - campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); - - const campaignParticipation = buildCampaignParticipation({ - userId, - campaignId: campaign.id, - createdAt: createdAt, - sharedAt: sharedAt || createdAt, - status: STARTED, - }); - - buildAssessment({ - userId, - campaignParticipationId: campaignParticipation.id, - createdAt: assessmentCreatedAt, - }); - - return campaignParticipation; - }, - - buildDeleted({ + campaignParticipationId: campaignParticipation.id, + state: assessmentState, + createdAt: assessmentCreatedAt, + }); + + return campaignParticipation; +}; + +const buildOnGoing = function ({ userId, createdAt, assessmentCreatedAt, campaignSkills } = {}) { + const campaign = buildCampaign(); + campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); + + const campaignParticipation = buildCampaignParticipation({ + userId, + createdAt: createdAt, + sharedAt: null, + status: STARTED, + campaignId: campaign.id, + }); + + buildAssessment({ userId, - createdAt, - sharedAt, - assessmentCreatedAt, - deletedAt = new Date('1998-07-01'), - deletedBy = buildUser().id, - campaignSkills, - } = {}) { - const campaign = buildCampaign(); - campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); - - const campaignParticipation = buildCampaignParticipation({ - userId, - campaignId: campaign.id, - createdAt: createdAt, - sharedAt: sharedAt || createdAt, - deletedAt, - deletedBy, - status: STARTED, - }); - - buildAssessment({ - userId, - campaignParticipationId: campaignParticipation.id, - createdAt: assessmentCreatedAt, - }); - - return campaignParticipation; - }, + campaignParticipationId: campaignParticipation.id, + state: Assessment.states.STARTED, + createdAt: assessmentCreatedAt, + }); + + return campaignParticipation; }; + +const buildToShare = function ({ userId, createdAt, assessmentCreatedAt, campaignSkills } = {}) { + const campaign = buildCampaign(); + campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); + + const campaignParticipation = buildCampaignParticipation({ + userId, + createdAt: createdAt, + sharedAt: null, + status: TO_SHARE, + campaignId: campaign.id, + }); + + buildAssessment({ + userId, + campaignParticipationId: campaignParticipation.id, + state: Assessment.states.COMPLETED, + createdAt: assessmentCreatedAt, + }); + + return campaignParticipation; +}; + +const buildEnded = function ({ userId, createdAt, sharedAt, assessmentCreatedAt, campaignSkills } = {}) { + const campaign = buildCampaign(); + campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); + + const campaignParticipation = buildCampaignParticipation({ + userId, + createdAt: createdAt, + sharedAt: sharedAt || createdAt, + campaignId: campaign.id, + }); + + buildAssessment({ + userId, + campaignParticipationId: campaignParticipation.id, + state: Assessment.states.COMPLETED, + createdAt: assessmentCreatedAt, + }); + + return campaignParticipation; +}; + +const buildArchived = function ({ + userId, + createdAt, + sharedAt, + assessmentCreatedAt, + campaignArchivedAt = new Date('1998-07-01'), + campaignSkills, +} = {}) { + const campaign = buildCampaign({ archivedAt: campaignArchivedAt }); + campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); + + const campaignParticipation = buildCampaignParticipation({ + userId, + campaignId: campaign.id, + createdAt: createdAt, + sharedAt: sharedAt || createdAt, + status: STARTED, + }); + + buildAssessment({ + userId, + campaignParticipationId: campaignParticipation.id, + createdAt: assessmentCreatedAt, + }); + + return campaignParticipation; +}; + +const buildDeleted = function ({ + userId, + createdAt, + sharedAt, + assessmentCreatedAt, + deletedAt = new Date('1998-07-01'), + deletedBy = buildUser().id, + campaignSkills, +} = {}) { + const campaign = buildCampaign(); + campaignSkills.forEach((skill) => buildCampaignSkill({ campaignId: campaign.id, skillId: skill })); + + const campaignParticipation = buildCampaignParticipation({ + userId, + campaignId: campaign.id, + createdAt: createdAt, + sharedAt: sharedAt || createdAt, + deletedAt, + deletedBy, + status: STARTED, + }); + + buildAssessment({ + userId, + campaignParticipationId: campaignParticipation.id, + createdAt: assessmentCreatedAt, + }); + + return campaignParticipation; +}; + +export { build, buildOnGoing, buildToShare, buildEnded, buildArchived, buildDeleted }; diff --git a/api/db/database-builder/factory/index.js b/api/db/database-builder/factory/index.js index 76dfe30cf53..0830bf47793 100644 --- a/api/db/database-builder/factory/index.js +++ b/api/db/database-builder/factory/index.js @@ -1,84 +1,84 @@ -const buildAccountRecoveryDemand = require('./build-account-recovery-demand'); -const buildAnswer = require('./build-answer'); -const buildAnsweredNotCompletedCertificationAssessment = require('./build-answered-not-completed-certification-assessment'); -const buildAssessment = require('./build-assessment'); -const buildAssessmentFromParticipation = require('./build-assessment-from-participation'); -const buildAssessmentResult = require('./build-assessment-result'); -const buildAuthenticationMethod = require('./build-authentication-method'); -const buildBadge = require('./build-badge'); -const buildBadgeAcquisition = require('./build-badge-acquisition'); -const buildBadgeCriterion = require('./build-badge-criterion'); -const buildSkillSet = require('./build-skill-set'); -const buildCampaign = require('./build-campaign'); -const buildCampaignSkill = require('./build-campaign-skill'); -const buildAssessmentCampaign = require('./build-assessment-campaign'); -const buildAssessmentCampaignForSkills = require('./build-assessment-campaign-for-skills'); -const buildCampaignParticipation = require('./build-campaign-participation'); -const buildCampaignParticipationElementsForOverview = require('./build-campaign-participation-elements-for-overview'); -const buildCampaignParticipationWithOrganizationLearner = require('./build-campaign-participation-with-organization-learner'); -const buildCampaignParticipationWithUser = require('./build-campaign-participation-with-user'); -const buildCertifiableUser = require('./build-certifiable-user'); -const buildCertificationCandidate = require('./build-certification-candidate'); -const buildCertificationCenter = require('./build-certification-center'); -const buildCertificationCenterInvitation = require('./build-certification-center-invitation'); -const buildCertificationCenterMembership = require('./build-certification-center-membership'); -const buildCertificationChallenge = require('./build-certification-challenge'); -const buildComplementaryCertificationCourseResult = require('./build-complementary-certification-course-result'); -const buildCertificationCourse = require('./build-certification-course'); -const buildCertificationCourseLastAssessmentResult = require('./build-certification-course-last-assessment-result'); -const buildCertificationCpfCity = require('./build-certification-cpf-city'); -const buildCertificationIssueReport = require('./build-certification-issue-report'); -const buildCertificationReport = require('./build-certification-report'); -const buildCertificationCpfCountry = require('./build-certification-cpf-country'); -const buildCompetenceEvaluation = require('./build-competence-evaluation'); -const buildCompetenceMark = require('./build-competence-mark'); -const buildComplementaryCertification = require('./build-complementary-certification'); -const buildComplementaryCertificationCourse = require('./build-complementary-certification-course'); -const buildComplementaryCertificationBadge = require('./build-complementary-certification-badge'); -const buildComplementaryCertificationHabilitation = require('./build-complementary-certification-habilitation'); -const buildComplementaryCertificationSubscription = require('./build-complementary-certification-subscription'); -const buildCorrectAnswersAndKnowledgeElementsForLearningContent = require('./build-correct-answers-and-knowledge-elements-for-learning-content'); -const buildCorrectAnswerAndKnowledgeElement = require('./build-correct-answer-and-knowledge-element'); -const buildDataProtectionOfficer = require('./build-data-protection-officer'); -const buildFinalizedSession = require('./build-finalized-session'); -const buildFlashAssessmentResult = require('./build-flash-assessment-result'); -const buildIssueReportCategory = require('./build-issue-report-category'); -const buildKnowledgeElement = require('./build-knowledge-element'); -const buildKnowledgeElementSnapshot = require('./build-knowledge-element-snapshot'); -const buildMembership = require('./build-membership'); -const buildOrganization = require('./build-organization'); -const buildFeature = require('./build-feature'); -const buildOrganizationFeature = require('./build-organization-feature'); -const buildOrganizationPlace = require('./build-organization-place'); -const buildOrganizationInvitation = require('./build-organization-invitation'); -const buildOrganizationLearner = require('./build-organization-learner'); -const buildOrganizationLearnerWithUser = require('./build-organization-learner-with-user'); -const buildOrganizationTag = require('./build-organization-tag'); -const buildPixAdminRole = require('./build-pix-admin-role'); -const buildResetPasswordDemand = require('./build-reset-password-demand'); -const buildSession = require('./build-session'); -const buildStage = require('./build-stage'); -const buildSupervisorAccess = require('./build-supervisor-access'); -const buildTag = require('./build-tag'); -const buildTargetProfile = require('./build-target-profile'); -const buildTargetProfileSkill = require('./build-target-profile-skill'); -const buildTargetProfileShare = require('./build-target-profile-share'); -const buildTargetProfileTraining = require('./build-target-profile-training'); -const buildTargetProfileTube = require('./build-target-profile-tube'); -const buildTraining = require('./build-training'); -const buildTrainingTrigger = require('./build-training-trigger'); -const buildTrainingTriggerTube = require('./build-training-trigger-tube'); -const buildTutorialEvaluation = require('./build-tutorial-evaluation'); -const buildUser = require('./build-user'); -const buildUserLogin = require('./build-user-login'); -const buildUserOrgaSettings = require('./build-user-orga-settings'); -const buildUserSavedTutorial = require('./build-user-saved-tutorial'); -const buildUserRecommendedTraining = require('./build-user-recommended-training'); -const campaignParticipationOverviewFactory = require('./campaign-participation-overview-factory'); -const knowledgeElementSnapshotFactory = require('./knowledge-elements-snapshot-factory'); -const poleEmploiSendingFactory = require('./pole-emploi-sending-factory'); +import { buildAccountRecoveryDemand } from './build-account-recovery-demand.js'; +import { buildAnswer } from './build-answer.js'; +import { buildAnsweredNotCompletedCertificationAssessment } from './build-answered-not-completed-certification-assessment.js'; +import { buildAssessment } from './build-assessment.js'; +import { buildAssessmentFromParticipation } from './build-assessment-from-participation.js'; +import { buildAssessmentResult } from './build-assessment-result.js'; +import { buildAuthenticationMethod } from './build-authentication-method.js'; +import { buildBadge } from './build-badge.js'; +import { buildBadgeAcquisition } from './build-badge-acquisition.js'; +import { buildBadgeCriterion } from './build-badge-criterion.js'; +import { buildSkillSet } from './build-skill-set.js'; +import { buildCampaign } from './build-campaign.js'; +import { buildCampaignSkill } from './build-campaign-skill.js'; +import { buildAssessmentCampaign } from './build-assessment-campaign.js'; +import { buildAssessmentCampaignForSkills } from './build-assessment-campaign-for-skills.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import { buildCampaignParticipationElementsForOverview } from './build-campaign-participation-elements-for-overview.js'; +import { buildCampaignParticipationWithOrganizationLearner } from './build-campaign-participation-with-organization-learner.js'; +import { buildCampaignParticipationWithUser } from './build-campaign-participation-with-user.js'; +import { buildCertifiableUser } from './build-certifiable-user.js'; +import { buildCertificationCandidate } from './build-certification-candidate.js'; +import { buildCertificationCenter } from './build-certification-center.js'; +import { buildCertificationCenterInvitation } from './build-certification-center-invitation.js'; +import { buildCertificationCenterMembership } from './build-certification-center-membership.js'; +import { buildCertificationChallenge } from './build-certification-challenge.js'; +import { buildComplementaryCertificationCourseResult } from './build-complementary-certification-course-result.js'; +import { buildCertificationCourse } from './build-certification-course.js'; +import { buildCertificationCourseLastAssessmentResult } from './build-certification-course-last-assessment-result.js'; +import { buildCertificationCpfCity } from './build-certification-cpf-city.js'; +import { buildCertificationIssueReport } from './build-certification-issue-report.js'; +import { buildCertificationReport } from './build-certification-report.js'; +import { buildCertificationCpfCountry } from './build-certification-cpf-country.js'; +import { buildCompetenceEvaluation } from './build-competence-evaluation.js'; +import { buildCompetenceMark } from './build-competence-mark.js'; +import { buildComplementaryCertification } from './build-complementary-certification.js'; +import { buildComplementaryCertificationCourse } from './build-complementary-certification-course.js'; +import { buildComplementaryCertificationBadge } from './build-complementary-certification-badge.js'; +import { buildComplementaryCertificationHabilitation } from './build-complementary-certification-habilitation.js'; +import { buildComplementaryCertificationSubscription } from './build-complementary-certification-subscription.js'; +import { buildCorrectAnswersAndKnowledgeElementsForLearningContent } from './build-correct-answers-and-knowledge-elements-for-learning-content.js'; +import { buildCorrectAnswerAndKnowledgeElement } from './build-correct-answer-and-knowledge-element.js'; +import * as buildDataProtectionOfficer from './build-data-protection-officer.js'; +import { buildFinalizedSession } from './build-finalized-session.js'; +import { buildFlashAssessmentResult } from './build-flash-assessment-result.js'; +import { buildIssueReportCategory } from './build-issue-report-category.js'; +import { buildKnowledgeElement } from './build-knowledge-element.js'; +import { buildKnowledgeElementSnapshot } from './build-knowledge-element-snapshot.js'; +import { buildMembership } from './build-membership.js'; +import { buildOrganization } from './build-organization.js'; +import { buildFeature } from './build-feature.js'; +import { buildOrganizationFeature } from './build-organization-feature.js'; +import { buildOrganizationPlace } from './build-organization-place.js'; +import { buildOrganizationInvitation } from './build-organization-invitation.js'; +import { buildOrganizationLearner } from './build-organization-learner.js'; +import { buildOrganizationLearnerWithUser } from './build-organization-learner-with-user.js'; +import { buildOrganizationTag } from './build-organization-tag.js'; +import { buildPixAdminRole } from './build-pix-admin-role.js'; +import { buildResetPasswordDemand } from './build-reset-password-demand.js'; +import { buildSession } from './build-session.js'; +import { buildStage } from './build-stage.js'; +import { buildSupervisorAccess } from './build-supervisor-access.js'; +import { buildTag } from './build-tag.js'; +import { buildTargetProfile } from './build-target-profile.js'; +import { buildTargetProfileSkill } from './build-target-profile-skill.js'; +import { buildTargetProfileShare } from './build-target-profile-share.js'; +import { buildTargetProfileTraining } from './build-target-profile-training.js'; +import { buildTargetProfileTube } from './build-target-profile-tube.js'; +import { buildTraining } from './build-training.js'; +import { buildTrainingTrigger } from './build-training-trigger.js'; +import { buildTrainingTriggerTube } from './build-training-trigger-tube.js'; +import { buildTutorialEvaluation } from './build-tutorial-evaluation.js'; +import { buildUser } from './build-user.js'; +import { buildUserLogin } from './build-user-login.js'; +import { buildUserOrgaSettings } from './build-user-orga-settings.js'; +import { buildUserSavedTutorial } from './build-user-saved-tutorial.js'; +import { buildUserRecommendedTraining } from './build-user-recommended-training.js'; +import * as campaignParticipationOverviewFactory from './campaign-participation-overview-factory.js'; +import * as knowledgeElementSnapshotFactory from './knowledge-elements-snapshot-factory.js'; +import * as poleEmploiSendingFactory from './pole-emploi-sending-factory.js'; -module.exports = { +export { buildAccountRecoveryDemand, buildAnswer, buildAnsweredNotCompletedCertificationAssessment, diff --git a/api/db/database-builder/factory/knowledge-elements-snapshot-factory.js b/api/db/database-builder/factory/knowledge-elements-snapshot-factory.js index 64629ef3e7c..581ff123a21 100644 --- a/api/db/database-builder/factory/knowledge-elements-snapshot-factory.js +++ b/api/db/database-builder/factory/knowledge-elements-snapshot-factory.js @@ -1,5 +1,5 @@ -const buildKnowledgeElement = require('./build-knowledge-element'); -const databaseBuffer = require('../database-buffer'); +import { buildKnowledgeElement } from './build-knowledge-element.js'; +import { databaseBuffer } from '../database-buffer.js'; function buildSnapshot({ id, userId, snappedAt, knowledgeElementsAttributes }) { const knowledgeElements = knowledgeElementsAttributes.map((attributes) => buildKnowledgeElement(attributes)); @@ -17,6 +17,4 @@ function buildSnapshot({ id, userId, snappedAt, knowledgeElementsAttributes }) { }); } -module.exports = { - buildSnapshot, -}; +export { buildSnapshot }; diff --git a/api/db/database-builder/factory/pole-emploi-sending-factory.js b/api/db/database-builder/factory/pole-emploi-sending-factory.js index 5bf25d794bc..2ac2dfe5476 100644 --- a/api/db/database-builder/factory/pole-emploi-sending-factory.js +++ b/api/db/database-builder/factory/pole-emploi-sending-factory.js @@ -1,8 +1,8 @@ -const buildCampaignParticipation = require('./build-campaign-participation'); -const buildUser = require('./build-user'); -const buildAuthenticationMethod = require('./build-authentication-method'); -const databaseBuffer = require('../database-buffer'); -const _ = require('lodash'); +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import { buildUser } from './build-user.js'; +import { buildAuthenticationMethod } from './build-authentication-method.js'; +import { databaseBuffer } from '../database-buffer.js'; +import _ from 'lodash'; function build({ id = databaseBuffer.getNextId(), @@ -39,7 +39,4 @@ function buildWithUser(sendingAttributes, externalIdentifier) { return build({ ...sendingAttributes, campaignParticipationId }); } -module.exports = { - build, - buildWithUser, -}; +export { build, buildWithUser }; diff --git a/api/db/knex-database-connection.js b/api/db/knex-database-connection.js index d7da8952a84..45ad891ef17 100644 --- a/api/db/knex-database-connection.js +++ b/api/db/knex-database-connection.js @@ -1,9 +1,18 @@ -const types = require('pg').types; -const { get } = require('lodash'); -const logger = require('../lib/infrastructure/logger'); -const monitoringTools = require('../lib/infrastructure/monitoring-tools'); -const { logging } = require('../lib/config'); -const { performance } = require('perf_hooks'); +import pg from 'pg'; + +const types = pg.types; +import _ from 'lodash'; + +const { get } = _; +import { logger } from '../lib/infrastructure/logger.js'; +import { monitoringTools } from '../lib/infrastructure/monitoring-tools.js'; +import { config } from '../lib/config.js'; +import perf_hooks from 'perf_hooks'; + +const { performance } = perf_hooks; + +import Knex from 'knex'; +import QueryBuilder from 'knex/lib/query/querybuilder.js'; /* By default, node-postgres casts a DATE value (PostgreSQL type) as a Date Object (JS type). But, when dealing with dates with no time (such as birthdate for example), we want to @@ -23,18 +32,16 @@ Links : */ types.setTypeParser(types.builtins.INT8, (value) => parseInt(value)); -const _ = require('lodash'); +import * as knexConfigs from './knexfile.js'; -const knexConfigs = require('./knexfile'); -const { environment } = require('../lib/config'); +const { logging, environment } = config; +const knexConfig = knexConfigs.default[environment]; +const configuredKnex = Knex(knexConfig); /* QueryBuilder Extension */ -const Knex = require('knex'); -const QueryBuilder = require('knex/lib/query/querybuilder'); - try { Knex.QueryBuilder.extend('whereInArray', function (column, values) { - return this.where(column, knex.raw('any(?)', [values])); + return this.where(column, configuredKnex.raw('any(?)', [values])); }); } catch (e) { if (e.message !== "Can't extend QueryBuilder with existing method ('whereInArray').") { @@ -43,9 +50,6 @@ try { } /* -------------------- */ -const knexConfig = knexConfigs[environment]; -const knex = require('knex')(knexConfig); - const originalToSQL = QueryBuilder.prototype.toSQL; QueryBuilder.prototype.toSQL = function () { const ret = originalToSQL.apply(this); @@ -55,14 +59,14 @@ QueryBuilder.prototype.toSQL = function () { return ret; }; -knex.on('query', function (data) { +configuredKnex.on('query', function (data) { if (logging.enableKnexPerformanceMonitoring) { const queryId = data.__knexQueryUid; monitoringTools.setInContext(`knexQueryStartTimes.${queryId}`, performance.now()); } }); -knex.on('query-response', function (response, data) { +configuredKnex.on('query-response', function (response, data) { monitoringTools.incrementInContext('metrics.knexQueryCount'); if (logging.enableKnexPerformanceMonitoring) { const queryStartedTime = monitoringTools.getInContext(`knexQueryStartTimes.${data.__knexQueryUid}`); @@ -74,10 +78,10 @@ knex.on('query-response', function (response, data) { }); async function disconnect() { - return knex.destroy(); + return configuredKnex.destroy(); } -const _databaseName = knex.client.database(); +const _databaseName = configuredKnex.client.database(); const _dbSpecificQueries = { listTablesQuery: @@ -88,7 +92,7 @@ const _dbSpecificQueries = { async function listAllTableNames() { const bindings = [_databaseName]; - const resultSet = await knex.raw( + const resultSet = await configuredKnex.raw( 'SELECT table_name FROM information_schema.tables WHERE table_schema = current_schema() AND table_catalog = ?', bindings ); @@ -110,11 +114,7 @@ async function emptyAllTables() { const query = _dbSpecificQueries.emptyTableQuery; // eslint-disable-next-line knex/avoid-injections - return knex.raw(`${query}${tables}`); + return configuredKnex.raw(`${query}${tables}`); } -module.exports = { - knex, - disconnect, - emptyAllTables, -}; +export { configuredKnex as knex, disconnect, emptyAllTables }; diff --git a/api/db/knexfile.js b/api/db/knexfile.js index bd9c5488a72..95350db1c69 100644 --- a/api/db/knexfile.js +++ b/api/db/knexfile.js @@ -1,4 +1,7 @@ -require('dotenv').config({ path: `${__dirname}/../.env` }); +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; +dotenv.config({ path: `${__dirname}/../.env` }); function localPostgresEnv(databaseUrl, knexAsyncStacktraceEnabled) { return { @@ -18,8 +21,7 @@ function localPostgresEnv(databaseUrl, knexAsyncStacktraceEnabled) { asyncStackTraces: knexAsyncStacktraceEnabled !== 'false', }; } - -module.exports = { +const environments = { development: localPostgresEnv(process.env.DATABASE_URL, process.env.KNEX_ASYNC_STACKTRACE_ENABLED), test: localPostgresEnv(process.env.TEST_DATABASE_URL, process.env.KNEX_ASYNC_STACKTRACE_ENABLED), @@ -41,3 +43,5 @@ module.exports = { asyncStackTraces: process.env.KNEX_ASYNC_STACKTRACE_ENABLED !== 'false', }, }; + +export default environments; diff --git a/api/db/migrations/20160927153108_create_users.js b/api/db/migrations/20160927153108_create_users.js index 037e367faf1..09802305d3c 100644 --- a/api/db/migrations/20160927153108_create_users.js +++ b/api/db/migrations/20160927153108_create_users.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'users'; -exports.up = (knex) => { +const up = function (knex) { function table(t) { t.increments().primary(); t.string('firstName').notNullable(); @@ -15,6 +15,8 @@ exports.up = (knex) => { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20160929164549_create_assessments.js b/api/db/migrations/20160929164549_create_assessments.js index d2c7901d261..f9d2bbb0cfb 100644 --- a/api/db/migrations/20160929164549_create_assessments.js +++ b/api/db/migrations/20160929164549_create_assessments.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'assessments'; -exports.up = (knex) => { +const up = function (knex) { function table(t) { t.increments().primary(); t.string('courseId'); @@ -13,6 +13,8 @@ exports.up = (knex) => { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20160929172038_create_answers.js b/api/db/migrations/20160929172038_create_answers.js index 89d7c2dc851..0026e2df90d 100644 --- a/api/db/migrations/20160929172038_create_answers.js +++ b/api/db/migrations/20160929172038_create_answers.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'answers'; -exports.up = (knex) => { +const up = function (knex) { function table(t) { t.increments().primary(); t.text('value').notNull(); @@ -14,6 +14,8 @@ exports.up = (knex) => { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20161221143039_create_scenarios.js b/api/db/migrations/20161221143039_create_scenarios.js index 0d816eba632..d35a23469d0 100644 --- a/api/db/migrations/20161221143039_create_scenarios.js +++ b/api/db/migrations/20161221143039_create_scenarios.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'scenarios'; -exports.up = function (knex) { +const up = function (knex) { function table(t) { t.increments().primary(); t.string('courseId').notNull(); @@ -13,6 +13,8 @@ exports.up = function (knex) { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20170105153948_update_answers_timeout.js b/api/db/migrations/20170105153948_update_answers_timeout.js index 8108bcc7302..f8e5e2211fb 100644 --- a/api/db/migrations/20170105153948_update_answers_timeout.js +++ b/api/db/migrations/20170105153948_update_answers_timeout.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'answers'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer('timeout'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('timeout'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170125155825_followers.js b/api/db/migrations/20170125155825_followers.js index 54bba81ab96..ec0fdf54b32 100644 --- a/api/db/migrations/20170125155825_followers.js +++ b/api/db/migrations/20170125155825_followers.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'followers'; -exports.up = (knex) => { +const up = function (knex) { function table(t) { t.increments().primary(); t.string('email').unique().notNullable(); @@ -11,6 +11,8 @@ exports.up = (knex) => { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20170207091544_create_feedbacks.js b/api/db/migrations/20170207091544_create_feedbacks.js index bf2c2ec8fb4..dad510b9c5b 100644 --- a/api/db/migrations/20170207091544_create_feedbacks.js +++ b/api/db/migrations/20170207091544_create_feedbacks.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'feedbacks'; -exports.up = (knex) => { +const up = function (knex) { function table(t) { t.increments().primary(); t.string('email'); @@ -14,6 +14,8 @@ exports.up = (knex) => { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20170306151003_update_answers.js b/api/db/migrations/20170306151003_update_answers.js index 2691c197346..6497d972e0a 100644 --- a/api/db/migrations/20170306151003_update_answers.js +++ b/api/db/migrations/20170306151003_update_answers.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'answers'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, (t) => { t.text('value').alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (t) => { t.text('string').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170329112753_add_elapsedTime_to_answers.js b/api/db/migrations/20170329112753_add_elapsedTime_to_answers.js index f4a2c00652a..cc97221ccd6 100644 --- a/api/db/migrations/20170329112753_add_elapsedTime_to_answers.js +++ b/api/db/migrations/20170329112753_add_elapsedTime_to_answers.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'answers'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer('elapsedTime'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('elapsedTime'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170329153349_update_answers--add_column_result_details.js b/api/db/migrations/20170329153349_update_answers--add_column_result_details.js index f884f37a4b4..d92d5a3d29f 100644 --- a/api/db/migrations/20170329153349_update_answers--add_column_result_details.js +++ b/api/db/migrations/20170329153349_update_answers--add_column_result_details.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'answers'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.text('resultDetails'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('resultDetails'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170418114929_remove_login_from_users.js b/api/db/migrations/20170418114929_remove_login_from_users.js index 48f9380b8e5..11276efb208 100644 --- a/api/db/migrations/20170418114929_remove_login_from_users.js +++ b/api/db/migrations/20170418114929_remove_login_from_users.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'users'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('login'); table.boolean('cgu'); @@ -8,9 +8,11 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string('login').defaultTo('').notNullable(); table.dropColumn('cgu'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170703105035_create_link_between_user_and_assessment.js b/api/db/migrations/20170703105035_create_link_between_user_and_assessment.js index dadb9681871..a24ebde2b0b 100644 --- a/api/db/migrations/20170703105035_create_link_between_user_and_assessment.js +++ b/api/db/migrations/20170703105035_create_link_between_user_and_assessment.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'assessments'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.bigInteger('userId').index().references('users.id'); table.dropColumn('userName'); @@ -8,10 +8,12 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('userId'); table.string('userName').notNull(); table.string('userEmail').notNull(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170703163243_update_assessment_with_level_and_score.js b/api/db/migrations/20170703163243_update_assessment_with_level_and_score.js index e6f65130b54..e97c644e9bb 100644 --- a/api/db/migrations/20170703163243_update_assessment_with_level_and_score.js +++ b/api/db/migrations/20170703163243_update_assessment_with_level_and_score.js @@ -1,15 +1,17 @@ const TABLE_NAME = 'assessments'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer('estimatedLevel'); table.integer('pixScore'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('estimatedLevel'); table.dropColumn('pixScore'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170724181108_creating_organizations.js b/api/db/migrations/20170724181108_creating_organizations.js index 451b41c5c0e..d21310bab6d 100644 --- a/api/db/migrations/20170724181108_creating_organizations.js +++ b/api/db/migrations/20170724181108_creating_organizations.js @@ -1,4 +1,4 @@ -exports.up = function (knex) { +const up = function (knex) { function table(table) { table.increments().primary(); table.string('email').notNullable(); @@ -12,6 +12,8 @@ exports.up = function (knex) { return knex.schema.createTable('organizations', table); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable('organizations'); }; + +export { up, down }; diff --git a/api/db/migrations/20170728141316_add_code_to_organization.js b/api/db/migrations/20170728141316_add_code_to_organization.js index 6c514c2a5b8..3864c4d197f 100644 --- a/api/db/migrations/20170728141316_add_code_to_organization.js +++ b/api/db/migrations/20170728141316_add_code_to_organization.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('organizations', function (table) { table.string('code', 6).default('').notNullable(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('organizations', (table) => { table.dropColumn('code'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170818115953_snapshots.js b/api/db/migrations/20170818115953_snapshots.js index ffb2c64d09c..d3aaf0b46bb 100644 --- a/api/db/migrations/20170818115953_snapshots.js +++ b/api/db/migrations/20170818115953_snapshots.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'snapshots'; -exports.up = function (knex) { +const up = function (knex) { function table(t) { t.increments().primary(); t.bigInteger('organizationId').unsigned().references('organizations.id'); @@ -14,6 +14,8 @@ exports.up = function (knex) { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20170829165045_add_completion_percentage_to_snapshot.js b/api/db/migrations/20170829165045_add_completion_percentage_to_snapshot.js index f3daf708b11..bcd7a8db4d7 100644 --- a/api/db/migrations/20170829165045_add_completion_percentage_to_snapshot.js +++ b/api/db/migrations/20170829165045_add_completion_percentage_to_snapshot.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('snapshots', function (table) { table.string('completionPercentage', 6); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('snapshots', (table) => { table.dropColumn('completionPercentage'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20170919181249_reset-password-demands.js b/api/db/migrations/20170919181249_reset-password-demands.js index f80a1f24c43..b8c0b10aec5 100644 --- a/api/db/migrations/20170919181249_reset-password-demands.js +++ b/api/db/migrations/20170919181249_reset-password-demands.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'reset-password-demands'; -exports.up = function (knex) { +const up = function (knex) { function table(t) { t.increments().primary(); t.string('email').index(); @@ -13,6 +13,8 @@ exports.up = function (knex) { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20171005222803_update_snapshots_add_student_and_campaign_code.js b/api/db/migrations/20171005222803_update_snapshots_add_student_and_campaign_code.js index 5badb753e2a..f0aac4f7b89 100644 --- a/api/db/migrations/20171005222803_update_snapshots_add_student_and_campaign_code.js +++ b/api/db/migrations/20171005222803_update_snapshots_add_student_and_campaign_code.js @@ -1,13 +1,15 @@ -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table('snapshots', (table) => { table.string('studentCode'); table.string('campaignCode'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table('snapshots', (table) => { table.dropColumn('studentCode'); table.dropColumn('campaignCode'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20171023183134_skills.js b/api/db/migrations/20171023183134_skills.js index fd137445c5b..a0837f65734 100644 --- a/api/db/migrations/20171023183134_skills.js +++ b/api/db/migrations/20171023183134_skills.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'skills'; -exports.up = function (knex) { +const up = function (knex) { function table(t) { t.increments().primary(); t.integer('assessmentId').unsigned().references('assessments.id').index(); @@ -13,6 +13,8 @@ exports.up = function (knex) { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20171113101130_certification-courses.js b/api/db/migrations/20171113101130_certification-courses.js index 49f42453ef0..f280b182aa2 100644 --- a/api/db/migrations/20171113101130_certification-courses.js +++ b/api/db/migrations/20171113101130_certification-courses.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-courses'; -exports.up = function (knex) { +const up = function (knex) { function table(t) { t.increments().primary(); t.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); @@ -10,6 +10,8 @@ exports.up = function (knex) { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20171113101244_certification-challenges.js b/api/db/migrations/20171113101244_certification-challenges.js index 13640bbcefa..3aa12165e6c 100644 --- a/api/db/migrations/20171113101244_certification-challenges.js +++ b/api/db/migrations/20171113101244_certification-challenges.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-challenges'; -exports.up = function (knex) { +const up = function (knex) { function table(t) { t.increments().primary(); t.string('challengeId'); @@ -14,6 +14,8 @@ exports.up = function (knex) { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20171113103608_add_type_to_assessments.js b/api/db/migrations/20171113103608_add_type_to_assessments.js index 6eefcc4ee24..77248644515 100644 --- a/api/db/migrations/20171113103608_add_type_to_assessments.js +++ b/api/db/migrations/20171113103608_add_type_to_assessments.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'assessments'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string('type'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('type'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20171204102525_add_userId_to_certification_course.js b/api/db/migrations/20171204102525_add_userId_to_certification_course.js index e4cad531141..e91eab83567 100644 --- a/api/db/migrations/20171204102525_add_userId_to_certification_course.js +++ b/api/db/migrations/20171204102525_add_userId_to_certification_course.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-courses'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer('userId').references('users.id').index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('userId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20171212144653_add_status_to_certification_course.js b/api/db/migrations/20171212144653_add_status_to_certification_course.js index 076a663302f..a0631d77e4b 100644 --- a/api/db/migrations/20171212144653_add_status_to_certification_course.js +++ b/api/db/migrations/20171212144653_add_status_to_certification_course.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-courses'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string('status'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('status'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180103152804_add_completed_time_to_certification_course.js b/api/db/migrations/20180103152804_add_completed_time_to_certification_course.js index fca3ffc30b1..217f748f5d3 100644 --- a/api/db/migrations/20180103152804_add_completed_time_to_certification_course.js +++ b/api/db/migrations/20180103152804_add_completed_time_to_certification_course.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-courses'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dateTime('completedAt'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('completedAt'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180109174844_create_mark_table.js b/api/db/migrations/20180109174844_create_mark_table.js index f626716992d..949b81b1335 100644 --- a/api/db/migrations/20180109174844_create_mark_table.js +++ b/api/db/migrations/20180109174844_create_mark_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'marks'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('level').unsigned(); @@ -11,6 +11,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20180116161332_modify_column_completedPercentage_to_tests_finished_in_snapshots.js b/api/db/migrations/20180116161332_modify_column_completedPercentage_to_tests_finished_in_snapshots.js index 1650e79c474..5960aa49981 100644 --- a/api/db/migrations/20180116161332_modify_column_completedPercentage_to_tests_finished_in_snapshots.js +++ b/api/db/migrations/20180116161332_modify_column_completedPercentage_to_tests_finished_in_snapshots.js @@ -3,7 +3,7 @@ const NUMBER_OF_COMPETENCES = 16; const MULTIPLICATOR_PERCENTAGE_TO_COMPETENCES = NUMBER_OF_COMPETENCES / 100; const MULTIPLICATOR_COMPETENCES_TO_PERCENTAGE = 100 / NUMBER_OF_COMPETENCES; -exports.up = function (knex) { +const up = function (knex) { return knex.schema .table(TABLE_NAME, function (table) { table.integer('testsFinished'); @@ -24,7 +24,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema .table(TABLE_NAME, function (table) { table.integer('completionPercentage'); @@ -44,3 +44,5 @@ exports.down = function (knex) { }); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180131153634_create_sessions_table.js b/api/db/migrations/20180131153634_create_sessions_table.js index 8405cc65e4e..ea8d9311d36 100644 --- a/api/db/migrations/20180131153634_create_sessions_table.js +++ b/api/db/migrations/20180131153634_create_sessions_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'sessions'; -exports.up = (knex) => { +const up = function (knex) { function table(t) { t.increments().primary(); t.text('certificationCenter').notNullable(); @@ -16,6 +16,8 @@ exports.up = (knex) => { return knex.schema.createTable(TABLE_NAME, table); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20180212111049_delete_scenario_table.js b/api/db/migrations/20180212111049_delete_scenario_table.js index 9028d76e677..acb2d7c742d 100644 --- a/api/db/migrations/20180212111049_delete_scenario_table.js +++ b/api/db/migrations/20180212111049_delete_scenario_table.js @@ -1,10 +1,10 @@ const TABLE_NAME = 'scenarios'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = function (knex) { +const down = function (knex) { function table(t) { t.increments().primary(); t.string('courseId').notNull(); @@ -16,3 +16,5 @@ exports.down = function (knex) { return knex.schema.createTable(TABLE_NAME, table); }; + +export { up, down }; diff --git a/api/db/migrations/20180216153505_add_user_details_and_rejection_reason_to_certification_courses.js b/api/db/migrations/20180216153505_add_user_details_and_rejection_reason_to_certification_courses.js index 937b2b047f6..754c4c8dfdf 100644 --- a/api/db/migrations/20180216153505_add_user_details_and_rejection_reason_to_certification_courses.js +++ b/api/db/migrations/20180216153505_add_user_details_and_rejection_reason_to_certification_courses.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-courses'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string('firstName'); table.string('lastName'); @@ -10,7 +10,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropTable('firstName'); table.dropTable('lastName'); @@ -19,3 +19,5 @@ exports.down = function (knex) { table.dropTable('rejectionReason'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180219191550_create_pix_roles.js b/api/db/migrations/20180219191550_create_pix_roles.js index 4bb0bfbb1cd..eea84745231 100644 --- a/api/db/migrations/20180219191550_create_pix_roles.js +++ b/api/db/migrations/20180219191550_create_pix_roles.js @@ -1,4 +1,4 @@ -exports.up = (knex) => { +const up = function (knex) { return knex.schema .createTable('pix_roles', (table) => { table.increments('id').primary(); @@ -18,8 +18,10 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable('pix_roles').then(() => { return knex.schema.dropTable('users_pix_roles'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180306151846_add_type_to_all_assessments.js b/api/db/migrations/20180306151846_add_type_to_all_assessments.js index 1863faa8a5f..38aeb829577 100644 --- a/api/db/migrations/20180306151846_add_type_to_all_assessments.js +++ b/api/db/migrations/20180306151846_add_type_to_all_assessments.js @@ -1,4 +1,4 @@ -const { batch } = require('../batch-processing'); +import { batch } from '../batch-processing.js'; const TABLE_NAME_ASSESSMENTS = 'assessments'; const TABLE_NAME_CERTIFICATIONS = 'certification-courses'; const LIST_COMPETENCES_PLACEMENT = [ @@ -24,7 +24,7 @@ const TYPE_CERTIFICATION = 'CERTIFICATION'; const TYPE_DEMO = 'DEMO'; const TYPE_PREVIEW = 'PREVIEW'; -exports.up = function (knex) { +const up = function (knex) { // XXX : Modify PREVIEW assessments return knex(TABLE_NAME_ASSESSMENTS) .select('id', 'courseId', 'type') @@ -83,6 +83,8 @@ exports.up = function (knex) { }); }; -exports.down = function () { +const down = function () { return; }; + +export { up, down }; diff --git a/api/db/migrations/20180306164441_remove-score-and-level-for-bugged-assessments.js b/api/db/migrations/20180306164441_remove-score-and-level-for-bugged-assessments.js index c56cd3eb583..06933e07af2 100644 --- a/api/db/migrations/20180306164441_remove-score-and-level-for-bugged-assessments.js +++ b/api/db/migrations/20180306164441_remove-score-and-level-for-bugged-assessments.js @@ -1,8 +1,8 @@ -const { batch } = require('../batch-processing'); +import { batch } from '../batch-processing.js'; const TABLE_NAME_ASSESSMENTS = 'assessments'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME_ASSESSMENTS) .select('id', 'estimatedLevel', 'pixScore', 'type') .where('type', '=', 'PLACEMENT') @@ -20,6 +20,8 @@ exports.up = function (knex) { }); }; -exports.down = function () { +const down = function () { return; }; + +export { up, down }; diff --git a/api/db/migrations/20180315164634_add-column-access-code-on-sessions.js b/api/db/migrations/20180315164634_add-column-access-code-on-sessions.js index f93862f1801..00f7b2ba894 100644 --- a/api/db/migrations/20180315164634_add-column-access-code-on-sessions.js +++ b/api/db/migrations/20180315164634_add-column-access-code-on-sessions.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'sessions'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string('accessCode'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('accessCode'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180315164647_add-column-session-id-on-certifications.js b/api/db/migrations/20180315164647_add-column-session-id-on-certifications.js index c2ececf623b..098487c559d 100644 --- a/api/db/migrations/20180315164647_add-column-session-id-on-certifications.js +++ b/api/db/migrations/20180315164647_add-column-session-id-on-certifications.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-courses'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer('sessionId').references('sessions.id').index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer('sessionId').references('sessions.id').index(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180329113849_add-indexes-on-many-tables.js b/api/db/migrations/20180329113849_add-indexes-on-many-tables.js index 59cfb1d2c9b..3b0657c36e4 100644 --- a/api/db/migrations/20180329113849_add-indexes-on-many-tables.js +++ b/api/db/migrations/20180329113849_add-indexes-on-many-tables.js @@ -1,4 +1,4 @@ -const Promise = require('bluebird'); +import Promise from 'bluebird'; const indexes = { answers: ['assessmentId'], @@ -8,7 +8,8 @@ const indexes = { marks: ['assessmentId'], snapshots: ['organizationId'], }; -exports.up = function (knex) { + +const up = function (knex) { const promises = Object.keys(indexes).map((tableForIndexes) => { return knex.schema.table(tableForIndexes, (table) => { indexes[tableForIndexes].forEach((column) => table.index(column)); @@ -17,7 +18,7 @@ exports.up = function (knex) { return Promise.all(promises); }; -exports.down = function (knex) { +const down = function (knex) { const promises = Object.keys(indexes).map((tableForIndexes) => { return knex.schema.table(tableForIndexes, (table) => { indexes[tableForIndexes].forEach((column) => table.dropIndex(column)); @@ -25,3 +26,5 @@ exports.down = function (knex) { }); return Promise.all(promises); }; + +export { up, down }; diff --git a/api/db/migrations/20180405100236_move_status_from_certification_to_assessment.js b/api/db/migrations/20180405100236_move_status_from_certification_to_assessment.js index 07b3d8e9c2f..05e3c4ea0c5 100644 --- a/api/db/migrations/20180405100236_move_status_from_certification_to_assessment.js +++ b/api/db/migrations/20180405100236_move_status_from_certification_to_assessment.js @@ -1,9 +1,9 @@ -const { batch } = require('../batch-processing'); +import { batch } from '../batch-processing.js'; const TABLE_NAME_CERTIFICATION = 'certification-courses'; const TABLE_NAME_ASSESSMENTS = 'assessments'; -exports.up = function (knex) { +const up = function (knex) { return ( knex.schema // Add Column @@ -42,7 +42,7 @@ exports.up = function (knex) { ); }; -exports.down = function (knex) { +const down = function (knex) { // Add Column return knex.schema .table(TABLE_NAME_CERTIFICATION, function (table) { @@ -68,3 +68,5 @@ exports.down = function (knex) { }); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180405100345_create_assessment_results_table.js b/api/db/migrations/20180405100345_create_assessment_results_table.js index 0cc00d69b69..c0e07a9b36d 100644 --- a/api/db/migrations/20180405100345_create_assessment_results_table.js +++ b/api/db/migrations/20180405100345_create_assessment_results_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'assessment-results'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); @@ -17,6 +17,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20180405100452_migrate_assessments_info_to_assessment_results.js b/api/db/migrations/20180405100452_migrate_assessments_info_to_assessment_results.js index d00a0bab628..6e635dca951 100644 --- a/api/db/migrations/20180405100452_migrate_assessments_info_to_assessment_results.js +++ b/api/db/migrations/20180405100452_migrate_assessments_info_to_assessment_results.js @@ -1,9 +1,9 @@ -const { batch } = require('../batch-processing'); +import { batch } from '../batch-processing.js'; const TABLE_NAME_ASSESSMENT_RESULT = 'assessment-results'; const TABLE_NAME_ASSESSMENTS = 'assessments'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME_ASSESSMENTS) .select('id', 'type', 'createdAt', 'pixScore', 'estimatedLevel') .where('state', '!=', 'started') @@ -28,7 +28,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema .table(TABLE_NAME_ASSESSMENTS, function (table) { table.integer('pixScore'); @@ -47,3 +47,5 @@ exports.down = function (knex) { return knex(TABLE_NAME_ASSESSMENT_RESULT).delete(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180405100530_link_marks_to_assessment_results.js b/api/db/migrations/20180405100530_link_marks_to_assessment_results.js index 7379475e465..c88221d298f 100644 --- a/api/db/migrations/20180405100530_link_marks_to_assessment_results.js +++ b/api/db/migrations/20180405100530_link_marks_to_assessment_results.js @@ -1,9 +1,9 @@ -const { batch } = require('../batch-processing'); +import { batch } from '../batch-processing.js'; const TABLE_NAME_ASSESSMENT_RESULTS = 'assessment-results'; const TABLE_NAME_MARKS = 'marks'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema .table(TABLE_NAME_MARKS, function (table) { table.integer('assessmentResultId').unsigned(); @@ -22,8 +22,10 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME_MARKS, function (table) { table.dropColumn('assessmentResultId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180405100632_create_table_competences-marks.js b/api/db/migrations/20180405100632_create_table_competences-marks.js index d58d4a604a1..2427677bb24 100644 --- a/api/db/migrations/20180405100632_create_table_competences-marks.js +++ b/api/db/migrations/20180405100632_create_table_competences-marks.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'competence-marks'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('level'); @@ -13,6 +13,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20180405100655_migrate_old_marks_in_competence-marks.js b/api/db/migrations/20180405100655_migrate_old_marks_in_competence-marks.js index cdc0d3c4658..e00f58cba2b 100644 --- a/api/db/migrations/20180405100655_migrate_old_marks_in_competence-marks.js +++ b/api/db/migrations/20180405100655_migrate_old_marks_in_competence-marks.js @@ -1,10 +1,10 @@ -const { batch } = require('../batch-processing'); +import { batch } from '../batch-processing.js'; const TABLE_NAME_MARKS = 'marks'; const TABLE_NAME_COMPETENCE_MARKS = 'competence-marks'; const TABLE_NAME_ASSESSMENT_RESULTS = 'assessment-results'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME_MARKS) .select('id', 'level', 'score', 'area_code', 'competence_code', 'assessmentResultId') .then((allMarks) => { @@ -21,7 +21,7 @@ exports.up = function (knex) { .then(() => knex.schema.dropTable(TABLE_NAME_MARKS)); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema .createTable(TABLE_NAME_MARKS, (t) => { t.increments().primary(); @@ -55,3 +55,5 @@ exports.down = function (knex) { }); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180409172412_add_external_id_to_certification.js b/api/db/migrations/20180409172412_add_external_id_to_certification.js index 13f800c43b3..442f5ed58b5 100644 --- a/api/db/migrations/20180409172412_add_external_id_to_certification.js +++ b/api/db/migrations/20180409172412_add_external_id_to_certification.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-courses'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('externalId'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('externalId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180425171813_add_isPublished_to_certifications.js b/api/db/migrations/20180425171813_add_isPublished_to_certifications.js index 3b4a8a4e769..662f2e29aab 100644 --- a/api/db/migrations/20180425171813_add_isPublished_to_certifications.js +++ b/api/db/migrations/20180425171813_add_isPublished_to_certifications.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-courses'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean('isPublished').notNullable().defaultTo(false); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('isPublished'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180528152339_create_table_organizations_roles.js b/api/db/migrations/20180528152339_create_table_organizations_roles.js index 6b1b82fbf00..b8a9de1e587 100644 --- a/api/db/migrations/20180528152339_create_table_organizations_roles.js +++ b/api/db/migrations/20180528152339_create_table_organizations_roles.js @@ -1,7 +1,7 @@ const ORGANIZATION_ROLES_TABLE = 'organization-roles'; const ORGANIZATIONS_ACCESSES_TABLE = 'organizations-accesses'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema .createTable(ORGANIZATION_ROLES_TABLE, (table) => { table.increments('id').primary(); @@ -21,8 +21,10 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(ORGANIZATIONS_ACCESSES_TABLE).then(() => { return knex.schema.dropTable(ORGANIZATION_ROLES_TABLE); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180620161732_create_campaigns.js b/api/db/migrations/20180620161732_create_campaigns.js index 0ed9a4e4e8f..babd4782a3d 100644 --- a/api/db/migrations/20180620161732_create_campaigns.js +++ b/api/db/migrations/20180620161732_create_campaigns.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'campaigns'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('name').notNullable(); @@ -11,6 +11,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20180711173105_create_knowledge-elements.js b/api/db/migrations/20180711173105_create_knowledge-elements.js index df6755438a4..924c8a52bf1 100644 --- a/api/db/migrations/20180711173105_create_knowledge-elements.js +++ b/api/db/migrations/20180711173105_create_knowledge-elements.js @@ -1,6 +1,6 @@ const KNOWLEDGE_ELEMENTS_TABLE_NAME = 'knowledge-elements'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(KNOWLEDGE_ELEMENTS_TABLE_NAME, (table) => { table.increments('id').primary(); table.string('source'); @@ -13,6 +13,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(KNOWLEDGE_ELEMENTS_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20180730120109_create_campaign_participations_table.js b/api/db/migrations/20180730120109_create_campaign_participations_table.js index 355eaceafd5..938606870b0 100644 --- a/api/db/migrations/20180730120109_create_campaign_participations_table.js +++ b/api/db/migrations/20180730120109_create_campaign_participations_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'campaign-participations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('campaignId').unsigned().references('campaigns.id').index(); @@ -9,6 +9,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20180731102046_create_target_profiles_table.js b/api/db/migrations/20180731102046_create_target_profiles_table.js index 89192dfe06d..7943ec281c8 100644 --- a/api/db/migrations/20180731102046_create_target_profiles_table.js +++ b/api/db/migrations/20180731102046_create_target_profiles_table.js @@ -2,7 +2,7 @@ const TABLE_NAME_TARGET_PROFILES = 'target-profiles'; const TABLE_NAME_TARGET_PROFILES_SKILLS = 'target-profiles_skills'; const TABLE_NAME_CAMPAIGNS = 'campaigns'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema .createTable(TABLE_NAME_TARGET_PROFILES, (t) => { t.increments().primary(); @@ -25,7 +25,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema .table(TABLE_NAME_CAMPAIGNS, function (table) { table.dropColumn('targetProfileId'); @@ -37,3 +37,5 @@ exports.down = function (knex) { return knex.schema.dropTable(TABLE_NAME_TARGET_PROFILES); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180823170636_add_column_id_pix_in_campaigns.js b/api/db/migrations/20180823170636_add_column_id_pix_in_campaigns.js index 42d3e2a51f6..059f027bf4f 100644 --- a/api/db/migrations/20180823170636_add_column_id_pix_in_campaigns.js +++ b/api/db/migrations/20180823170636_add_column_id_pix_in_campaigns.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaigns'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('idPixLabel'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('idPixLabel'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180823173827_add-skill-id-to-certification-challenge.js b/api/db/migrations/20180823173827_add-skill-id-to-certification-challenge.js index 4b600e2dce6..d117b8b5a07 100644 --- a/api/db/migrations/20180823173827_add-skill-id-to-certification-challenge.js +++ b/api/db/migrations/20180823173827_add-skill-id-to-certification-challenge.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-challenges'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('associatedSkillId'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('associatedSkillId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180827141001_add_isShared_to_campaign_participations_table.js b/api/db/migrations/20180827141001_add_isShared_to_campaign_participations_table.js index cf0b43c73e7..1b3e8287c30 100644 --- a/api/db/migrations/20180827141001_add_isShared_to_campaign_participations_table.js +++ b/api/db/migrations/20180827141001_add_isShared_to_campaign_participations_table.js @@ -1,15 +1,17 @@ const TABLE_NAME = 'campaign-participations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean('isShared').notNullable().defaultTo(false); table.dateTime('sharedAt'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('isShared'); table.dropColumn('sharedAt'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180921125008_add-column-user-id-in-campaign-participation.js b/api/db/migrations/20180921125008_add-column-user-id-in-campaign-participation.js index 605532446e9..0392725e897 100644 --- a/api/db/migrations/20180921125008_add-column-user-id-in-campaign-participation.js +++ b/api/db/migrations/20180921125008_add-column-user-id-in-campaign-participation.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaign-participations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer('userId').unsigned().references('users.id').index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('userId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20180927153712_add_participant_external_id_to_campaign_participation.js b/api/db/migrations/20180927153712_add_participant_external_id_to_campaign_participation.js index 34d0b6bed6c..871f012e752 100644 --- a/api/db/migrations/20180927153712_add_participant_external_id_to_campaign_participation.js +++ b/api/db/migrations/20180927153712_add_participant_external_id_to_campaign_participation.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaign-participations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('participantExternalId'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('participantExternalId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181001172308_create_target_profile_shares.js b/api/db/migrations/20181001172308_create_target_profile_shares.js index 22a3241c97b..db49aa8bea7 100644 --- a/api/db/migrations/20181001172308_create_target_profile_shares.js +++ b/api/db/migrations/20181001172308_create_target_profile_shares.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'target-profile-shares'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('targetProfileId').unsigned().references('target-profiles.id').index(); @@ -9,6 +9,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20181002192146_add_pix_orga_tos_to_user.js b/api/db/migrations/20181002192146_add_pix_orga_tos_to_user.js index 673ef3108f3..bc1cb4b967f 100644 --- a/api/db/migrations/20181002192146_add_pix_orga_tos_to_user.js +++ b/api/db/migrations/20181002192146_add_pix_orga_tos_to_user.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'users'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean('pixOrgaTermsOfServiceAccepted').defaultTo(false); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('pixOrgaTermsOfServiceAccepted'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181010091446_update_organizations_remove_column_email.js b/api/db/migrations/20181010091446_update_organizations_remove_column_email.js index 179404f43a0..d86789e4e82 100644 --- a/api/db/migrations/20181010091446_update_organizations_remove_column_email.js +++ b/api/db/migrations/20181010091446_update_organizations_remove_column_email.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'organizations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('email'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('email'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181015115708_add_title_to_campaign.js b/api/db/migrations/20181015115708_add_title_to_campaign.js index 1365191ddf0..e93dbbfa321 100644 --- a/api/db/migrations/20181015115708_add_title_to_campaign.js +++ b/api/db/migrations/20181015115708_add_title_to_campaign.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaigns'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('title'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('title'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181017163633_delete-followers.js b/api/db/migrations/20181017163633_delete-followers.js index e25847f5ffc..56919ab1efa 100644 --- a/api/db/migrations/20181017163633_delete-followers.js +++ b/api/db/migrations/20181017163633_delete-followers.js @@ -1,10 +1,10 @@ const TABLE_NAME = 'followers'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = (knex) => { +const down = function (knex) { function table(t) { t.increments().primary(); t.string('email').unique().notNullable(); @@ -14,3 +14,5 @@ exports.down = (knex) => { return knex.schema.createTable(TABLE_NAME, table); }; + +export { up, down }; diff --git a/api/db/migrations/20181023231845_update_organizations_add_column_logourl.js b/api/db/migrations/20181023231845_update_organizations_add_column_logourl.js index b857af39034..166b8980ead 100644 --- a/api/db/migrations/20181023231845_update_organizations_add_column_logourl.js +++ b/api/db/migrations/20181023231845_update_organizations_add_column_logourl.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'organizations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text('logoUrl'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.drop('logoUrl'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181030141633_add_custom_landing_page_text_to_campaign.js b/api/db/migrations/20181030141633_add_custom_landing_page_text_to_campaign.js index 5c23bc3086d..a87d39ed0ce 100644 --- a/api/db/migrations/20181030141633_add_custom_landing_page_text_to_campaign.js +++ b/api/db/migrations/20181030141633_add_custom_landing_page_text_to_campaign.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaigns'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text('customLandingPageText'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('customLandingPageText'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181031151955_rename-organization-accesses-into-memberships.js b/api/db/migrations/20181031151955_rename-organization-accesses-into-memberships.js index d52c3179bd6..585664e5039 100644 --- a/api/db/migrations/20181031151955_rename-organization-accesses-into-memberships.js +++ b/api/db/migrations/20181031151955_rename-organization-accesses-into-memberships.js @@ -1,9 +1,11 @@ const TABLE_NAME = 'organizations-accesses'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.renameTable(TABLE_NAME, 'memberships'); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.renameTable('memberships', TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20181113161140_add_samlId_to_user.js b/api/db/migrations/20181113161140_add_samlId_to_user.js index d215b88a739..fbb1c6ffdb0 100644 --- a/api/db/migrations/20181113161140_add_samlId_to_user.js +++ b/api/db/migrations/20181113161140_add_samlId_to_user.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'users'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('samlId').unique(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('samlId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181121105953_make_users_email_nullable.js b/api/db/migrations/20181121105953_make_users_email_nullable.js index 7c1e7006c6c..f23d1d5efe6 100644 --- a/api/db/migrations/20181121105953_make_users_email_nullable.js +++ b/api/db/migrations/20181121105953_make_users_email_nullable.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'users'; -exports.up = async (knex) => { +const up = async function (knex) { // SQLite does not support altering columns, so we do not try to alter // the column if it is already nullable, and we have modified the column // creation in the original migration to create it as nullable. @@ -13,8 +13,10 @@ exports.up = async (knex) => { } }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.string('email').notNullable().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181128103517_add_column_create_at_to_knowledge_elements.js b/api/db/migrations/20181128103517_add_column_create_at_to_knowledge_elements.js index 689ab6ef6ed..f156875234c 100644 --- a/api/db/migrations/20181128103517_add_column_create_at_to_knowledge_elements.js +++ b/api/db/migrations/20181128103517_add_column_create_at_to_knowledge_elements.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'knowledge-elements'; -exports.up = async (knex) => { +const up = async function (knex) { const info = await knex(TABLE_NAME).columnInfo(); if (!info.createdAt) { return knex.schema @@ -13,8 +13,10 @@ exports.up = async (knex) => { } }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('createdAt'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181128135852_add_pix_certif_tos_to_user.js b/api/db/migrations/20181128135852_add_pix_certif_tos_to_user.js index 2d652be9841..f9e278ebe05 100644 --- a/api/db/migrations/20181128135852_add_pix_certif_tos_to_user.js +++ b/api/db/migrations/20181128135852_add_pix_certif_tos_to_user.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'users'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean('pixCertifTermsOfServiceAccepted').defaultTo(false); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('pixCertifTermsOfServiceAccepted'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20181210154610_delete_column_email_from_feedbacks.js b/api/db/migrations/20181210154610_delete_column_email_from_feedbacks.js index fe3eed4759d..32083509382 100644 --- a/api/db/migrations/20181210154610_delete_column_email_from_feedbacks.js +++ b/api/db/migrations/20181210154610_delete_column_email_from_feedbacks.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'feedbacks'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('email'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('email'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190115155237_create_certification_center_table.js b/api/db/migrations/20190115155237_create_certification_center_table.js index 4208704f6e0..f34f8c131e4 100644 --- a/api/db/migrations/20190115155237_create_certification_center_table.js +++ b/api/db/migrations/20190115155237_create_certification_center_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-centers'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('name').notNullable(); @@ -8,6 +8,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20190116013637_update_memberships_add_foreign_key.js b/api/db/migrations/20190116013637_update_memberships_add_foreign_key.js index 9a02b7f6e08..44274ab37c1 100644 --- a/api/db/migrations/20190116013637_update_memberships_add_foreign_key.js +++ b/api/db/migrations/20190116013637_update_memberships_add_foreign_key.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'memberships'; -exports.up = async (knex) => { +const up = async function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.unique(['userId', 'organizationId']); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['userId', 'organizationId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190117115615_create_certification_center_memberships_table.js b/api/db/migrations/20190117115615_create_certification_center_memberships_table.js index b0c307a5f5e..3459ea3bd4e 100644 --- a/api/db/migrations/20190117115615_create_certification_center_memberships_table.js +++ b/api/db/migrations/20190117115615_create_certification_center_memberships_table.js @@ -1,6 +1,6 @@ const CERTIFICATION_CENTER_MEMBERSHIPS = 'certification-center-memberships'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(CERTIFICATION_CENTER_MEMBERSHIPS, (t) => { t.increments('id').primary(); t.bigInteger('userId').references('users.id').index(); @@ -10,6 +10,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(CERTIFICATION_CENTER_MEMBERSHIPS); }; + +export { up, down }; diff --git a/api/db/migrations/20190117170302_add_certificationCenterId_to_sessions.js b/api/db/migrations/20190117170302_add_certificationCenterId_to_sessions.js index a1144a78973..6f7f331aa6a 100644 --- a/api/db/migrations/20190117170302_add_certificationCenterId_to_sessions.js +++ b/api/db/migrations/20190117170302_add_certificationCenterId_to_sessions.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'sessions'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer('certificationCenterId').references('certification-centers.id').index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('certificationCenterId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190205153549_update_pix-score_column_in_knowledge_element_table.js b/api/db/migrations/20190205153549_update_pix-score_column_in_knowledge_element_table.js index 0e8267b0487..8813df4914c 100644 --- a/api/db/migrations/20190205153549_update_pix-score_column_in_knowledge_element_table.js +++ b/api/db/migrations/20190205153549_update_pix-score_column_in_knowledge_element_table.js @@ -1,36 +1,15 @@ const TABLE_NAME = 'knowledge-elements'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (t) => { t.float('earnedPix').notNullable().defaultTo(0); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, (t) => { t.dropColumn('earnedPix'); }); }; -/* Generating the skill value table: - -require('dotenv').config(); -const airtable = require('./lib/infrastructure/airtable.js'); -const _ = require('lodash'); - -async function getPixValues() { - const acquis = await airtable.findRecords('Acquis'); // [ Acquis { … }, … ] - const byValue = _.groupBy(acquis, 'fields.PixValue'); // { "0": [ Acquis { … }, … ], … } - const idsByValue = _(byValue) - .toPairs() // [ [ "0", [ Acquis { … }, … ] ], … ] - .reject([0, "0"]) // [ [ "4.0", [ Acquis { … }, … ] ], … ] - .sortBy(0) // [ [ "0.5", [ Acquis { … }, … ] ], … ] - .map(([value, acquis]) => ` "${value}": ${JSON.stringify(_.map(acquis, 'id').sort())},`) - // [ '"0.5": ["recAvcedefz", …]' ] - .value(); - console.log(`const acquisByValue = {\n${idsByValue.join('\n')}\n};`); -} - -getPixValues().then(()=>{process.exit(0)}); - -*/ +export { up, down }; diff --git a/api/db/migrations/20190206150018_delete_skills_table.js b/api/db/migrations/20190206150018_delete_skills_table.js index 52d9128332a..602ff3b196b 100644 --- a/api/db/migrations/20190206150018_delete_skills_table.js +++ b/api/db/migrations/20190206150018_delete_skills_table.js @@ -1,10 +1,10 @@ const TABLE_NAME = 'skills'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = (knex) => { +const down = function (knex) { function table(t) { t.increments().primary(); t.integer('assessmentId').unsigned().references('assessments.id').index(); @@ -16,3 +16,5 @@ exports.down = (knex) => { return knex.schema.createTable(TABLE_NAME, table); }; + +export { up, down }; diff --git a/api/db/migrations/20190301111215_add_column_user_id_to_knowledge_elements.js b/api/db/migrations/20190301111215_add_column_user_id_to_knowledge_elements.js index bf431512d8b..fba131345ce 100644 --- a/api/db/migrations/20190301111215_add_column_user_id_to_knowledge_elements.js +++ b/api/db/migrations/20190301111215_add_column_user_id_to_knowledge_elements.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'knowledge-elements'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer('userId').references('users.id').index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('userId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190301111229_add_column_competence_to_knowlege_elements.js b/api/db/migrations/20190301111229_add_column_competence_to_knowlege_elements.js index f2d6efb0ac7..488ca05265f 100644 --- a/api/db/migrations/20190301111229_add_column_competence_to_knowlege_elements.js +++ b/api/db/migrations/20190301111229_add_column_competence_to_knowlege_elements.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'knowledge-elements'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('competenceId').index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('competenceId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190301152021_remove_pix_score_column_of_knowledge_elements.js b/api/db/migrations/20190301152021_remove_pix_score_column_of_knowledge_elements.js index 574d99e0373..df35ab95e43 100644 --- a/api/db/migrations/20190301152021_remove_pix_score_column_of_knowledge_elements.js +++ b/api/db/migrations/20190301152021_remove_pix_score_column_of_knowledge_elements.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'knowledge-elements'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('pixScore'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('pixScore'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190405155259_create_competence_evaluations_table.js b/api/db/migrations/20190405155259_create_competence_evaluations_table.js index 5b964b98bc6..312a53dd6fc 100644 --- a/api/db/migrations/20190405155259_create_competence_evaluations_table.js +++ b/api/db/migrations/20190405155259_create_competence_evaluations_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'competence-evaluations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('assessmentId').unsigned().references('assessments.id').index(); @@ -11,6 +11,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20190503173617_add_courseId_index_to_assessments_table.js b/api/db/migrations/20190503173617_add_courseId_index_to_assessments_table.js index da880f287e5..9cef08b2677 100644 --- a/api/db/migrations/20190503173617_add_courseId_index_to_assessments_table.js +++ b/api/db/migrations/20190503173617_add_courseId_index_to_assessments_table.js @@ -1,7 +1,9 @@ -exports.up = (knex) => { +const up = function (knex) { return knex.raw('CREATE INDEX "assessment_courseid_index" ON assessments ("courseId");'); }; -exports.down = (knex) => { +const down = function (knex) { return knex.raw('DROP INDEX "assessment_courseid_index";'); }; + +export { up, down }; diff --git a/api/db/migrations/20190520161908_add_status_to_competence_evaluations.js b/api/db/migrations/20190520161908_add_status_to_competence_evaluations.js index 365a28f3686..07c017f482b 100644 --- a/api/db/migrations/20190520161908_add_status_to_competence_evaluations.js +++ b/api/db/migrations/20190520161908_add_status_to_competence_evaluations.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'competence-evaluations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('status'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('status'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190529124405_add_column_competence_id_in_assessments.js b/api/db/migrations/20190529124405_add_column_competence_id_in_assessments.js index 7b86e3d5d4d..120fb6473e5 100644 --- a/api/db/migrations/20190529124405_add_column_competence_id_in_assessments.js +++ b/api/db/migrations/20190529124405_add_column_competence_id_in_assessments.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'assessments'; -exports.up = async function (knex) { +const up = async function (knex) { const info = await knex(TABLE_NAME).columnInfo(); if (!info.competenceId) { await knex.schema.table(TABLE_NAME, (t) => t.string('competenceId').index()); @@ -12,8 +12,10 @@ exports.up = async function (knex) { } }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (t) => { t.dropColumn('competenceId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190606125500_add_is-v2-certification_column_in_certification-course.js b/api/db/migrations/20190606125500_add_is-v2-certification_column_in_certification-course.js index b85ca3b0714..338426b108c 100644 --- a/api/db/migrations/20190606125500_add_is-v2-certification_column_in_certification-course.js +++ b/api/db/migrations/20190606125500_add_is-v2-certification_column_in_certification-course.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-courses'; const COLUMN_NAME = 'isV2Certification'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190621155332_create_member_organization_role.js b/api/db/migrations/20190621155332_create_member_organization_role.js index 800ad528f87..b9d33828691 100644 --- a/api/db/migrations/20190621155332_create_member_organization_role.js +++ b/api/db/migrations/20190621155332_create_member_organization_role.js @@ -1,9 +1,11 @@ const TABLE_NAME = 'organization-roles'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).insert({ id: 2, name: 'MEMBER' }); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).where('name', 'MEMBER').delete(); }; + +export { up, down }; diff --git a/api/db/migrations/20190626111900_add_campaign_participation_unique_constraint_on_user_and_campaign.js b/api/db/migrations/20190626111900_add_campaign_participation_unique_constraint_on_user_and_campaign.js index 3ed45db30fc..c133123566f 100644 --- a/api/db/migrations/20190626111900_add_campaign_participation_unique_constraint_on_user_and_campaign.js +++ b/api/db/migrations/20190626111900_add_campaign_participation_unique_constraint_on_user_and_campaign.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'campaign-participations'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw(` DELETE FROM "campaign-participations" WHERE id IN ( @@ -18,8 +18,10 @@ exports.up = async function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['campaignId', 'userId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190627154044_create_certification_candidates_table.js b/api/db/migrations/20190627154044_create_certification_candidates_table.js index 9617fcbb5a2..811f6cfc1b1 100644 --- a/api/db/migrations/20190627154044_create_certification_candidates_table.js +++ b/api/db/migrations/20190627154044_create_certification_candidates_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-candidates'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('firstName').notNullable(); @@ -14,6 +14,8 @@ exports.up = async (knex) => { }); }; -exports.down = async (knex) => { +const down = async function (knex) { await knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20190701102247_remove_organizationRoleId_column.js b/api/db/migrations/20190701102247_remove_organizationRoleId_column.js index fc4b9947c93..ec777082767 100644 --- a/api/db/migrations/20190701102247_remove_organizationRoleId_column.js +++ b/api/db/migrations/20190701102247_remove_organizationRoleId_column.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'memberships'; -exports.up = async function (knex) { +const up = async function (knex) { const info = await knex(TABLE_NAME).columnInfo(); if (info.organizationRoleId) { await knex.schema.alterTable(TABLE_NAME, (table) => { @@ -13,7 +13,7 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.alterTable(TABLE_NAME, (table) => { table.bigInteger('organizationRoleId').references('organization-roles.id').index(); table.dropColumn('organizationRole'); @@ -26,3 +26,5 @@ exports.down = async function (knex) { 'ADMIN', ]); }; + +export { up, down }; diff --git a/api/db/migrations/20190702111254_remove_organization_roles_table.js b/api/db/migrations/20190702111254_remove_organization_roles_table.js index ce14668774b..e525cdfb7ec 100644 --- a/api/db/migrations/20190702111254_remove_organization_roles_table.js +++ b/api/db/migrations/20190702111254_remove_organization_roles_table.js @@ -1,10 +1,10 @@ const TABLE_NAME = 'organization-roles'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema .createTable(TABLE_NAME, (table) => { table.increments('id').primary(); @@ -16,3 +16,5 @@ exports.down = function (knex) { return knex.batchInsert(TABLE_NAME, roles); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190703140740_add_MEMBER_role_to_memberships.js b/api/db/migrations/20190703140740_add_MEMBER_role_to_memberships.js index d7965288c47..91a32358303 100644 --- a/api/db/migrations/20190703140740_add_MEMBER_role_to_memberships.js +++ b/api/db/migrations/20190703140740_add_MEMBER_role_to_memberships.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'memberships'; -exports.up = async function (knex) { +const up = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw(` WITH newroles AS ( @@ -13,9 +13,10 @@ exports.up = async function (knex) { `); }; -// Rollback, make every membership an MEMBER -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).update({ organizationRole: 'MEMBER', }); }; + +export { up, down }; diff --git a/api/db/migrations/20190705112020_add_column_had-seen-new-profile-info_to_user.js b/api/db/migrations/20190705112020_add_column_had-seen-new-profile-info_to_user.js index 6acb6f73153..ff3221d6fbe 100644 --- a/api/db/migrations/20190705112020_add_column_had-seen-new-profile-info_to_user.js +++ b/api/db/migrations/20190705112020_add_column_had-seen-new-profile-info_to_user.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'hasSeenNewProfileInfo'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190709160455_add_column_to_remember_migration_to_user.js b/api/db/migrations/20190709160455_add_column_to_remember_migration_to_user.js index 7238db6664e..cfd65df6667 100644 --- a/api/db/migrations/20190709160455_add_column_to_remember_migration_to_user.js +++ b/api/db/migrations/20190709160455_add_column_to_remember_migration_to_user.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'users'; const COLUMN_NAME_PROFILEV2 = 'isProfileV2'; const COLUMN_NAME_PROFILEV2_DATE = 'migratedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME_PROFILEV2).notNullable().defaultTo(false); table.dateTime(COLUMN_NAME_PROFILEV2_DATE).nullable(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME_PROFILEV2); table.dropColumn(COLUMN_NAME_PROFILEV2_DATE); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190719152419_add_column_externalId_to_organizations.js b/api/db/migrations/20190719152419_add_column_externalId_to_organizations.js index 8b347a5e24c..f346106511d 100644 --- a/api/db/migrations/20190719152419_add_column_externalId_to_organizations.js +++ b/api/db/migrations/20190719152419_add_column_externalId_to_organizations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'externalId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME).index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190729162546_create_table_students.js b/api/db/migrations/20190729162546_create_table_students.js index 268edbca96f..afbb2301b43 100644 --- a/api/db/migrations/20190729162546_create_table_students.js +++ b/api/db/migrations/20190729162546_create_table_students.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'students'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('userId').unsigned().references('users.id').index(); @@ -13,6 +13,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20190730172148_add_column_has-seen-assessment-instructions_to_user.js b/api/db/migrations/20190730172148_add_column_has-seen-assessment-instructions_to_user.js index 5df42493967..80b7ddb5898 100644 --- a/api/db/migrations/20190730172148_add_column_has-seen-assessment-instructions_to_user.js +++ b/api/db/migrations/20190730172148_add_column_has-seen-assessment-instructions_to_user.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'hasSeenAssessmentInstructions'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190730175015_add_column_isManagingStudents_to_organizations.js b/api/db/migrations/20190730175015_add_column_isManagingStudents_to_organizations.js index 4541868de12..72afe6ee049 100644 --- a/api/db/migrations/20190730175015_add_column_isManagingStudents_to_organizations.js +++ b/api/db/migrations/20190730175015_add_column_isManagingStudents_to_organizations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'isManagingStudents'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190820092603_add_several_attributes_to_student.js b/api/db/migrations/20190820092603_add_several_attributes_to_student.js index 057cd61f7f1..c749108d441 100644 --- a/api/db/migrations/20190820092603_add_several_attributes_to_student.js +++ b/api/db/migrations/20190820092603_add_several_attributes_to_student.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'students'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('preferredLastName'); table.string('middleName'); @@ -16,7 +16,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('preferredLastName'); table.dropColumn('middleName'); @@ -31,3 +31,5 @@ exports.down = function (knex) { table.dropColumn('division'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190822152123_add_column_category_and_answer_to_feedback_form.js b/api/db/migrations/20190822152123_add_column_category_and_answer_to_feedback_form.js index 44d485b3a3b..27824d6bfd9 100644 --- a/api/db/migrations/20190822152123_add_column_category_and_answer_to_feedback_form.js +++ b/api/db/migrations/20190822152123_add_column_category_and_answer_to_feedback_form.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'feedbacks'; const COLUMN_CATEGORY = 'category'; const COLUMN_ANSWER = 'answer'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_CATEGORY); table.string(COLUMN_ANSWER); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_CATEGORY); table.dropColumn(COLUMN_ANSWER); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190826131512_add_column_isImproving_to_Assessments.js b/api/db/migrations/20190826131512_add_column_isImproving_to_Assessments.js index a2f2c318887..9854879d5a6 100644 --- a/api/db/migrations/20190826131512_add_column_isImproving_to_Assessments.js +++ b/api/db/migrations/20190826131512_add_column_isImproving_to_Assessments.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'assessments'; const COLUMN_NAME = 'isImproving'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190826140605_add_column_campaign_participation_id_in_assessments.js b/api/db/migrations/20190826140605_add_column_campaign_participation_id_in_assessments.js index 7a176a6d345..8d51db43dbe 100644 --- a/api/db/migrations/20190826140605_add_column_campaign_participation_id_in_assessments.js +++ b/api/db/migrations/20190826140605_add_column_campaign_participation_id_in_assessments.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'assessments'; -exports.up = async function (knex) { +const up = async function (knex) { const info = await knex(TABLE_NAME).columnInfo(); if (!info.campaignParticipationId) { await knex.schema.table(TABLE_NAME, (t) => @@ -14,8 +14,10 @@ exports.up = async function (knex) { } }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (t) => { t.dropColumn('campaignParticipationId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190904140605_remove_column_assessment_id_in_campaign_participation.js b/api/db/migrations/20190904140605_remove_column_assessment_id_in_campaign_participation.js index 2c7b48cfde8..038af1c5abb 100644 --- a/api/db/migrations/20190904140605_remove_column_assessment_id_in_campaign_participation.js +++ b/api/db/migrations/20190904140605_remove_column_assessment_id_in_campaign_participation.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'campaign-participations'; -exports.up = async function (knex) { +const up = async function (knex) { const info = await knex(TABLE_NAME).columnInfo(); if (info.assessmentId) { await knex.schema.alterTable(TABLE_NAME, (table) => { @@ -8,10 +8,13 @@ exports.up = async function (knex) { }); } }; -exports.down = async function (knex) { + +const down = async function (knex) { await knex.schema.table(TABLE_NAME, (t) => t.integer('assessmentId').unsigned().references('assessments.id').index()); await knex.raw(` UPDATE "campaign-participations" SET "assessmentId" = (SELECT id FROM "assessments" WHERE "campaign-participations".id = assessments."campaignParticipationId" ORDER BY "assessments"."createdAt" desc limit 1) `); }; + +export { up, down }; diff --git a/api/db/migrations/20190905120343_alter_table_assessments_column_user_id_from_bigint_to_integer.js b/api/db/migrations/20190905120343_alter_table_assessments_column_user_id_from_bigint_to_integer.js index 76902f08cd4..98ea979ae17 100644 --- a/api/db/migrations/20190905120343_alter_table_assessments_column_user_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190905120343_alter_table_assessments_column_user_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'assessments'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('userId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('userId').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906090933_alter_table_certification_center_memberships_column_user_id_from_bigint_to_integer.js b/api/db/migrations/20190906090933_alter_table_certification_center_memberships_column_user_id_from_bigint_to_integer.js index c65930ec1b0..42e5b793e9f 100644 --- a/api/db/migrations/20190906090933_alter_table_certification_center_memberships_column_user_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906090933_alter_table_certification_center_memberships_column_user_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-center-memberships'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('userId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('userId').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906094217_alter_table_certification_center_memberships_column_certification_center_id_from_bigint_to_integer.js b/api/db/migrations/20190906094217_alter_table_certification_center_memberships_column_certification_center_id_from_bigint_to_integer.js index e72be059d77..8d20d382c41 100644 --- a/api/db/migrations/20190906094217_alter_table_certification_center_memberships_column_certification_center_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906094217_alter_table_certification_center_memberships_column_certification_center_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-center-memberships'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('certificationCenterId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('certificationCenterId').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906100845_alter_table_certification_challenges_column_course_id_from_bigint_to_integer.js b/api/db/migrations/20190906100845_alter_table_certification_challenges_column_course_id_from_bigint_to_integer.js index 77c6bcceca5..de3ae22324b 100644 --- a/api/db/migrations/20190906100845_alter_table_certification_challenges_column_course_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906100845_alter_table_certification_challenges_column_course_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-challenges'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('courseId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('courseId').unsigned().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906101419_alter_table_memberships_column_user_id_from_bigint_to_integer.js b/api/db/migrations/20190906101419_alter_table_memberships_column_user_id_from_bigint_to_integer.js index eb223041d0c..06a14d7b885 100644 --- a/api/db/migrations/20190906101419_alter_table_memberships_column_user_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906101419_alter_table_memberships_column_user_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'memberships'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('userId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('userId').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906101520_alter_table_memberships_column_organization_id_from_bigint_to_integer.js b/api/db/migrations/20190906101520_alter_table_memberships_column_organization_id_from_bigint_to_integer.js index c3b2e23fb09..7662aec4206 100644 --- a/api/db/migrations/20190906101520_alter_table_memberships_column_organization_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906101520_alter_table_memberships_column_organization_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'memberships'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('organizationId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('organizationId').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906101739_alter_table_organizations_column_user_id_from_bigint_to_integer.js b/api/db/migrations/20190906101739_alter_table_organizations_column_user_id_from_bigint_to_integer.js index f2ed3aa4522..9ae8b98b423 100644 --- a/api/db/migrations/20190906101739_alter_table_organizations_column_user_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906101739_alter_table_organizations_column_user_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'organizations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('userId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('userId').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906101930_alter_table_snapshots_column_user_id_from_bigint_to_integer.js b/api/db/migrations/20190906101930_alter_table_snapshots_column_user_id_from_bigint_to_integer.js index 07a543b865a..30b6f257224 100644 --- a/api/db/migrations/20190906101930_alter_table_snapshots_column_user_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906101930_alter_table_snapshots_column_user_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'snapshots'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('userId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('userId').unsigned().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906102015_alter_table_snapshots_column_organization_id_from_bigint_to_integer.js b/api/db/migrations/20190906102015_alter_table_snapshots_column_organization_id_from_bigint_to_integer.js index b1907f4b2a6..8bd5ca901d0 100644 --- a/api/db/migrations/20190906102015_alter_table_snapshots_column_organization_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906102015_alter_table_snapshots_column_organization_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'snapshots'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('organizationId').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('organizationId').unsigned().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906102158_alter_table_users_pix_roles_column_user_id_from_bigint_to_integer.js b/api/db/migrations/20190906102158_alter_table_users_pix_roles_column_user_id_from_bigint_to_integer.js index f786f79243d..db257feabfb 100644 --- a/api/db/migrations/20190906102158_alter_table_users_pix_roles_column_user_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906102158_alter_table_users_pix_roles_column_user_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'users_pix_roles'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('user_id').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('user_id').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190906102335_alter_table_users_pix_roles_column_pix_role_id_from_bigint_to_integer.js b/api/db/migrations/20190906102335_alter_table_users_pix_roles_column_pix_role_id_from_bigint_to_integer.js index 6345c4387ca..9ff58171874 100644 --- a/api/db/migrations/20190906102335_alter_table_users_pix_roles_column_pix_role_id_from_bigint_to_integer.js +++ b/api/db/migrations/20190906102335_alter_table_users_pix_roles_column_pix_role_id_from_bigint_to_integer.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'users_pix_roles'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.integer('pix_role_id').unsigned().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.bigInteger('pix_role_id').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190910165023_create_organization_invitations_table.js b/api/db/migrations/20190910165023_create_organization_invitations_table.js index 4b08aac9e94..cc4971bcf78 100644 --- a/api/db/migrations/20190910165023_create_organization_invitations_table.js +++ b/api/db/migrations/20190910165023_create_organization_invitations_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'organization-invitations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (table) => { table.increments('id').primary(); table.integer('organizationId').unsigned().references('organizations.id').index(); @@ -11,6 +11,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20190918105231_add_column_provinceCode_to_organizations.js b/api/db/migrations/20190918105231_add_column_provinceCode_to_organizations.js index a0d5d981138..2753e34520d 100644 --- a/api/db/migrations/20190918105231_add_column_provinceCode_to_organizations.js +++ b/api/db/migrations/20190918105231_add_column_provinceCode_to_organizations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'provinceCode'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME).index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20190930115538_rename_column_birthplace_into_birthCity_in_certification_candidates.js b/api/db/migrations/20190930115538_rename_column_birthplace_into_birthCity_in_certification_candidates.js index 7aee0fbf587..4617e9c68c8 100644 --- a/api/db/migrations/20190930115538_rename_column_birthplace_into_birthCity_in_certification_candidates.js +++ b/api/db/migrations/20190930115538_rename_column_birthplace_into_birthCity_in_certification_candidates.js @@ -2,10 +2,12 @@ const TABLE_NAME = 'certification-candidates'; const OLD_COLUMN_NAME = 'birthplace'; const NEW_COLUMN_NAME = 'birthCity'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(OLD_COLUMN_NAME, NEW_COLUMN_NAME)); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20190930121453_add_columns_birthProvinceCode_and_birthCity_to_certification_candidates.js b/api/db/migrations/20190930121453_add_columns_birthProvinceCode_and_birthCity_to_certification_candidates.js index 4838b83850d..f5e19662255 100644 --- a/api/db/migrations/20190930121453_add_columns_birthProvinceCode_and_birthCity_to_certification_candidates.js +++ b/api/db/migrations/20190930121453_add_columns_birthProvinceCode_and_birthCity_to_certification_candidates.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'certification-candidates'; const BIRTH_PROVINCE_CODE_COLUMN_NAME = 'birthProvinceCode'; const BIRTH_COUNTRY_COLUMN_NAME = 'birthCountry'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(BIRTH_PROVINCE_CODE_COLUMN_NAME); table.string(BIRTH_COUNTRY_COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(BIRTH_PROVINCE_CODE_COLUMN_NAME); table.dropColumn(BIRTH_COUNTRY_COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191008142311_alter_feedback_answer_column_to_text.js b/api/db/migrations/20191008142311_alter_feedback_answer_column_to_text.js index 72d04b634c6..fdca2340bcf 100644 --- a/api/db/migrations/20191008142311_alter_feedback_answer_column_to_text.js +++ b/api/db/migrations/20191008142311_alter_feedback_answer_column_to_text.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'feedbacks'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.text('answer').alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.string('answer').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191014155036_add_code_to_organizationInvitations.js b/api/db/migrations/20191014155036_add_code_to_organizationInvitations.js index 10c091e6ee7..758779c0284 100644 --- a/api/db/migrations/20191014155036_add_code_to_organizationInvitations.js +++ b/api/db/migrations/20191014155036_add_code_to_organizationInvitations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organization-invitations'; const COLUMN_NAME = 'code'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME).notNullable(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191017151624_add_columns_outdated_to_target_profiles_table.js b/api/db/migrations/20191017151624_add_columns_outdated_to_target_profiles_table.js index 8188cda93bc..19c5ad12a86 100644 --- a/api/db/migrations/20191017151624_add_columns_outdated_to_target_profiles_table.js +++ b/api/db/migrations/20191017151624_add_columns_outdated_to_target_profiles_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'target-profiles'; const OUTDATED_COLUMN_NAME = 'outdated'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(OUTDATED_COLUMN_NAME).notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(OUTDATED_COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191025161754_add_column_user_id_to_certification_candidates.js b/api/db/migrations/20191025161754_add_column_user_id_to_certification_candidates.js index 6b5c6a56248..b11681b7dd2 100644 --- a/api/db/migrations/20191025161754_add_column_user_id_to_certification_candidates.js +++ b/api/db/migrations/20191025161754_add_column_user_id_to_certification_candidates.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-candidates'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer('userId').references('users.id').index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('userId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191028171724_delete_column_hasSeenNewProfileInfo_users_table.js b/api/db/migrations/20191028171724_delete_column_hasSeenNewProfileInfo_users_table.js index 5e297333358..8218f74d00c 100644 --- a/api/db/migrations/20191028171724_delete_column_hasSeenNewProfileInfo_users_table.js +++ b/api/db/migrations/20191028171724_delete_column_hasSeenNewProfileInfo_users_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const OUTDATED_COLUMN_NAME = 'hasSeenNewProfileInfo'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(OUTDATED_COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(OUTDATED_COLUMN_NAME).notNullable().defaultTo(true); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191029091642_add_certification_candidates_unique_constraint_on_user_and_session.js b/api/db/migrations/20191029091642_add_certification_candidates_unique_constraint_on_user_and_session.js index 5953989db48..8d160ece4f6 100644 --- a/api/db/migrations/20191029091642_add_certification_candidates_unique_constraint_on_user_and_session.js +++ b/api/db/migrations/20191029091642_add_certification_candidates_unique_constraint_on_user_and_session.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-candidates'; -exports.up = async function (knex) { +const up = async function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.unique(['sessionId', 'userId']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['sessionId', 'userId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191029103059_add_column_status_in_session.js b/api/db/migrations/20191029103059_add_column_status_in_session.js index 5218ab98e16..4de3bd545c1 100644 --- a/api/db/migrations/20191029103059_add_column_status_in_session.js +++ b/api/db/migrations/20191029103059_add_column_status_in_session.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME = 'status'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => { table.string(COLUMN_NAME).defaultTo('started'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191112121128_update_memberships_modify_organizationRole.js b/api/db/migrations/20191112121128_update_memberships_modify_organizationRole.js index 1082958ba9b..12dfa43db0f 100644 --- a/api/db/migrations/20191112121128_update_memberships_modify_organizationRole.js +++ b/api/db/migrations/20191112121128_update_memberships_modify_organizationRole.js @@ -1,9 +1,11 @@ const TABLE_NAME = 'memberships'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).where('organizationRole', '=', 'OWNER').update({ organizationRole: 'ADMIN' }); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).where('organizationRole', '=', 'ADMIN').update({ organizationRole: 'OWNER' }); }; + +export { up, down }; diff --git a/api/db/migrations/20191115123716_trim_lastname_firstname_from_certification_candidate.js b/api/db/migrations/20191115123716_trim_lastname_firstname_from_certification_candidate.js index 88f568dc5ea..d7e956c6358 100644 --- a/api/db/migrations/20191115123716_trim_lastname_firstname_from_certification_candidate.js +++ b/api/db/migrations/20191115123716_trim_lastname_firstname_from_certification_candidate.js @@ -1,20 +1,19 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw(` - UPDATE "public"."certification-candidates" - SET "firstName" = trim("firstName"), - "lastName" = trim("lastName"), - "birthCity" = trim("birthCity"), - "birthCountry" = trim("birthCountry") - WHERE id IN - (SELECT "public"."certification-candidates"."id" AS "id" - FROM "public"."certification-candidates" - WHERE "public"."certification-candidates"."firstName" LIKE '% ' - OR "public"."certification-candidates"."lastName" LIKE '% ' - OR "public"."certification-candidates"."birthCity" LIKE '% ' - OR "public"."certification-candidates"."birthCountry" LIKE '% ' ); - `); -}; - -exports.down = function () { - // no rollback for this case + UPDATE "public"."certification-candidates" + SET "firstName" = trim("firstName"), + "lastName" = trim("lastName"), + "birthCity" = trim("birthCity"), + "birthCountry" = trim("birthCountry") + WHERE id IN + (SELECT "public"."certification-candidates"."id" AS "id" + FROM "public"."certification-candidates" + WHERE "public"."certification-candidates"."firstName" LIKE '% ' + OR "public"."certification-candidates"."lastName" LIKE '% ' + OR "public"."certification-candidates"."birthCity" LIKE '% ' + OR "public"."certification-candidates"."birthCountry" LIKE '% ' ); + `); }; +// eslint-disable-next-line no-empty-function +const down = function () {}; +export { up, down }; diff --git a/api/db/migrations/20191118173128_copy-external-id-from-candidate-to-course.js b/api/db/migrations/20191118173128_copy-external-id-from-candidate-to-course.js index fe10bc1b559..864ebbd5640 100644 --- a/api/db/migrations/20191118173128_copy-external-id-from-candidate-to-course.js +++ b/api/db/migrations/20191118173128_copy-external-id-from-candidate-to-course.js @@ -1,9 +1,9 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw(` UPDATE "public"."certification-courses" as cc SET "externalId" = joinCcAndCca."externalIdCertificationCandidate" FROM - ( SELECT + ( SELECT cc."id" AS "idCertificationCourse", cca."externalId" AS "externalIdCertificationCandidate" FROM "public"."certification-courses" AS cc @@ -12,11 +12,10 @@ exports.up = async function (knex) { AND cc."sessionId" = cca."sessionId" WHERE cca."externalId" IS NOT NULL AND cc."externalId" IS NULL ) as joinCcAndCca - + WHERE cc."id" = joinCcAndCca."idCertificationCourse"; `); }; - -exports.down = function () { - // no rollback for this case -}; +// eslint-disable-next-line no-empty-function +const down = function () {}; +export { up, down }; diff --git a/api/db/migrations/20191129100835_add_column_comment_to_session.js b/api/db/migrations/20191129100835_add_column_comment_to_session.js index 169ff9d4df9..7962e968680 100644 --- a/api/db/migrations/20191129100835_add_column_comment_to_session.js +++ b/api/db/migrations/20191129100835_add_column_comment_to_session.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME = 'examinerComment'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME, 500); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191202152127_add_column_externalId_to_certification_centers.js b/api/db/migrations/20191202152127_add_column_externalId_to_certification_centers.js index 9e38be331ff..22168d88d6b 100644 --- a/api/db/migrations/20191202152127_add_column_externalId_to_certification_centers.js +++ b/api/db/migrations/20191202152127_add_column_externalId_to_certification_centers.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-centers'; const COLUMN_NAME = 'externalId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191202152240_add_column_type_to_certification_centers.js b/api/db/migrations/20191202152240_add_column_type_to_certification_centers.js index 2b3928a1c3d..18efe2e7dad 100644 --- a/api/db/migrations/20191202152240_add_column_type_to_certification_centers.js +++ b/api/db/migrations/20191202152240_add_column_type_to_certification_centers.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-centers'; const COLUMN_NAME = 'type'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.enu(COLUMN_NAME, ['SCO', 'SUP', 'PRO']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191202164101_replace_unique_on_national_student_id_by_unique_on_national_student_id_and_organization_id.js b/api/db/migrations/20191202164101_replace_unique_on_national_student_id_by_unique_on_national_student_id_and_organization_id.js index 2bd41b5abde..aa5ca213ed3 100644 --- a/api/db/migrations/20191202164101_replace_unique_on_national_student_id_by_unique_on_national_student_id_and_organization_id.js +++ b/api/db/migrations/20191202164101_replace_unique_on_national_student_id_by_unique_on_national_student_id_and_organization_id.js @@ -1,15 +1,17 @@ const TABLE_NAME = 'students'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique('nationalStudentId'); table.unique(['nationalStudentId', 'organizationId']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.unique('nationalStudentId'); table.dropUnique(['nationalStudentId', 'organizationId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191203174112_add_students_unique_on_user_id_and_organization_id.js b/api/db/migrations/20191203174112_add_students_unique_on_user_id_and_organization_id.js index 8b3fb19140d..17f71d90ba8 100644 --- a/api/db/migrations/20191203174112_add_students_unique_on_user_id_and_organization_id.js +++ b/api/db/migrations/20191203174112_add_students_unique_on_user_id_and_organization_id.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'students'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.unique(['userId', 'organizationId']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['userId', 'organizationId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191208041507_add_columns_examinerComment_and_hasSeenEndTestScreen_on_certification_candidates.js b/api/db/migrations/20191208041507_add_columns_examinerComment_and_hasSeenEndTestScreen_on_certification_candidates.js index a28766733b8..9d71f7ef80c 100644 --- a/api/db/migrations/20191208041507_add_columns_examinerComment_and_hasSeenEndTestScreen_on_certification_candidates.js +++ b/api/db/migrations/20191208041507_add_columns_examinerComment_and_hasSeenEndTestScreen_on_certification_candidates.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'certification-candidates'; const EXAMINER_COMMENT_NAME = 'examinerComment'; const HAS_SEEN_END_TEST_SCREEN_NAME = 'hasSeenEndTestScreen'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(EXAMINER_COMMENT_NAME, 500); table.boolean(HAS_SEEN_END_TEST_SCREEN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(EXAMINER_COMMENT_NAME); table.dropColumn(HAS_SEEN_END_TEST_SCREEN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191211110034_add_column_email_for_session_report.js b/api/db/migrations/20191211110034_add_column_email_for_session_report.js index 58af1128e31..58d987eef4a 100644 --- a/api/db/migrations/20191211110034_add_column_email_for_session_report.js +++ b/api/db/migrations/20191211110034_add_column_email_for_session_report.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-candidates'; const COLUMN_NAME = 'email'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191217105506_add_username_to_users.js b/api/db/migrations/20191217105506_add_username_to_users.js index ae04b5a4dfb..604175808b6 100644 --- a/api/db/migrations/20191217105506_add_username_to_users.js +++ b/api/db/migrations/20191217105506_add_username_to_users.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'users'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('username').unique(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('username'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20191220174321_remove_user_migration_column.js b/api/db/migrations/20191220174321_remove_user_migration_column.js index 875510c39bf..6b3cbc63b67 100644 --- a/api/db/migrations/20191220174321_remove_user_migration_column.js +++ b/api/db/migrations/20191220174321_remove_user_migration_column.js @@ -1,15 +1,17 @@ const TABLE_NAME = 'users'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('isProfileV2'); table.dropColumn('migratedAt'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean('isProfileV2').defaultTo(true); table.dateTime('migratedAt').nullable(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200106155510_update_cgu_for_gar_users.js b/api/db/migrations/20200106155510_update_cgu_for_gar_users.js index ac99c4f8676..e85beb5d05d 100644 --- a/api/db/migrations/20200106155510_update_cgu_for_gar_users.js +++ b/api/db/migrations/20200106155510_update_cgu_for_gar_users.js @@ -1,9 +1,11 @@ const TABLE_NAME = 'users'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).whereNotNull('samlId').update({ cgu: false }); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).whereNotNull('samlId').update({ cgu: true }); }; + +export { up, down }; diff --git a/api/db/migrations/20200114155324_add_archived_at_column_on_campaigns.js b/api/db/migrations/20200114155324_add_archived_at_column_on_campaigns.js index 5466f7776c8..6ef97fe96c2 100644 --- a/api/db/migrations/20200114155324_add_archived_at_column_on_campaigns.js +++ b/api/db/migrations/20200114155324_add_archived_at_column_on_campaigns.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaigns'; const COLUMN_NAME = 'archivedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => { table.dateTime(COLUMN_NAME).nullable(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200117170614_rename_session_examiner_comment_to_examiner_global_comment.js b/api/db/migrations/20200117170614_rename_session_examiner_comment_to_examiner_global_comment.js index 61d747b1d08..b2f73c435ca 100644 --- a/api/db/migrations/20200117170614_rename_session_examiner_comment_to_examiner_global_comment.js +++ b/api/db/migrations/20200117170614_rename_session_examiner_comment_to_examiner_global_comment.js @@ -2,10 +2,12 @@ const TABLE_NAME = 'sessions'; const OLD_COLUMN_NAME = 'examinerComment'; const NEW_COLUMN_NAME = 'examinerGlobalComment'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(OLD_COLUMN_NAME, NEW_COLUMN_NAME)); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20200117173110_add_examinerComment_and_hasSeenEndTestScreen_to_certifCourses_table.js b/api/db/migrations/20200117173110_add_examinerComment_and_hasSeenEndTestScreen_to_certifCourses_table.js index 742da89a9f2..7778dcf6e1f 100644 --- a/api/db/migrations/20200117173110_add_examinerComment_and_hasSeenEndTestScreen_to_certifCourses_table.js +++ b/api/db/migrations/20200117173110_add_examinerComment_and_hasSeenEndTestScreen_to_certifCourses_table.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'certification-courses'; const EXAMINER_COMMENT_NAME = 'examinerComment'; const HAS_SEEN_END_TEST_SCREEN_NAME = 'hasSeenEndTestScreen'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(EXAMINER_COMMENT_NAME, 500); table.boolean(HAS_SEEN_END_TEST_SCREEN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(EXAMINER_COMMENT_NAME); table.dropColumn(HAS_SEEN_END_TEST_SCREEN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200117173940_remove_column_examinerComment_and_hasSeenEndTestScreen_from_certifCandidates_table.js b/api/db/migrations/20200117173940_remove_column_examinerComment_and_hasSeenEndTestScreen_from_certifCandidates_table.js index 2e2e494540a..c010493c582 100644 --- a/api/db/migrations/20200117173940_remove_column_examinerComment_and_hasSeenEndTestScreen_from_certifCandidates_table.js +++ b/api/db/migrations/20200117173940_remove_column_examinerComment_and_hasSeenEndTestScreen_from_certifCandidates_table.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'certification-candidates'; const FIRST_COLUMN_NAME = 'examinerComment'; const SECOND_COLUMN_NAME = 'hasSeenEndTestScreen'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(FIRST_COLUMN_NAME); table.dropColumn(SECOND_COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(FIRST_COLUMN_NAME); table.string(SECOND_COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200129155649_add_column_finalizedAt_to_sessions.js b/api/db/migrations/20200129155649_add_column_finalizedAt_to_sessions.js index 86e90d1613e..4484aa6815b 100644 --- a/api/db/migrations/20200129155649_add_column_finalizedAt_to_sessions.js +++ b/api/db/migrations/20200129155649_add_column_finalizedAt_to_sessions.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME = 'finalizedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200204191322_set_competenceId_for_legacy_placement_assessments.js b/api/db/migrations/20200204191322_set_competenceId_for_legacy_placement_assessments.js index 93982771154..5604c343011 100644 --- a/api/db/migrations/20200204191322_set_competenceId_for_legacy_placement_assessments.js +++ b/api/db/migrations/20200204191322_set_competenceId_for_legacy_placement_assessments.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'assessments'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME) .where({ type: 'PLACEMENT', @@ -28,7 +28,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME) .where({ type: 'PLACEMENT', @@ -37,3 +37,5 @@ exports.down = function (knex) { competenceId: null, }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212135345_fix_indexes_on_table_campaign-participations.js b/api/db/migrations/20200212135345_fix_indexes_on_table_campaign-participations.js index 018434ca8c5..3a47fea8234 100644 --- a/api/db/migrations/20200212135345_fix_indexes_on_table_campaign-participations.js +++ b/api/db/migrations/20200212135345_fix_indexes_on_table_campaign-participations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaign-participations'; const CAMPAIGNID_COLUMN = 'campaignId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(CAMPAIGNID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(CAMPAIGNID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212135819_fix_indexes_on_table_certification-candidates.js b/api/db/migrations/20200212135819_fix_indexes_on_table_certification-candidates.js index 131012785e6..8e2f1ac7dfb 100644 --- a/api/db/migrations/20200212135819_fix_indexes_on_table_certification-candidates.js +++ b/api/db/migrations/20200212135819_fix_indexes_on_table_certification-candidates.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-candidates'; const SESSIONID_COLUMN = 'sessionId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(SESSIONID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(SESSIONID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212140202_fix_indexes_on_table_certification-center-memberships.js b/api/db/migrations/20200212140202_fix_indexes_on_table_certification-center-memberships.js index dbdfef61523..d50345ced9c 100644 --- a/api/db/migrations/20200212140202_fix_indexes_on_table_certification-center-memberships.js +++ b/api/db/migrations/20200212140202_fix_indexes_on_table_certification-center-memberships.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'certification-center-memberships'; const USERID_COLUMN = 'userId'; const CERTIFICATIONCENTERID_COLUMN = 'certificationCenterId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(USERID_COLUMN); table.dropIndex(CERTIFICATIONCENTERID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(USERID_COLUMN); table.index(CERTIFICATIONCENTERID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212140810_fix_indexes_on_table_competence-evaluations.js b/api/db/migrations/20200212140810_fix_indexes_on_table_competence-evaluations.js index 426c10be98e..5170910a206 100644 --- a/api/db/migrations/20200212140810_fix_indexes_on_table_competence-evaluations.js +++ b/api/db/migrations/20200212140810_fix_indexes_on_table_competence-evaluations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'competence-evaluations'; const COMPETENCEID_COLUMN = 'competenceId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(COMPETENCEID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(COMPETENCEID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212141121_fix_indexes_on_table_knowledge-elements.js b/api/db/migrations/20200212141121_fix_indexes_on_table_knowledge-elements.js index 6602ef6c9f4..b2289e69531 100644 --- a/api/db/migrations/20200212141121_fix_indexes_on_table_knowledge-elements.js +++ b/api/db/migrations/20200212141121_fix_indexes_on_table_knowledge-elements.js @@ -4,7 +4,7 @@ const ANSWERID_COLUMN = 'answerId'; const ASSESSMENTID_COLUMN = 'assessmentId'; const COMPETENCEID_COLUMN = 'competenceId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(SKILLID_COLUMN); table.dropIndex(ANSWERID_COLUMN); @@ -13,7 +13,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(SKILLID_COLUMN); table.index(ANSWERID_COLUMN); @@ -21,3 +21,5 @@ exports.down = function (knex) { table.index(COMPETENCEID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212141456_fix_indexes_on_table_memberships.js b/api/db/migrations/20200212141456_fix_indexes_on_table_memberships.js index 8785330b89c..3cc36cd4f63 100644 --- a/api/db/migrations/20200212141456_fix_indexes_on_table_memberships.js +++ b/api/db/migrations/20200212141456_fix_indexes_on_table_memberships.js @@ -4,7 +4,7 @@ const ORGANIZATIONID_COLUMN = 'organizationId'; const OLD_INDEX_USERID = 'organizations_accesses_userid_index'; const OLD_INDEX_ORGANIZATIONID = 'organizations_accesses_organizationid_index'; -exports.up = async function (knex) { +const up = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw(`DROP INDEX IF EXISTS ${OLD_INDEX_USERID}`); // eslint-disable-next-line knex/avoid-injections @@ -14,10 +14,12 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(ORGANIZATIONID_COLUMN); table.index(USERID_COLUMN, OLD_INDEX_USERID); table.index(ORGANIZATIONID_COLUMN, OLD_INDEX_ORGANIZATIONID); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212141646_fix_indexes_on_table_organizations.js b/api/db/migrations/20200212141646_fix_indexes_on_table_organizations.js index 28274cde893..b0650adfbf2 100644 --- a/api/db/migrations/20200212141646_fix_indexes_on_table_organizations.js +++ b/api/db/migrations/20200212141646_fix_indexes_on_table_organizations.js @@ -4,7 +4,7 @@ const PROVINCECODE_COLUMN = 'provinceCode'; const EXTERNALID_COLUMN = 'externalId'; const CODE_COLUMN = 'code'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(USERID_COLUMN); table.dropIndex(PROVINCECODE_COLUMN); @@ -13,7 +13,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(USERID_COLUMN); table.index(PROVINCECODE_COLUMN); @@ -21,3 +21,5 @@ exports.down = function (knex) { table.dropIndex(CODE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212142949_fix_indexes_on_table_sessions.js b/api/db/migrations/20200212142949_fix_indexes_on_table_sessions.js index fcf150313ca..5d00d016bf6 100644 --- a/api/db/migrations/20200212142949_fix_indexes_on_table_sessions.js +++ b/api/db/migrations/20200212142949_fix_indexes_on_table_sessions.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'sessions'; const ACCESSCODE_COLUMN = 'accessCode'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(ACCESSCODE_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(ACCESSCODE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200212143352_fix_indexes_on_table_students.js b/api/db/migrations/20200212143352_fix_indexes_on_table_students.js index 767141da6f8..7fd2d7716de 100644 --- a/api/db/migrations/20200212143352_fix_indexes_on_table_students.js +++ b/api/db/migrations/20200212143352_fix_indexes_on_table_students.js @@ -3,7 +3,7 @@ const USERID_COLUMN = 'userId'; const ORGANIZATIONID_COLUMN = 'organizationId'; const NATIONALSTUDENTID_COLUMN = 'nationalStudentId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(NATIONALSTUDENTID_COLUMN); table.dropIndex(ORGANIZATIONID_COLUMN); @@ -13,7 +13,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(NATIONALSTUDENTID_COLUMN); table.index(ORGANIZATIONID_COLUMN); @@ -22,3 +22,5 @@ exports.down = function (knex) { table.dropUnique([ORGANIZATIONID_COLUMN, NATIONALSTUDENTID_COLUMN]); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200214151519_rename_session_status_started_to_created.js b/api/db/migrations/20200214151519_rename_session_status_started_to_created.js index 615eff783d0..2ff89cab0d1 100644 --- a/api/db/migrations/20200214151519_rename_session_status_started_to_created.js +++ b/api/db/migrations/20200214151519_rename_session_status_started_to_created.js @@ -2,10 +2,12 @@ const TABLE_NAME = 'sessions'; const OLD_STATUS = 'started'; const NEW_STATUS = 'created'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).where('status', '=', OLD_STATUS).update({ status: NEW_STATUS }); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).where('status', '=', NEW_STATUS).update({ status: OLD_STATUS }); }; + +export { up, down }; diff --git a/api/db/migrations/20200217171312_create_badges_table.js b/api/db/migrations/20200217171312_create_badges_table.js index 9492f367fa2..0ebbbbbc8b4 100644 --- a/api/db/migrations/20200217171312_create_badges_table.js +++ b/api/db/migrations/20200217171312_create_badges_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'badges'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (table) => { table.increments('id').primary(); table.string('altMessage').notNullable(); @@ -10,6 +10,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200218114201_add_sendToPrescriber_column_in_session_table.js b/api/db/migrations/20200218114201_add_sendToPrescriber_column_in_session_table.js index ff0ddc92ccb..7ebb3717001 100644 --- a/api/db/migrations/20200218114201_add_sendToPrescriber_column_in_session_table.js +++ b/api/db/migrations/20200218114201_add_sendToPrescriber_column_in_session_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME = 'resultsSentToPrescriberAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200220145135_create_user_orga_settings.js b/api/db/migrations/20200220145135_create_user_orga_settings.js index 4e2e2e2b657..cc7ba07da5d 100644 --- a/api/db/migrations/20200220145135_create_user_orga_settings.js +++ b/api/db/migrations/20200220145135_create_user_orga_settings.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'user-orga-settings'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments('id').primary(); t.bigInteger('userId').references('users.id').index(); @@ -9,6 +9,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200220145419_migrate_first_organization_join_to_user_orga_settings.js b/api/db/migrations/20200220145419_migrate_first_organization_join_to_user_orga_settings.js index 058f97b1b05..33e7f359276 100644 --- a/api/db/migrations/20200220145419_migrate_first_organization_join_to_user_orga_settings.js +++ b/api/db/migrations/20200220145419_migrate_first_organization_join_to_user_orga_settings.js @@ -1,9 +1,9 @@ -const { batch } = require('../batch-processing'); +import { batch } from '../batch-processing.js'; const TABLE_NAME_USER_ORGA_SETTINGS = 'user-orga-settings'; const TABLE_NAME_MEMBERSHIPS = 'memberships'; -exports.up = function (knex) { +const up = function (knex) { const subQuery = knex(TABLE_NAME_MEMBERSHIPS).min('id').groupBy('userId'); return knex(TABLE_NAME_MEMBERSHIPS) @@ -19,7 +19,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { const subQuery = knex(TABLE_NAME_MEMBERSHIPS).min('id').groupBy('userId'); return knex(TABLE_NAME_MEMBERSHIPS) @@ -34,3 +34,5 @@ exports.down = function (knex) { }); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200225130232_remove-user-id-in-organizations.js b/api/db/migrations/20200225130232_remove-user-id-in-organizations.js index fb54a5f5695..10922938aba 100644 --- a/api/db/migrations/20200225130232_remove-user-id-in-organizations.js +++ b/api/db/migrations/20200225130232_remove-user-id-in-organizations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'userId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer(COLUMN_NAME).unsigned(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200225133240_remove-code-on-organizations.js b/api/db/migrations/20200225133240_remove-code-on-organizations.js index 8c42449d561..592319b8e12 100644 --- a/api/db/migrations/20200225133240_remove-code-on-organizations.js +++ b/api/db/migrations/20200225133240_remove-code-on-organizations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'code'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME, 6).default('').notNullable(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200225142247_add_column_certification-course-id_to_table_assessments.js b/api/db/migrations/20200225142247_add_column_certification-course-id_to_table_assessments.js index 3220f1f04fb..2148eac72b5 100644 --- a/api/db/migrations/20200225142247_add_column_certification-course-id_to_table_assessments.js +++ b/api/db/migrations/20200225142247_add_column_certification-course-id_to_table_assessments.js @@ -2,7 +2,7 @@ const TABLE_NAME = 'assessments'; const COLUMN_NAME = 'certificationCourseId'; const REFERENCE = 'certification-courses.id'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).unsigned().references(REFERENCE).index(); }); @@ -27,8 +27,10 @@ exports.up = async function (knex) { ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200302104707_create_badge_acquisitions.js b/api/db/migrations/20200302104707_create_badge_acquisitions.js index 14480702fc2..2e3db50ef23 100644 --- a/api/db/migrations/20200302104707_create_badge_acquisitions.js +++ b/api/db/migrations/20200302104707_create_badge_acquisitions.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'badge-acquisitions'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (table) => { table.increments('id').primary(); table.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); @@ -9,6 +9,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200303140224_add_columns_createdAt_and_updatedAt_to_user_orga_settings.js b/api/db/migrations/20200303140224_add_columns_createdAt_and_updatedAt_to_user_orga_settings.js index 2b2d11bbeb6..40bca5bb810 100644 --- a/api/db/migrations/20200303140224_add_columns_createdAt_and_updatedAt_to_user_orga_settings.js +++ b/api/db/migrations/20200303140224_add_columns_createdAt_and_updatedAt_to_user_orga_settings.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'user-orga-settings'; const CREATED_AT_COLUMN = 'createdAt'; const UPDATED_AT_COLUMN = 'updatedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(CREATED_AT_COLUMN).notNullable().defaultTo(knex.fn.now()); table.dateTime(UPDATED_AT_COLUMN).notNullable().defaultTo(knex.fn.now()); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(UPDATED_AT_COLUMN); table.dropColumn(CREATED_AT_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200303153018_add-credit-column-to-organization.js b/api/db/migrations/20200303153018_add-credit-column-to-organization.js index c407c16345d..1f691ef28a1 100644 --- a/api/db/migrations/20200303153018_add-credit-column-to-organization.js +++ b/api/db/migrations/20200303153018_add-credit-column-to-organization.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'credit'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).defaultTo(0); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200306143100_delete-snapshots-table.js b/api/db/migrations/20200306143100_delete-snapshots-table.js index f52bf469452..fd0acadb182 100644 --- a/api/db/migrations/20200306143100_delete-snapshots-table.js +++ b/api/db/migrations/20200306143100_delete-snapshots-table.js @@ -1,10 +1,10 @@ const TABLE_NAME = 'snapshots'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('studentCode'); @@ -18,3 +18,5 @@ exports.down = function (knex) { t.dateTime('updatedAt').notNullable().defaultTo(knex.fn.now()); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200317112058_add_unique_constraint_on_userid_certificationcourseid_table_assessments.js b/api/db/migrations/20200317112058_add_unique_constraint_on_userid_certificationcourseid_table_assessments.js index eac4f45d005..eabf9671cbe 100644 --- a/api/db/migrations/20200317112058_add_unique_constraint_on_userid_certificationcourseid_table_assessments.js +++ b/api/db/migrations/20200317112058_add_unique_constraint_on_userid_certificationcourseid_table_assessments.js @@ -2,7 +2,7 @@ const TABLE_NAME = 'assessments'; const COLUMN_USER_ID = 'userId'; const COLUMN_CERTIFICATION_COURSE_ID = 'certificationCourseId'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.raw(` WITH ASSESSMENTS_BY_CERTIFICATION_COURSES AS ( SELECT "as"."id" as assessment_id, @@ -24,8 +24,10 @@ exports.up = async (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique([COLUMN_USER_ID, COLUMN_CERTIFICATION_COURSE_ID]); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200317151424_create-badge-partner-competences.js b/api/db/migrations/20200317151424_create-badge-partner-competences.js index e46584da0bd..ccf8b9f2992 100644 --- a/api/db/migrations/20200317151424_create-badge-partner-competences.js +++ b/api/db/migrations/20200317151424_create-badge-partner-competences.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'badge-partner-competences'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (table) => { table.increments('id').primary(); table.string('name').notNullable(); @@ -10,6 +10,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200320144239_rename_table_students_to_schooling-registrations.js b/api/db/migrations/20200320144239_rename_table_students_to_schooling-registrations.js index 88317d27f3d..2725e50f79a 100644 --- a/api/db/migrations/20200320144239_rename_table_students_to_schooling-registrations.js +++ b/api/db/migrations/20200320144239_rename_table_students_to_schooling-registrations.js @@ -1,10 +1,12 @@ const OLD_TABLE_NAME = 'students'; const NEW_TABLE_NAME = 'schooling-registrations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.renameTable(OLD_TABLE_NAME, NEW_TABLE_NAME); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.renameTable(NEW_TABLE_NAME, OLD_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200320163042_add_functional_key_on_badges_table.js b/api/db/migrations/20200320163042_add_functional_key_on_badges_table.js index a46d46435c1..78ba17c72ee 100644 --- a/api/db/migrations/20200320163042_add_functional_key_on_badges_table.js +++ b/api/db/migrations/20200320163042_add_functional_key_on_badges_table.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'badges'; const COLUMN_KEY = 'key'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.alterTable(TABLE_NAME, function (table) { table.text(COLUMN_KEY); }); @@ -11,8 +11,10 @@ exports.up = async (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_KEY); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200320170707_add-type-to-campaign.js b/api/db/migrations/20200320170707_add-type-to-campaign.js index 8278754db50..5c635e35791 100644 --- a/api/db/migrations/20200320170707_add-type-to-campaign.js +++ b/api/db/migrations/20200320170707_add-type-to-campaign.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'campaigns'; const COLUMN_NAME = 'type'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema .table(TABLE_NAME, function (table) { table.string(COLUMN_NAME).notNullable().defaultTo(''); @@ -13,8 +13,10 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200320171110_add_column_shouldChangePassword_to_table_users.js b/api/db/migrations/20200320171110_add_column_shouldChangePassword_to_table_users.js index 2752bedeff9..09ab2d134e8 100644 --- a/api/db/migrations/20200320171110_add_column_shouldChangePassword_to_table_users.js +++ b/api/db/migrations/20200320171110_add_column_shouldChangePassword_to_table_users.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'users'; const SHOULD_CHANGE_PASSWORD_COLUMN = 'shouldChangePassword'; const DEFAULT_VALUE = false; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(SHOULD_CHANGE_PASSWORD_COLUMN).notNullable().defaultTo(DEFAULT_VALUE); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(SHOULD_CHANGE_PASSWORD_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200324101353_add-can-collect-profiles-to-organization.js b/api/db/migrations/20200324101353_add-can-collect-profiles-to-organization.js index 30564875a4e..426ee1f7cad 100644 --- a/api/db/migrations/20200324101353_add-can-collect-profiles-to-organization.js +++ b/api/db/migrations/20200324101353_add-can-collect-profiles-to-organization.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'canCollectProfiles'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200324161149_create-user-tutorials.js b/api/db/migrations/20200324161149_create-user-tutorials.js index b9b9e3c46ef..1d8d1bd1967 100644 --- a/api/db/migrations/20200324161149_create-user-tutorials.js +++ b/api/db/migrations/20200324161149_create-user-tutorials.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'user_tutorials'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments('id').primary(); t.bigInteger('userId').index(); @@ -11,6 +11,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200326163043_add-published-at-column-to-table-sessions.js b/api/db/migrations/20200326163043_add-published-at-column-to-table-sessions.js index bdaea4f5881..02ecdbb53f2 100644 --- a/api/db/migrations/20200326163043_add-published-at-column-to-table-sessions.js +++ b/api/db/migrations/20200326163043_add-published-at-column-to-table-sessions.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME = 'publishedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200327084158_drop_column_status_table_sessions.js b/api/db/migrations/20200327084158_drop_column_status_table_sessions.js index 0c107b95287..2c6699f2631 100644 --- a/api/db/migrations/20200327084158_drop_column_status_table_sessions.js +++ b/api/db/migrations/20200327084158_drop_column_status_table_sessions.js @@ -1,16 +1,18 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME = 'status'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME).defaultTo('created'); }); await knex.raw('UPDATE "sessions" SET "status" = \'finalized\' WHERE "sessions"."finalizedAt" IS NOT NULL'); return knex.raw('UPDATE "sessions" SET "status" = \'processed\' WHERE "sessions"."publishedAt" IS NOT NULL'); }; + +export { up, down }; diff --git a/api/db/migrations/20200327110821_save_acquired_partner_certification_key_on_certif_course_table.js b/api/db/migrations/20200327110821_save_acquired_partner_certification_key_on_certif_course_table.js index 89fd36951ff..d603a574da7 100644 --- a/api/db/migrations/20200327110821_save_acquired_partner_certification_key_on_certif_course_table.js +++ b/api/db/migrations/20200327110821_save_acquired_partner_certification_key_on_certif_course_table.js @@ -1,12 +1,14 @@ const TABLE_NAME = 'certification-partner-acquisitions'; -exports.up = async (knex) => { +const up = async function (knex) { return knex.schema.createTable(TABLE_NAME, (table) => { table.integer('certificationCourseId').references('certification-courses.id').notNullable().index(); table.string('partnerKey').references('badges.key').notNullable(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200327225551_add-column-assignedCertificationOfficerId-column-table-sessions.js b/api/db/migrations/20200327225551_add-column-assignedCertificationOfficerId-column-table-sessions.js index 72eb5582611..23416c820da 100644 --- a/api/db/migrations/20200327225551_add-column-assignedCertificationOfficerId-column-table-sessions.js +++ b/api/db/migrations/20200327225551_add-column-assignedCertificationOfficerId-column-table-sessions.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME = 'assignedCertificationOfficerId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).references('users.id'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200331131815_replace-campaign-type-TEST_GIVEN-by-ASSESSMENT.js b/api/db/migrations/20200331131815_replace-campaign-type-TEST_GIVEN-by-ASSESSMENT.js index 724efdbeeb3..09c2d2194e7 100644 --- a/api/db/migrations/20200331131815_replace-campaign-type-TEST_GIVEN-by-ASSESSMENT.js +++ b/api/db/migrations/20200331131815_replace-campaign-type-TEST_GIVEN-by-ASSESSMENT.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaigns'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).where('type', '=', 'TEST_GIVEN').update({ type: 'ASSESSMENT', }); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).where('type', '=', 'ASSESSMENT').update({ type: 'TEST_GIVEN', }); }; + +export { up, down }; diff --git a/api/db/migrations/20200409104933_rename_associated-skill_into_associated-skill-name_table_certification-challenges.js b/api/db/migrations/20200409104933_rename_associated-skill_into_associated-skill-name_table_certification-challenges.js index 1247c61b66b..181fa714220 100644 --- a/api/db/migrations/20200409104933_rename_associated-skill_into_associated-skill-name_table_certification-challenges.js +++ b/api/db/migrations/20200409104933_rename_associated-skill_into_associated-skill-name_table_certification-challenges.js @@ -2,10 +2,12 @@ const TABLE_NAME = 'certification-challenges'; const OLD_COLUMN_NAME = 'associatedSkill'; const NEW_COLUMN_NAME = 'associatedSkillName'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(OLD_COLUMN_NAME, NEW_COLUMN_NAME)); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20200414164040_create_tutorial-evaluations-table.js b/api/db/migrations/20200414164040_create_tutorial-evaluations-table.js index 367ccab3649..ca95f577937 100644 --- a/api/db/migrations/20200414164040_create_tutorial-evaluations-table.js +++ b/api/db/migrations/20200414164040_create_tutorial-evaluations-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'tutorial-evaluations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments('id').primary(); t.bigInteger('userId').notNullable().index(); @@ -11,6 +11,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200420120328_add_mustValidateTermsOfService_to_users.js b/api/db/migrations/20200420120328_add_mustValidateTermsOfService_to_users.js index 1331ae39d97..e93242f69b0 100644 --- a/api/db/migrations/20200420120328_add_mustValidateTermsOfService_to_users.js +++ b/api/db/migrations/20200420120328_add_mustValidateTermsOfService_to_users.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'users'; const NEW_COLUMN = 'mustValidateTermsOfService'; const DEFAULT_VALUE = false; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(NEW_COLUMN).notNullable().defaultTo(DEFAULT_VALUE); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(NEW_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200503193240_add_lastTermsOfServiceValidatedAt_to_user.js b/api/db/migrations/20200503193240_add_lastTermsOfServiceValidatedAt_to_user.js index 785e209e1de..ecc8e0dbec5 100644 --- a/api/db/migrations/20200503193240_add_lastTermsOfServiceValidatedAt_to_user.js +++ b/api/db/migrations/20200503193240_add_lastTermsOfServiceValidatedAt_to_user.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'lastTermsOfServiceValidatedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200505174655_create_badge-criteria_table.js b/api/db/migrations/20200505174655_create_badge-criteria_table.js index 97047a1fec3..cc0c81b6990 100644 --- a/api/db/migrations/20200505174655_create_badge-criteria_table.js +++ b/api/db/migrations/20200505174655_create_badge-criteria_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'badge-criteria'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (table) => { table.increments('id').primary(); table.string('scope').notNullable(); @@ -9,6 +9,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200509110115_update-associated-skill-id-column-certification-challenges-table.js b/api/db/migrations/20200509110115_update-associated-skill-id-column-certification-challenges-table.js index 8937d66d5ba..cae5a8ab74c 100644 --- a/api/db/migrations/20200509110115_update-associated-skill-id-column-certification-challenges-table.js +++ b/api/db/migrations/20200509110115_update-associated-skill-id-column-certification-challenges-table.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); +import _ from 'lodash'; -exports.up = async function (knex) { +const up = async function (knex) { return knex.transaction(async (trx) => { const valuesTable = _.map(skills_at_2020_04_30, (skillId, skillName) => `('${skillId}', '${skillName}')`); const valuesString = _.join(valuesTable, ','); @@ -23,10 +23,12 @@ exports.up = async function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw('UPDATE ?? SET ?? = NULL', ['certification-challenges', 'associatedSkillId']); }; +export { up, down }; + // skillName -> md5() const skills_at_2020_04_30 = { '01f7ba2aff740a06e754b9f9dd9595e2': 'rec0J9OXaAj5v7w3r', diff --git a/api/db/migrations/20200515163806_add-column-createdat-updatedat-to-memberships.js b/api/db/migrations/20200515163806_add-column-createdat-updatedat-to-memberships.js index 7c1f632cf51..f00701ec52b 100644 --- a/api/db/migrations/20200515163806_add-column-createdat-updatedat-to-memberships.js +++ b/api/db/migrations/20200515163806_add-column-createdat-updatedat-to-memberships.js @@ -2,7 +2,7 @@ const TABLE_NAME = 'memberships'; const CREATED_AT_COLUMN = 'createdAt'; const UPDATED_AT_COLUMN = 'updatedAt'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.dateTime(CREATED_AT_COLUMN); table.dateTime(UPDATED_AT_COLUMN); @@ -13,9 +13,11 @@ exports.up = async function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(UPDATED_AT_COLUMN); table.dropColumn(CREATED_AT_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200518173853_insert_badge_criteria.js b/api/db/migrations/20200518173853_insert_badge_criteria.js index f0a95d6c463..c9bda070177 100644 --- a/api/db/migrations/20200518173853_insert_badge_criteria.js +++ b/api/db/migrations/20200518173853_insert_badge_criteria.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'badge-criteria'; -exports.up = async function (knex) { +const up = async function (knex) { const badgeClea = await knex('badges').select('id').where('key', 'PIX_EMPLOI_CLEA'); if (badgeClea.length > 0) { await knex(TABLE_NAME).insert({ scope: 'CampaignParticipation', threshold: 85, badgeId: badgeClea[0].id }); @@ -8,9 +8,11 @@ exports.up = async function (knex) { } }; -exports.down = async function (knex) { +const down = async function (knex) { const badgeClea = await knex('badges').select('id').where('key', 'PIX_EMPLOI_CLEA'); if (badgeClea.length > 0) { await knex(TABLE_NAME).where('badgeId', badgeClea[0].id).delete(); } }; + +export { up, down }; diff --git a/api/db/migrations/20200522090553_add-competenceId-column-competence-marks-table.js b/api/db/migrations/20200522090553_add-competenceId-column-competence-marks-table.js index 0a0074e12dc..b3c383cda6c 100644 --- a/api/db/migrations/20200522090553_add-competenceId-column-competence-marks-table.js +++ b/api/db/migrations/20200522090553_add-competenceId-column-competence-marks-table.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'competence-marks'; const COLUMN_NAME = 'competenceId'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); @@ -66,8 +66,10 @@ exports.up = async function (knex) { ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200528170928_add_certif_partner_acquisition_success_value.js b/api/db/migrations/20200528170928_add_certif_partner_acquisition_success_value.js index be6254f76b0..3a422a7b31b 100644 --- a/api/db/migrations/20200528170928_add_certif_partner_acquisition_success_value.js +++ b/api/db/migrations/20200528170928_add_certif_partner_acquisition_success_value.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'certification-partner-acquisitions'; const COLUMN_NAME = 'acquired'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME); }); @@ -13,8 +13,10 @@ exports.up = async function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200604161113_rename-certification-partner.js b/api/db/migrations/20200604161113_rename-certification-partner.js index b8d37f5f26c..75487276e94 100644 --- a/api/db/migrations/20200604161113_rename-certification-partner.js +++ b/api/db/migrations/20200604161113_rename-certification-partner.js @@ -1,10 +1,12 @@ const OLD_TABLE_NAME = 'certification-partner-acquisitions'; const TABLE_NAME = 'partner-certifications'; -exports.up = async function (knex) { +const up = async function (knex) { return knex.schema.renameTable(OLD_TABLE_NAME, TABLE_NAME); }; -exports.down = async function (knex) { +const down = async function (knex) { return knex.schema.renameTable(TABLE_NAME, OLD_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200608170256_alter_table_badgePartnerCompetences_column_color_from_notNullable_to_nullable.js b/api/db/migrations/20200608170256_alter_table_badgePartnerCompetences_column_color_from_notNullable_to_nullable.js index 49dbb5d6b6e..d80fc9f4f08 100644 --- a/api/db/migrations/20200608170256_alter_table_badgePartnerCompetences_column_color_from_notNullable_to_nullable.js +++ b/api/db/migrations/20200608170256_alter_table_badgePartnerCompetences_column_color_from_notNullable_to_nullable.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'badge-partner-competences'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.string('color').nullable().alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.string('color').notNullable().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200610153738_update-type-smart-placement-for-campaign.js b/api/db/migrations/20200610153738_update-type-smart-placement-for-campaign.js index b453fab79cc..8cc98228c33 100644 --- a/api/db/migrations/20200610153738_update-type-smart-placement-for-campaign.js +++ b/api/db/migrations/20200610153738_update-type-smart-placement-for-campaign.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'assessments'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME) .where('type', 'SMART_PLACEMENT') .update({ type: 'CAMPAIGN', courseId: '[NOT USED] Campaign Assessment CourseId Not Used' }); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME) .where('type', 'CAMPAIGN') .update({ type: 'SMART_PLACEMENT', courseId: 'Smart Placement Tests CourseId Not Used' }); }; + +export { up, down }; diff --git a/api/db/migrations/20200612093847_add-column-disabledAt-to-memberships.js b/api/db/migrations/20200612093847_add-column-disabledAt-to-memberships.js index 78f196e2675..ce8dd45c9b6 100644 --- a/api/db/migrations/20200612093847_add-column-disabledAt-to-memberships.js +++ b/api/db/migrations/20200612093847_add-column-disabledAt-to-memberships.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'memberships'; const DISABLED_AT_COLUMN = 'disabledAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(DISABLED_AT_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(DISABLED_AT_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200617111042_add-column-title-to-badges.js b/api/db/migrations/20200617111042_add-column-title-to-badges.js index 87bb227fa63..8232f33ce0e 100644 --- a/api/db/migrations/20200617111042_add-column-title-to-badges.js +++ b/api/db/migrations/20200617111042_add-column-title-to-badges.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'badges'; const TITLE_COLUMN = 'title'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(TITLE_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(TITLE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200623155650_add_updatedByUser_to_memberships.js b/api/db/migrations/20200623155650_add_updatedByUser_to_memberships.js index 559b4481efa..66b02c9f4f2 100644 --- a/api/db/migrations/20200623155650_add_updatedByUser_to_memberships.js +++ b/api/db/migrations/20200623155650_add_updatedByUser_to_memberships.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'memberships'; const COLUMN_NAME = 'updatedByUserId'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).unsigned().references('users.id'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200625113402_add-column-email-to-organizations.js b/api/db/migrations/20200625113402_add-column-email-to-organizations.js index 1b4ee09c808..7705306f88f 100644 --- a/api/db/migrations/20200625113402_add-column-email-to-organizations.js +++ b/api/db/migrations/20200625113402_add-column-email-to-organizations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'email'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200702114943_add_check_on_memberships_role.js b/api/db/migrations/20200702114943_add_check_on_memberships_role.js index 1313c824124..3ef3d3e8675 100644 --- a/api/db/migrations/20200702114943_add_check_on_memberships_role.js +++ b/api/db/migrations/20200702114943_add_check_on_memberships_role.js @@ -1,12 +1,11 @@ -// Switching to raw SQL, because knex can't add CHECK constraint on existing column -// https://github.com/knex/knex/issues/1699 - -exports.up = function (knex) { +const up = function (knex) { return knex.raw( 'ALTER TABLE memberships ADD CONSTRAINT "memberships_organizationRole_check" CHECK ( "organizationRole" IN (\'ADMIN\', \'MEMBER\' ) )' ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw('ALTER TABLE memberships DROP CONSTRAINT "memberships_organizationRole_check" '); }; + +export { up, down }; diff --git a/api/db/migrations/20200702135519_add-sup-columns-to-schooling-registrations.js b/api/db/migrations/20200702135519_add-sup-columns-to-schooling-registrations.js index 99b9be38235..72eae5589f8 100644 --- a/api/db/migrations/20200702135519_add-sup-columns-to-schooling-registrations.js +++ b/api/db/migrations/20200702135519_add-sup-columns-to-schooling-registrations.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'schooling-registrations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('email'); table.string('studentNumber'); @@ -11,7 +11,7 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('email'); table.dropColumn('studentNumber'); @@ -21,3 +21,5 @@ exports.down = function (knex) { table.dropColumn('diploma'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200706144840_add_role_to_organization_invitation.js b/api/db/migrations/20200706144840_add_role_to_organization_invitation.js index 41ea271b1e8..62be0dcc3a8 100644 --- a/api/db/migrations/20200706144840_add_role_to_organization_invitation.js +++ b/api/db/migrations/20200706144840_add_role_to_organization_invitation.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organization-invitations'; const COLUMN_NAME = 'role'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.enu(COLUMN_NAME, ['MEMBER', 'ADMIN']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200718085730_create-table-knowledge-element-snapshots.js b/api/db/migrations/20200718085730_create-table-knowledge-element-snapshots.js index afb52240864..7e42f0eb907 100644 --- a/api/db/migrations/20200718085730_create-table-knowledge-element-snapshots.js +++ b/api/db/migrations/20200718085730_create-table-knowledge-element-snapshots.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'knowledge-element-snapshots'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (table) => { table.increments('id').primary(); table.integer('userId').notNullable(); @@ -10,6 +10,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200721180935_add_nationalStudentId_index_to_schooling-registrations_table.js b/api/db/migrations/20200721180935_add_nationalStudentId_index_to_schooling-registrations_table.js index 0c5431c1559..70b64e348cf 100644 --- a/api/db/migrations/20200721180935_add_nationalStudentId_index_to_schooling-registrations_table.js +++ b/api/db/migrations/20200721180935_add_nationalStudentId_index_to_schooling-registrations_table.js @@ -1,9 +1,11 @@ -exports.up = (knex) => { +const up = function (knex) { return knex.raw( 'CREATE INDEX "schooling-registrations_nationalstudentid_index" ON "schooling-registrations" ("nationalStudentId");' ); }; -exports.down = (knex) => { +const down = function (knex) { return knex.raw('DROP INDEX "schooling-registrations_nationalstudentid_index";'); }; + +export { up, down }; diff --git a/api/db/migrations/20200722120645_add-uniqu-constraint-for-schooling-registrations-on-student-number-and-organization-id.js b/api/db/migrations/20200722120645_add-uniqu-constraint-for-schooling-registrations-on-student-number-and-organization-id.js index cf84521d018..a00d251b4af 100644 --- a/api/db/migrations/20200722120645_add-uniqu-constraint-for-schooling-registrations-on-student-number-and-organization-id.js +++ b/api/db/migrations/20200722120645_add-uniqu-constraint-for-schooling-registrations-on-student-number-and-organization-id.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'schooling-registrations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.unique(['studentNumber', 'organizationId']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['studentNumber', 'organizationId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200724115030_replace-knowledge-element-snapshots-index-by-unique-index-on-userId-and-snappedAt.js b/api/db/migrations/20200724115030_replace-knowledge-element-snapshots-index-by-unique-index-on-userId-and-snappedAt.js index b27cd7d8338..2b8f2ee955d 100644 --- a/api/db/migrations/20200724115030_replace-knowledge-element-snapshots-index-by-unique-index-on-userId-and-snappedAt.js +++ b/api/db/migrations/20200724115030_replace-knowledge-element-snapshots-index-by-unique-index-on-userId-and-snappedAt.js @@ -1,15 +1,17 @@ const TABLE_NAME = 'knowledge-element-snapshots'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex('userId'); table.unique(['userId', 'snappedAt']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index('userId'); table.dropUnique(['userId', 'snappedAt']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200731170630_add-certificationCourse-verifyCode-column.js b/api/db/migrations/20200731170630_add-certificationCourse-verifyCode-column.js index dd40ba2cbde..8736dbceb06 100644 --- a/api/db/migrations/20200731170630_add-certificationCourse-verifyCode-column.js +++ b/api/db/migrations/20200731170630_add-certificationCourse-verifyCode-column.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'certification-courses'; const COLUMN_NAME = 'verificationCode'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); @@ -11,9 +11,11 @@ exports.up = async function (knex) { ]); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('DROP INDEX index_certification_courses_upper_verification_code'); await knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200803144114_create-stages-table.js b/api/db/migrations/20200803144114_create-stages-table.js index e9c99746e7e..c06d365d13f 100644 --- a/api/db/migrations/20200803144114_create-stages-table.js +++ b/api/db/migrations/20200803144114_create-stages-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'stages'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments('id').primary(); t.integer('targetProfileId').notNullable().references('target-profiles.id').index(); @@ -12,6 +12,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20200813154124_add-column-imageUrl-to-target-profiles.js b/api/db/migrations/20200813154124_add-column-imageUrl-to-target-profiles.js index 43a0c09a439..41c561c4f40 100644 --- a/api/db/migrations/20200813154124_add-column-imageUrl-to-target-profiles.js +++ b/api/db/migrations/20200813154124_add-column-imageUrl-to-target-profiles.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'target-profiles'; const COLUMN_NAME = 'imageUrl'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME).defaultTo(null); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814135754_drop-redundant-index-table-tutorial-evaluations-on-column-user-id.js b/api/db/migrations/20200814135754_drop-redundant-index-table-tutorial-evaluations-on-column-user-id.js index 8d37e3bdbf1..d68c063c63e 100644 --- a/api/db/migrations/20200814135754_drop-redundant-index-table-tutorial-evaluations-on-column-user-id.js +++ b/api/db/migrations/20200814135754_drop-redundant-index-table-tutorial-evaluations-on-column-user-id.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'tutorial-evaluations'; const USERID_COLUMN = 'userId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(USERID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(USERID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814140251_drop-not-need-index-table-tutorial-evaluations-on-column-tutorial-id.js b/api/db/migrations/20200814140251_drop-not-need-index-table-tutorial-evaluations-on-column-tutorial-id.js index 892312918ee..1b45ff833f3 100644 --- a/api/db/migrations/20200814140251_drop-not-need-index-table-tutorial-evaluations-on-column-tutorial-id.js +++ b/api/db/migrations/20200814140251_drop-not-need-index-table-tutorial-evaluations-on-column-tutorial-id.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'tutorial-evaluations'; const TUTORIALID_COLUMN = 'tutorialId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(TUTORIALID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(TUTORIALID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814141138_drop-unused-index-on-user-id-table-certification-candidates.js b/api/db/migrations/20200814141138_drop-unused-index-on-user-id-table-certification-candidates.js index 88cbfd2cae6..7f9837f9272 100644 --- a/api/db/migrations/20200814141138_drop-unused-index-on-user-id-table-certification-candidates.js +++ b/api/db/migrations/20200814141138_drop-unused-index-on-user-id-table-certification-candidates.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-candidates'; const USERID_COLUMN = 'userId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(USERID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(USERID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814142127_drop-unused-index-on-course-id-table-assessments.js b/api/db/migrations/20200814142127_drop-unused-index-on-course-id-table-assessments.js index f03f36c6382..89667c2dd4b 100644 --- a/api/db/migrations/20200814142127_drop-unused-index-on-course-id-table-assessments.js +++ b/api/db/migrations/20200814142127_drop-unused-index-on-course-id-table-assessments.js @@ -1,7 +1,9 @@ -exports.up = (knex) => { +const up = function (knex) { return knex.raw('DROP INDEX IF EXISTS "assessment_courseid_index";'); }; -exports.down = (knex) => { +const down = function (knex) { return knex.raw('CREATE INDEX "assessment_courseid_index" ON assessments ("courseId");'); }; + +export { up, down }; diff --git a/api/db/migrations/20200814142831_drop-redundant-index-table-user-tutorials-on-column-user-id.js b/api/db/migrations/20200814142831_drop-redundant-index-table-user-tutorials-on-column-user-id.js index dfa3a2ae773..d7b3ea874a4 100644 --- a/api/db/migrations/20200814142831_drop-redundant-index-table-user-tutorials-on-column-user-id.js +++ b/api/db/migrations/20200814142831_drop-redundant-index-table-user-tutorials-on-column-user-id.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'user_tutorials'; const USERID_COLUMN = 'userId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(USERID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(USERID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814142948_drop-not-needed-index-table-user-tutorials-on-column-tutorial-id.js b/api/db/migrations/20200814142948_drop-not-needed-index-table-user-tutorials-on-column-tutorial-id.js index ac7973accdc..d9236c56851 100644 --- a/api/db/migrations/20200814142948_drop-not-needed-index-table-user-tutorials-on-column-tutorial-id.js +++ b/api/db/migrations/20200814142948_drop-not-needed-index-table-user-tutorials-on-column-tutorial-id.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'user_tutorials'; const TUTORIALID_COLUMN = 'tutorialId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(TUTORIALID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(TUTORIALID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814144054_drop-not-needed-index-table-feedbacks-on-column-assessment-id.js b/api/db/migrations/20200814144054_drop-not-needed-index-table-feedbacks-on-column-assessment-id.js index ee6373068cb..40c56b913ae 100644 --- a/api/db/migrations/20200814144054_drop-not-needed-index-table-feedbacks-on-column-assessment-id.js +++ b/api/db/migrations/20200814144054_drop-not-needed-index-table-feedbacks-on-column-assessment-id.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'feedbacks'; const ASSESSMENTID_COLUMN = 'assessmentId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(ASSESSMENTID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(ASSESSMENTID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814144606_drop-not-needed-index-table-assessments-on-column-type.js b/api/db/migrations/20200814144606_drop-not-needed-index-table-assessments-on-column-type.js index 3abc5741322..06e59c6be35 100644 --- a/api/db/migrations/20200814144606_drop-not-needed-index-table-assessments-on-column-type.js +++ b/api/db/migrations/20200814144606_drop-not-needed-index-table-assessments-on-column-type.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'assessments'; const TYPE_COLUMN = 'type'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(TYPE_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(TYPE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814144712_drop-not-needed-index-table-assessments-on-column-state.js b/api/db/migrations/20200814144712_drop-not-needed-index-table-assessments-on-column-state.js index b6365886a7f..6e335d0ebc9 100644 --- a/api/db/migrations/20200814144712_drop-not-needed-index-table-assessments-on-column-state.js +++ b/api/db/migrations/20200814144712_drop-not-needed-index-table-assessments-on-column-state.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'assessments'; const TYPE_COLUMN = 'state'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(TYPE_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(TYPE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814144752_drop-not-needed-index-table-assessments-on-column-competence-id.js b/api/db/migrations/20200814144752_drop-not-needed-index-table-assessments-on-column-competence-id.js index 7787c7065e7..f1e5780fca5 100644 --- a/api/db/migrations/20200814144752_drop-not-needed-index-table-assessments-on-column-competence-id.js +++ b/api/db/migrations/20200814144752_drop-not-needed-index-table-assessments-on-column-competence-id.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'assessments'; const COMPETENCEID_COLUMN = 'competenceId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(COMPETENCEID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(COMPETENCEID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814160658_add-column-additional-to-schooling-registration.js b/api/db/migrations/20200814160658_add-column-additional-to-schooling-registration.js index 7aa7435e0d7..425e6a449f9 100644 --- a/api/db/migrations/20200814160658_add-column-additional-to-schooling-registration.js +++ b/api/db/migrations/20200814160658_add-column-additional-to-schooling-registration.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'schooling-registrations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean('isSupernumerary'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('isSupernumerary'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200814175528_add_notnull-constraint-to-schooling-registration-organization-id.js b/api/db/migrations/20200814175528_add_notnull-constraint-to-schooling-registration-organization-id.js index d1f5ed6bb27..81f76ac141a 100644 --- a/api/db/migrations/20200814175528_add_notnull-constraint-to-schooling-registration-organization-id.js +++ b/api/db/migrations/20200814175528_add_notnull-constraint-to-schooling-registration-organization-id.js @@ -1,17 +1,9 @@ -// Switching to raw SQL, because knex can't NOT NULL constraint on existing column -// exports.up = function(knex) { -// return knex.schema -// .alterTable(TABLE_NAME, (table) => { -// table.string(COLUMN_NAME).notNullable().alter(); -// }); -// }; -// migration failed with error: alter table "schooling-registrations" alter column "organizationId" type varchar(255) using ("organizationId"::varchar(255)) - -// foreign key constraint "students_organizationid_foreign" cannot be implemented - -exports.up = function (knex) { +const up = function (knex) { return knex.raw('ALTER TABLE "schooling-registrations" ALTER COLUMN "organizationId" SET NOT NULL;'); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw('ALTER TABLE "schooling-registrations" ALTER COLUMN "organizationId" DROP NOT NULL;'); }; + +export { up, down }; diff --git a/api/db/migrations/20200919165145_alter-table-campaigns-set-column-organizationId-not-nullable.js b/api/db/migrations/20200919165145_alter-table-campaigns-set-column-organizationId-not-nullable.js index c1b6e238009..9a8204929b6 100644 --- a/api/db/migrations/20200919165145_alter-table-campaigns-set-column-organizationId-not-nullable.js +++ b/api/db/migrations/20200919165145_alter-table-campaigns-set-column-organizationId-not-nullable.js @@ -1,10 +1,12 @@ const TABLE = 'campaigns'; const ORGANIZATION_ID_COLUMN = 'organizationId'; -exports.up = function (knex) { +const up = function (knex) { return knex.raw('ALTER TABLE ?? ALTER COLUMN ?? SET NOT NULL', [TABLE, ORGANIZATION_ID_COLUMN]); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw('ALTER TABLE ?? ALTER COLUMN ?? DROP NOT NULL', [TABLE, ORGANIZATION_ID_COLUMN]); }; + +export { up, down }; diff --git a/api/db/migrations/20200921174050_add-unique-constraint-for-schooling-registrations-on-student-number-and-organization-id-and-not-supernumerary.js b/api/db/migrations/20200921174050_add-unique-constraint-for-schooling-registrations-on-student-number-and-organization-id-and-not-supernumerary.js index 9bb01077ad8..7bfcf4958d6 100644 --- a/api/db/migrations/20200921174050_add-unique-constraint-for-schooling-registrations-on-student-number-and-organization-id-and-not-supernumerary.js +++ b/api/db/migrations/20200921174050_add-unique-constraint-for-schooling-registrations-on-student-number-and-organization-id-and-not-supernumerary.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'schooling-registrations'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw( 'CREATE INDEX "organizationid_studentnumber_index" ON "schooling-registrations" ("organizationId", "studentNumber");' ); @@ -10,7 +10,7 @@ exports.up = async function (knex) { return knex.schema.table(TABLE_NAME, (table) => table.dropUnique(['studentNumber', 'organizationId'])); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => table.unique(['studentNumber', 'organizationId'])); await knex.raw( 'DROP INDEX "organizationid_studentnumber_index" ON "schooling-registrations" ("organizationId", "studentNumber");' @@ -19,3 +19,5 @@ exports.down = async function (knex) { 'DROP UNIQUE INDEX "organizationid_studentnumber_notsupernumerary_index" ON "schooling-registrations" ("organizationId", "studentNumber") WHERE "isSupernumerary" IS FALSE;' ); }; + +export { up, down }; diff --git a/api/db/migrations/20200928163952_add-result-recipient-email-column-certification-candidates.js b/api/db/migrations/20200928163952_add-result-recipient-email-column-certification-candidates.js index e1500ce08ac..cc959c57549 100644 --- a/api/db/migrations/20200928163952_add-result-recipient-email-column-certification-candidates.js +++ b/api/db/migrations/20200928163952_add-result-recipient-email-column-certification-candidates.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-candidates'; const RESULT_RECIPIENT_EMAIL = 'resultRecipientEmail'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(RESULT_RECIPIENT_EMAIL, 500); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(RESULT_RECIPIENT_EMAIL); }); }; + +export { up, down }; diff --git a/api/db/migrations/20200929142112_update-constraint-memberships_userid_organizationid_unique.js b/api/db/migrations/20200929142112_update-constraint-memberships_userid_organizationid_unique.js index 71eff7c7d96..ee6410141c3 100644 --- a/api/db/migrations/20200929142112_update-constraint-memberships_userid_organizationid_unique.js +++ b/api/db/migrations/20200929142112_update-constraint-memberships_userid_organizationid_unique.js @@ -4,7 +4,7 @@ const ORGANIZATIONID_COLUMN = 'organizationId'; const DISABLEDAT_COLUMN = 'disabledAt'; const NEW_CONSTRAINT_NAME = 'memberships_userid_organizationid_disabledAt_unique'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropUnique([USERID_COLUMN, ORGANIZATIONID_COLUMN]); }); @@ -14,9 +14,11 @@ exports.up = async function (knex) { ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropUnique(null, NEW_CONSTRAINT_NAME); table.unique([USERID_COLUMN, ORGANIZATIONID_COLUMN]); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201001165441_create-help-external-id-in-campaigns.js b/api/db/migrations/20201001165441_create-help-external-id-in-campaigns.js index d9ccfc52591..fa2c58b1ba9 100644 --- a/api/db/migrations/20201001165441_create-help-external-id-in-campaigns.js +++ b/api/db/migrations/20201001165441_create-help-external-id-in-campaigns.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaigns'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text('externalIdHelpImageUrl'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('externalIdHelpImageUrl'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201006140921_create_organization_tags.js b/api/db/migrations/20201006140921_create_organization_tags.js index 867a3eacb2e..955122a1b69 100644 --- a/api/db/migrations/20201006140921_create_organization_tags.js +++ b/api/db/migrations/20201006140921_create_organization_tags.js @@ -1,7 +1,7 @@ const TAGS_TABLE_NAME = 'tags'; const ORGANIZATION_TAGS_TABLE_NAME = 'organization-tags'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.createTable(TAGS_TABLE_NAME, (t) => { t.increments().primary(); t.string('name').notNullable().unique(); @@ -19,7 +19,9 @@ exports.up = async (knex) => { }); }; -exports.down = async (knex) => { +const down = async function (knex) { await knex.schema.dropTable(ORGANIZATION_TAGS_TABLE_NAME); return knex.schema.dropTable(TAGS_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20201013093514_create-alternative-text-to-external-id-help-image.js b/api/db/migrations/20201013093514_create-alternative-text-to-external-id-help-image.js index f151ab77194..beb69418434 100644 --- a/api/db/migrations/20201013093514_create-alternative-text-to-external-id-help-image.js +++ b/api/db/migrations/20201013093514_create-alternative-text-to-external-id-help-image.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaigns'; const TITLE_COLUMN = 'alternativeTextToExternalIdHelpImage'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text(TITLE_COLUMN); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(TITLE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201026162616_add-schooling-registration-id-column-to-certification-candidate-table.js b/api/db/migrations/20201026162616_add-schooling-registration-id-column-to-certification-candidate-table.js index a639d0309f7..d4a995ef122 100644 --- a/api/db/migrations/20201026162616_add-schooling-registration-id-column-to-certification-candidate-table.js +++ b/api/db/migrations/20201026162616_add-schooling-registration-id-column-to-certification-candidate-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-candidates'; const COLUMN_NAME = 'schoolingRegistrationId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => { table.integer(COLUMN_NAME).references('schooling-registrations.id'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201027144304_add_nationalApprenticeId_to_schooling-registrations.js b/api/db/migrations/20201027144304_add_nationalApprenticeId_to_schooling-registrations.js index f02c55b599a..5cfcfbb07c2 100644 --- a/api/db/migrations/20201027144304_add_nationalApprenticeId_to_schooling-registrations.js +++ b/api/db/migrations/20201027144304_add_nationalApprenticeId_to_schooling-registrations.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'schooling-registrations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string('nationalApprenticeId'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('nationalApprenticeId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201027154028_add_id_identite_externe_to_user.js b/api/db/migrations/20201027154028_add_id_identite_externe_to_user.js index 11f242e8ac6..1f393cb2c02 100644 --- a/api/db/migrations/20201027154028_add_id_identite_externe_to_user.js +++ b/api/db/migrations/20201027154028_add_id_identite_externe_to_user.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'externalIdentityId'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201028134814_create_table_authentication_methods.js b/api/db/migrations/20201028134814_create_table_authentication_methods.js index cf36944ec41..77549c1642a 100644 --- a/api/db/migrations/20201028134814_create_table_authentication_methods.js +++ b/api/db/migrations/20201028134814_create_table_authentication_methods.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'authentication-methods'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.createTable(TABLE_NAME, (t) => { t.increments('id').primary(); t.integer('userId').references('users.id').index(); @@ -19,6 +19,8 @@ exports.up = async (knex) => { ); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20201029134518_add-unique-constraint-organizationid-targetprofileid-on-target-profile-shares.js b/api/db/migrations/20201029134518_add-unique-constraint-organizationid-targetprofileid-on-target-profile-shares.js index 2d374a3c0c6..74712546783 100644 --- a/api/db/migrations/20201029134518_add-unique-constraint-organizationid-targetprofileid-on-target-profile-shares.js +++ b/api/db/migrations/20201029134518_add-unique-constraint-organizationid-targetprofileid-on-target-profile-shares.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex .with('all_target_profile_shares_ranked', (qb) => { qb.select([ @@ -18,6 +18,8 @@ exports.up = async function (knex) { return knex.schema.table('target-profile-shares', (table) => table.unique(['organizationId', 'targetProfileId'])); }; -exports.down = async function (knex) { +const down = async function (knex) { return knex.schema.table('target-profile-shares', (table) => table.dropUnique(['organizationId', 'targetProfileId'])); }; + +export { up, down }; diff --git a/api/db/migrations/20201106093514_add_unicity_contraint_schooling_registration_on_apprenticeId_and_organizationId.js b/api/db/migrations/20201106093514_add_unicity_contraint_schooling_registration_on_apprenticeId_and_organizationId.js index 1081233d65c..ba2c36949c5 100644 --- a/api/db/migrations/20201106093514_add_unicity_contraint_schooling_registration_on_apprenticeId_and_organizationId.js +++ b/api/db/migrations/20201106093514_add_unicity_contraint_schooling_registration_on_apprenticeId_and_organizationId.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'schooling-registrations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.unique(['organizationId', 'nationalApprenticeId']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['organizationId', 'nationalApprenticeId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201106114017_add-lang-column-for-user.js b/api/db/migrations/20201106114017_add-lang-column-for-user.js index aa522cc2977..33855c231d7 100644 --- a/api/db/migrations/20201106114017_add-lang-column-for-user.js +++ b/api/db/migrations/20201106114017_add-lang-column-for-user.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'lang'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => { table.string(COLUMN_NAME).notNullable().defaultTo('fr'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201113105430_migrate-password-and-shouldChangePassword-to-authentication-methods.js b/api/db/migrations/20201113105430_migrate-password-and-shouldChangePassword-to-authentication-methods.js index bdd2c12219d..e6d5611ee18 100644 --- a/api/db/migrations/20201113105430_migrate-password-and-shouldChangePassword-to-authentication-methods.js +++ b/api/db/migrations/20201113105430_migrate-password-and-shouldChangePassword-to-authentication-methods.js @@ -1,4 +1,4 @@ -exports.up = async (knex) => { +const up = async function (knex) { // eslint-disable-next-line knex/avoid-injections return knex.raw( 'INSERT INTO "authentication-methods" ("userId", "identityProvider", "authenticationComplement") ' + @@ -9,7 +9,7 @@ exports.up = async (knex) => { ); }; -exports.down = async (knex) => { +const down = async function (knex) { const sqlRequest = 'UPDATE users ' + 'SET password = subquery.password, ' + @@ -29,3 +29,5 @@ exports.down = async (knex) => { return knex.raw('DELETE FROM "authentication-methods" WHERE "identityProvider" = \'PIX\';'); }; + +export { up, down }; diff --git a/api/db/migrations/20201117143916_update-stages-message-column-string-to-text.js b/api/db/migrations/20201117143916_update-stages-message-column-string-to-text.js index 856c930cd59..b895f92b443 100644 --- a/api/db/migrations/20201117143916_update-stages-message-column-string-to-text.js +++ b/api/db/migrations/20201117143916_update-stages-message-column-string-to-text.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'stages'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.text('message').alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.string('message').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201117144053_update-badges-message-column-string-to-text.js b/api/db/migrations/20201117144053_update-badges-message-column-string-to-text.js index fa5eca286d0..b2bcca367a6 100644 --- a/api/db/migrations/20201117144053_update-badges-message-column-string-to-text.js +++ b/api/db/migrations/20201117144053_update-badges-message-column-string-to-text.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'badges'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.text('message').alter(); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (table) { table.string('message').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201119145715_drop_column_external_identity_id_from_users.js b/api/db/migrations/20201119145715_drop_column_external_identity_id_from_users.js index f724ce97212..ff8195e1636 100644 --- a/api/db/migrations/20201119145715_drop_column_external_identity_id_from_users.js +++ b/api/db/migrations/20201119145715_drop_column_external_identity_id_from_users.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'externalIdentityId'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201125103011_migrate-samlid-to-authentication-methods.js b/api/db/migrations/20201125103011_migrate-samlid-to-authentication-methods.js index 34618599dcc..1c0630fe1e1 100644 --- a/api/db/migrations/20201125103011_migrate-samlid-to-authentication-methods.js +++ b/api/db/migrations/20201125103011_migrate-samlid-to-authentication-methods.js @@ -1,6 +1,6 @@ -const AuthenticationMethod = require('../../lib/domain/models/AuthenticationMethod'); +import { AuthenticationMethod } from '../../lib/domain/models/AuthenticationMethod.js'; -exports.up = function (knex) { +const up = function (knex) { // eslint-disable-next-line knex/avoid-injections return knex.raw( 'INSERT INTO "authentication-methods"("userId", "externalIdentifier", "identityProvider") ' + @@ -8,7 +8,7 @@ exports.up = function (knex) { ); }; -exports.down = async function (knex) { +const down = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw( 'UPDATE users SET "samlId" = ' + @@ -19,3 +19,5 @@ exports.down = async function (knex) { .where({ identityProvider: AuthenticationMethod.identityProviders.GAR }) .delete(); }; + +export { up, down }; diff --git a/api/db/migrations/20201126101242_create-certification-issue-reports-table.js b/api/db/migrations/20201126101242_create-certification-issue-reports-table.js index f289214196b..c33ab02084a 100644 --- a/api/db/migrations/20201126101242_create-certification-issue-reports-table.js +++ b/api/db/migrations/20201126101242_create-certification-issue-reports-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-issue-reports'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.createTable(TABLE_NAME, (t) => { t.increments('id').primary(); t.integer('certificationCourseId').references('certification-courses.id').index(); @@ -11,6 +11,8 @@ exports.up = async (knex) => { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20201126103437_migrate-examinerComment-to-certification-issue-reports.js b/api/db/migrations/20201126103437_migrate-examinerComment-to-certification-issue-reports.js index 7ee50f13175..2ed318fbe0f 100644 --- a/api/db/migrations/20201126103437_migrate-examinerComment-to-certification-issue-reports.js +++ b/api/db/migrations/20201126103437_migrate-examinerComment-to-certification-issue-reports.js @@ -1,8 +1,9 @@ -const { CertificationIssueReportCategories } = require('../../lib/domain/models/CertificationIssueReportCategory'); +import { CertificationIssueReportCategory } from '../../lib/domain/models/CertificationIssueReportCategory.js'; + const CERTIFICATION_COURSES = 'certification-courses'; const CERTIFICATION_ISSUE_REPORTS = 'certification-issue-reports'; -exports.up = async (knex) => { +const up = async function (knex) { const certificationCoursesWithExaminerComment = await knex(CERTIFICATION_COURSES) .select('id', 'examinerComment') .whereNotNull('examinerComment'); @@ -11,14 +12,14 @@ exports.up = async (knex) => { return { certificationCourseId: id, description: examinerComment, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, }; }); return knex.batchInsert(CERTIFICATION_ISSUE_REPORTS, reportsToInsert); }; -exports.down = async (knex) => { +const down = async function (knex) { const certificationCoursesWithExaminerComment = await knex(CERTIFICATION_COURSES) .select('id') .whereNotNull('examinerComment'); @@ -27,3 +28,5 @@ exports.down = async (knex) => { return knex(CERTIFICATION_ISSUE_REPORTS).whereIn('certificationCourseId', idsToDelete).delete(); }; + +export { up, down }; diff --git a/api/db/migrations/20201201151026_create-pole-emploi-sendings-table.js b/api/db/migrations/20201201151026_create-pole-emploi-sendings-table.js index 2ed1fea018f..0a7fd6585d1 100644 --- a/api/db/migrations/20201201151026_create-pole-emploi-sendings-table.js +++ b/api/db/migrations/20201201151026_create-pole-emploi-sendings-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'pole-emploi-sendings'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.createTable(TABLE_NAME, (t) => { t.increments('id').primary(); t.integer('campaignParticipationId').references('campaign-participations.id').index(); @@ -12,6 +12,8 @@ exports.up = async (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20201215145328_add-column-max-reachable-level-certification-course.js b/api/db/migrations/20201215145328_add-column-max-reachable-level-certification-course.js index 609e0eabdb3..cc6464b99b6 100644 --- a/api/db/migrations/20201215145328_add-column-max-reachable-level-certification-course.js +++ b/api/db/migrations/20201215145328_add-column-max-reachable-level-certification-course.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-courses'; const COLUMN_NAME = 'maxReachableLevelOnCertificationDate'; -exports.up = async (knex) => { +const up = async function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).notNullable().defaultTo(5); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201215163843_add_column_has-seen-new-level-info_to_users.js b/api/db/migrations/20201215163843_add_column_has-seen-new-level-info_to_users.js index dcfc8cca9a0..bdc7e845cd8 100644 --- a/api/db/migrations/20201215163843_add_column_has-seen-new-level-info_to_users.js +++ b/api/db/migrations/20201215163843_add_column_has-seen-new-level-info_to_users.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'hasSeenNewLevelInfo'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201217144235_add-subcategory-column-to-certif-issue-report.js b/api/db/migrations/20201217144235_add-subcategory-column-to-certif-issue-report.js index b7823c17cd3..526e6774ce7 100644 --- a/api/db/migrations/20201217144235_add-subcategory-column-to-certif-issue-report.js +++ b/api/db/migrations/20201217144235_add-subcategory-column-to-certif-issue-report.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-issue-reports'; const COLUMN_NAME = 'subcategory'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20201222163514_add-question-number-column-to-certification-issue-reports-table.js b/api/db/migrations/20201222163514_add-question-number-column-to-certification-issue-reports-table.js index fb47efd1270..90bdb2e5428 100644 --- a/api/db/migrations/20201222163514_add-question-number-column-to-certification-issue-reports-table.js +++ b/api/db/migrations/20201222163514_add-question-number-column-to-certification-issue-reports-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-issue-reports'; const COLUMN_NAME = 'questionNumber'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer(COLUMN_NAME).unsigned(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210111154804_rename-target-profile-organizationid-to-target-profile-owner-organization-id.js b/api/db/migrations/20210111154804_rename-target-profile-organizationid-to-target-profile-owner-organization-id.js index 0ea2bf66587..2e5e62f3e10 100644 --- a/api/db/migrations/20210111154804_rename-target-profile-organizationid-to-target-profile-owner-organization-id.js +++ b/api/db/migrations/20210111154804_rename-target-profile-organizationid-to-target-profile-owner-organization-id.js @@ -2,10 +2,12 @@ const TABLE_NAME = 'target-profiles'; const OLD_COLUMN_NAME = 'organizationId'; const NEW_COLUMN_NAME = 'ownerOrganizationId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(OLD_COLUMN_NAME, NEW_COLUMN_NAME)); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20210115143718_add-column-in-target-profiles-is-simplified-access.js b/api/db/migrations/20210115143718_add-column-in-target-profiles-is-simplified-access.js index 16171817ae7..47b75611586 100644 --- a/api/db/migrations/20210115143718_add-column-in-target-profiles-is-simplified-access.js +++ b/api/db/migrations/20210115143718_add-column-in-target-profiles-is-simplified-access.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'target-profiles'; const COLUMN_NAME = 'isSimplifiedAccess'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210118162334_add_column_has-seen-new-dashboard-info_to_users.js b/api/db/migrations/20210118162334_add_column_has-seen-new-dashboard-info_to_users.js index 1c81419ca9b..580b0091a7e 100644 --- a/api/db/migrations/20210118162334_add_column_has-seen-new-dashboard-info_to_users.js +++ b/api/db/migrations/20210118162334_add_column_has-seen-new-dashboard-info_to_users.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'hasSeenNewDashboardInfo'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210119120015_add-validated-skills-count-to-campaign-participations.js b/api/db/migrations/20210119120015_add-validated-skills-count-to-campaign-participations.js index 256c1d5dbec..5bb4ca6fe78 100644 --- a/api/db/migrations/20210119120015_add-validated-skills-count-to-campaign-participations.js +++ b/api/db/migrations/20210119120015_add-validated-skills-count-to-campaign-participations.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaign-participations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer('validatedSkillsCount'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('validatedSkillsCount'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210119141645_add-column-is-anonymous-to-users.js b/api/db/migrations/20210119141645_add-column-is-anonymous-to-users.js index 35a486e841c..b0f7236677e 100644 --- a/api/db/migrations/20210119141645_add-column-is-anonymous-to-users.js +++ b/api/db/migrations/20210119141645_add-column-is-anonymous-to-users.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'isAnonymous'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210129110252_remove_password_column_from_users_table.js b/api/db/migrations/20210129110252_remove_password_column_from_users_table.js index add71044b64..79efa81941c 100644 --- a/api/db/migrations/20210129110252_remove_password_column_from_users_table.js +++ b/api/db/migrations/20210129110252_remove_password_column_from_users_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'password'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210129124701_remove_shouldChangePassword_column_from_users_table.js b/api/db/migrations/20210129124701_remove_shouldChangePassword_column_from_users_table.js index 47897faba85..8c84c9ada0d 100644 --- a/api/db/migrations/20210129124701_remove_shouldChangePassword_column_from_users_table.js +++ b/api/db/migrations/20210129124701_remove_shouldChangePassword_column_from_users_table.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'shouldChangePassword'; const DEFAULT_VALUE = false; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(DEFAULT_VALUE); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210129140117_remove_samlId_column_from_users_table.js b/api/db/migrations/20210129140117_remove_samlId_column_from_users_table.js index 0e60353a5fd..eae1666be0b 100644 --- a/api/db/migrations/20210129140117_remove_samlId_column_from_users_table.js +++ b/api/db/migrations/20210129140117_remove_samlId_column_from_users_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'samlId'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME)(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210201101653_create-finalized-session-table.js b/api/db/migrations/20210201101653_create-finalized-session-table.js index bfdb9b540ab..5320f9ac0d1 100644 --- a/api/db/migrations/20210201101653_create-finalized-session-table.js +++ b/api/db/migrations/20210201101653_create-finalized-session-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'finalized-sessions'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.createTable(TABLE_NAME, (t) => { t.integer('sessionId').primary(); t.boolean('isPublishable').notNullable(); @@ -11,6 +11,8 @@ exports.up = async (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20210203110934_add-publishedAt-in-finalized-session-table.js b/api/db/migrations/20210203110934_add-publishedAt-in-finalized-session-table.js index ed70b79ee9d..2efb2f7cc89 100644 --- a/api/db/migrations/20210203110934_add-publishedAt-in-finalized-session-table.js +++ b/api/db/migrations/20210203110934_add-publishedAt-in-finalized-session-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'finalized-sessions'; const COLUMN_NAME = 'publishedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210216141040_add-column-for-absolute-novice-to-campaigns.js b/api/db/migrations/20210216141040_add-column-for-absolute-novice-to-campaigns.js index aa28a1c7796..3efea4d30d4 100644 --- a/api/db/migrations/20210216141040_add-column-for-absolute-novice-to-campaigns.js +++ b/api/db/migrations/20210216141040_add-column-for-absolute-novice-to-campaigns.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaigns'; const COLUMN_NAME = 'isForAbsoluteNovice'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210224170037_add-prescriber-description-and-prescriber-title-to-stages-table.js b/api/db/migrations/20210224170037_add-prescriber-description-and-prescriber-title-to-stages-table.js index 8dd1e53ac10..84f2a21bae8 100644 --- a/api/db/migrations/20210224170037_add-prescriber-description-and-prescriber-title-to-stages-table.js +++ b/api/db/migrations/20210224170037_add-prescriber-description-and-prescriber-title-to-stages-table.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'stages'; const PRESCRIBER_TITLE_COLUMN = 'prescriberTitle'; const PRESCRIBER_DESCRIPTION_COLUMN = 'prescriberDescription'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string(PRESCRIBER_TITLE_COLUMN); table.text(PRESCRIBER_DESCRIPTION_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(PRESCRIBER_TITLE_COLUMN); table.dropColumn(PRESCRIBER_DESCRIPTION_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210226114025_drop-column-has-seen-new-level-info-from-users.js b/api/db/migrations/20210226114025_drop-column-has-seen-new-level-info-from-users.js index 5614317574f..dc40317dedf 100644 --- a/api/db/migrations/20210226114025_drop-column-has-seen-new-level-info-from-users.js +++ b/api/db/migrations/20210226114025_drop-column-has-seen-new-level-info-from-users.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'hasSeenNewLevelInfo'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210304154309_add-partner-competences-ids-to-badge-criteria-table.js b/api/db/migrations/20210304154309_add-partner-competences-ids-to-badge-criteria-table.js index 9783443e11a..9983fa0a398 100644 --- a/api/db/migrations/20210304154309_add-partner-competences-ids-to-badge-criteria-table.js +++ b/api/db/migrations/20210304154309_add-partner-competences-ids-to-badge-criteria-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'badge-criteria'; const NEW_COLUMN = 'partnerCompetenceIds'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.specificType(NEW_COLUMN, 'int[]'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(NEW_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210309173118_add_assigned_certification_officer_name_to_finalized_sessions_table.js b/api/db/migrations/20210309173118_add_assigned_certification_officer_name_to_finalized_sessions_table.js index 0e5a8b74e59..aacaca525f7 100644 --- a/api/db/migrations/20210309173118_add_assigned_certification_officer_name_to_finalized_sessions_table.js +++ b/api/db/migrations/20210309173118_add_assigned_certification_officer_name_to_finalized_sessions_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'finalized-sessions'; const COLUMN_NAME = 'assignedCertificationOfficerName'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210310110213_add-last-question-date-in-assesments-table.js b/api/db/migrations/20210310110213_add-last-question-date-in-assesments-table.js index 1082515ce48..91425a6bd15 100644 --- a/api/db/migrations/20210310110213_add-last-question-date-in-assesments-table.js +++ b/api/db/migrations/20210310110213_add-last-question-date-in-assesments-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'assessments'; const COLUMN_NAME = 'lastQuestionDate'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210311142327_add-column-timespent-in-answers.js b/api/db/migrations/20210311142327_add-column-timespent-in-answers.js index 373f214aea7..4a9182a24f1 100644 --- a/api/db/migrations/20210311142327_add-column-timespent-in-answers.js +++ b/api/db/migrations/20210311142327_add-column-timespent-in-answers.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'answers'; const COLUMN_NAME = 'timeSpent'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210315154549_drop-elapsedTime-in-answers-table.js b/api/db/migrations/20210315154549_drop-elapsedTime-in-answers-table.js index fcf95de6604..5cc9f6549ab 100644 --- a/api/db/migrations/20210315154549_drop-elapsedTime-in-answers-table.js +++ b/api/db/migrations/20210315154549_drop-elapsedTime-in-answers-table.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'answers'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('elapsedTime'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer('elapsedTime'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210316221427_add-column-isNeutralized-in-certification-challenges.js b/api/db/migrations/20210316221427_add-column-isNeutralized-in-certification-challenges.js index e1289ecba8a..f8de1348107 100644 --- a/api/db/migrations/20210316221427_add-column-isNeutralized-in-certification-challenges.js +++ b/api/db/migrations/20210316221427_add-column-isNeutralized-in-certification-challenges.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-challenges'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean('isNeutralized').notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('isNeutralized'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210318145742_add-column-is-certifiable-to-badges.js b/api/db/migrations/20210318145742_add-column-is-certifiable-to-badges.js index f8750608966..b64056d7a78 100644 --- a/api/db/migrations/20210318145742_add-column-is-certifiable-to-badges.js +++ b/api/db/migrations/20210318145742_add-column-is-certifiable-to-badges.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'badges'; const COLUMN_NAME = 'isCertifiable'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210324101030_add-campaign-participation-to-badge-acquisitions-table.js b/api/db/migrations/20210324101030_add-campaign-participation-to-badge-acquisitions-table.js index 1108278cc48..65a513fd3d9 100644 --- a/api/db/migrations/20210324101030_add-campaign-participation-to-badge-acquisitions-table.js +++ b/api/db/migrations/20210324101030_add-campaign-participation-to-badge-acquisitions-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'badge-acquisitions'; const CAMPAIGN_PARTICIPATION_ID_COLUMN = 'campaignParticipationId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer(CAMPAIGN_PARTICIPATION_ID_COLUMN).references('campaign-participations.id').index(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(CAMPAIGN_PARTICIPATION_ID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210325103306_add-custom-fields-to-campaign.js b/api/db/migrations/20210325103306_add-custom-fields-to-campaign.js index 0af820b62d2..8fa5b928970 100644 --- a/api/db/migrations/20210325103306_add-custom-fields-to-campaign.js +++ b/api/db/migrations/20210325103306_add-custom-fields-to-campaign.js @@ -3,7 +3,7 @@ const CUSTOM_RESULT_PAGE_TEXT_COLUMN = 'customResultPageText'; const CUSTOM_RESULT_PAGE_BUTTON_TEXT_COLUMN = 'customResultPageButtonText'; const CUSTOM_RESULT_PAGE_BUTTON_URL_COLUMN = 'customResultPageButtonUrl'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.text(CUSTOM_RESULT_PAGE_TEXT_COLUMN); table.string(CUSTOM_RESULT_PAGE_BUTTON_TEXT_COLUMN); @@ -11,10 +11,12 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(CUSTOM_RESULT_PAGE_TEXT_COLUMN); table.dropColumn(CUSTOM_RESULT_PAGE_BUTTON_TEXT_COLUMN); table.dropColumn(CUSTOM_RESULT_PAGE_BUTTON_URL_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210413170121_add-column-envoisMultiples-to-campaigns-and-add-isImproved-to-campaign-participations-and-update-constraint-campaign-participations-unique-userId-campaignId-isImproved.js b/api/db/migrations/20210413170121_add-column-envoisMultiples-to-campaigns-and-add-isImproved-to-campaign-participations-and-update-constraint-campaign-participations-unique-userId-campaignId-isImproved.js index e9fb4212a59..22dfda23b8e 100644 --- a/api/db/migrations/20210413170121_add-column-envoisMultiples-to-campaigns-and-add-isImproved-to-campaign-participations-and-update-constraint-campaign-participations-unique-userId-campaignId-isImproved.js +++ b/api/db/migrations/20210413170121_add-column-envoisMultiples-to-campaigns-and-add-isImproved-to-campaign-participations-and-update-constraint-campaign-participations-unique-userId-campaignId-isImproved.js @@ -7,7 +7,7 @@ const USERID_COLUMN = 'userId'; const CAMPAIGNID_COLUMN = 'campaignId'; const NEW_CONSTRAINT_NAME = 'campaign_participations_campaignid_userid_isimproved'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.table(CAMPAIGNS_TABLE, function (table) { table.boolean(MULTIPLESENDINGS_COLUMN).defaultTo(false); }); @@ -23,7 +23,7 @@ exports.up = async (knex) => { ); }; -exports.down = async (knex) => { +const down = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw(`DROP INDEX ${NEW_CONSTRAINT_NAME};`); await knex.schema.table(CAMPAIGNPARTICIPATIONS_TABLE, (table) => { @@ -36,3 +36,5 @@ exports.down = async (knex) => { table.dropColumn(MULTIPLESENDINGS_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210414154016_add-index-on-lower-email-column-table-users.js b/api/db/migrations/20210414154016_add-index-on-lower-email-column-table-users.js index c3dc6b16fb8..f7aad7e66e0 100644 --- a/api/db/migrations/20210414154016_add-index-on-lower-email-column-table-users.js +++ b/api/db/migrations/20210414154016_add-index-on-lower-email-column-table-users.js @@ -1,11 +1,13 @@ const INDEX_NAME = 'users_email_lower'; -exports.up = (knex) => { +const up = function (knex) { // eslint-disable-next-line knex/avoid-injections return knex.raw(`CREATE INDEX "${INDEX_NAME}" ON "users"(LOWER("email"))`); }; -exports.down = (knex) => { +const down = function (knex) { // eslint-disable-next-line knex/avoid-injections return knex.raw(`DROP INDEX "${INDEX_NAME}"`); }; + +export { up, down }; diff --git a/api/db/migrations/20210414161434_add-index-lower-email-reset-password.js b/api/db/migrations/20210414161434_add-index-lower-email-reset-password.js index 49b31ce896d..c2d4936aa4d 100644 --- a/api/db/migrations/20210414161434_add-index-lower-email-reset-password.js +++ b/api/db/migrations/20210414161434_add-index-lower-email-reset-password.js @@ -1,6 +1,6 @@ const INDEX_NAME = 'reset-password-demands_email_lower'; -exports.up = async (knex) => { +const up = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw(`CREATE INDEX "${INDEX_NAME}" ON "reset-password-demands"(LOWER("email"))`); return knex.schema.table('reset-password-demands', function (table) { @@ -8,7 +8,7 @@ exports.up = async (knex) => { }); }; -exports.down = async (knex) => { +const down = async function (knex) { await knex.schema.table('reset-password-demands', function (table) { table.index('email'); }); @@ -16,3 +16,5 @@ exports.down = async (knex) => { // eslint-disable-next-line knex/avoid-injections return knex.raw(`DROP INDEX "${INDEX_NAME}"`); }; + +export { up, down }; diff --git a/api/db/migrations/20210416082943_add-column-certifiable-badge-key-to-certification-challenges-table.js b/api/db/migrations/20210416082943_add-column-certifiable-badge-key-to-certification-challenges-table.js index 5c7a8b3c10d..e858481ca8a 100644 --- a/api/db/migrations/20210416082943_add-column-certifiable-badge-key-to-certification-challenges-table.js +++ b/api/db/migrations/20210416082943_add-column-certifiable-badge-key-to-certification-challenges-table.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-challenges'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('certifiableBadgeKey'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('certifiableBadgeKey'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210420154410_add-column-isCancelled-to-certification-course.js b/api/db/migrations/20210420154410_add-column-isCancelled-to-certification-course.js index b8337dfb21b..816b8d209d0 100644 --- a/api/db/migrations/20210420154410_add-column-isCancelled-to-certification-course.js +++ b/api/db/migrations/20210420154410_add-column-isCancelled-to-certification-course.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-courses'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean('isCancelled').notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('isCancelled'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210427100545_add_indexes_on_table_campaign-participations.js b/api/db/migrations/20210427100545_add_indexes_on_table_campaign-participations.js index b0b9d579c0b..aa2c480fbf7 100644 --- a/api/db/migrations/20210427100545_add_indexes_on_table_campaign-participations.js +++ b/api/db/migrations/20210427100545_add_indexes_on_table_campaign-participations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaign-participations'; const CAMPAIGNID_COLUMN = 'campaignId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(CAMPAIGNID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(CAMPAIGNID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210429113555_replace-organization-id-student-number-index-on-schooling-registration.js b/api/db/migrations/20210429113555_replace-organization-id-student-number-index-on-schooling-registration.js index 8e33e738eb5..d3e6e0c6595 100644 --- a/api/db/migrations/20210429113555_replace-organization-id-student-number-index-on-schooling-registration.js +++ b/api/db/migrations/20210429113555_replace-organization-id-student-number-index-on-schooling-registration.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'schooling-registrations'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('DROP INDEX "organizationid_studentnumber_index"'); await knex.raw('DROP INDEX "organizationid_studentnumber_notsupernumerary_index"'); @@ -9,7 +9,7 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw( 'CREATE INDEX "organizationid_studentnumber_index" ON "schooling-registrations" ("organizationId", "studentNumber");' ); @@ -21,3 +21,5 @@ exports.down = async function (knex) { table.dropUnique(['studentNumber', 'organizationId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210430154711_trim-certification-candidates-first-name-and-last-name.js b/api/db/migrations/20210430154711_trim-certification-candidates-first-name-and-last-name.js index 9fce4772298..a9859ada8a2 100644 --- a/api/db/migrations/20210430154711_trim-certification-candidates-first-name-and-last-name.js +++ b/api/db/migrations/20210430154711_trim-certification-candidates-first-name-and-last-name.js @@ -1,4 +1,4 @@ -exports.up = function (knex) { +const up = function (knex) { // eslint-disable-next-line knex/avoid-injections return knex.raw( 'UPDATE "certification-candidates"' + @@ -8,6 +8,8 @@ exports.up = function (knex) { ); }; -exports.down = function () { +const down = function () { return; }; + +export { up, down }; diff --git a/api/db/migrations/20210503164450_remove-isSupernumeray-column.js b/api/db/migrations/20210503164450_remove-isSupernumeray-column.js index 18acbed6017..3f23befd838 100644 --- a/api/db/migrations/20210503164450_remove-isSupernumeray-column.js +++ b/api/db/migrations/20210503164450_remove-isSupernumeray-column.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'schooling-registrations'; const COLUMN = 'isSupernumerary'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210506112005_fill-missing-competence-id-values-in-table-competence-marks.js b/api/db/migrations/20210506112005_fill-missing-competence-id-values-in-table-competence-marks.js index ff1ae73cf66..79ccabe7b2c 100644 --- a/api/db/migrations/20210506112005_fill-missing-competence-id-values-in-table-competence-marks.js +++ b/api/db/migrations/20210506112005_fill-missing-competence-id-values-in-table-competence-marks.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex('competence-marks').whereNull('competenceId').where('competence_code', '1.1').update({ competenceId: 'recsvLz0W2ShyfD63', }); @@ -52,6 +52,8 @@ exports.up = async function (knex) { }); }; -exports.down = function () { +const down = function () { return; }; + +export { up, down }; diff --git a/api/db/migrations/20210506114245_remove-nullable-mentions-in-columns-table-competence-marks.js b/api/db/migrations/20210506114245_remove-nullable-mentions-in-columns-table-competence-marks.js index 33bb4d14703..5be29ff99d5 100644 --- a/api/db/migrations/20210506114245_remove-nullable-mentions-in-columns-table-competence-marks.js +++ b/api/db/migrations/20210506114245_remove-nullable-mentions-in-columns-table-competence-marks.js @@ -1,13 +1,15 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('ALTER TABLE "competence-marks" ALTER COLUMN "competenceId" SET NOT NULL'); await knex.raw('ALTER TABLE "competence-marks" ALTER COLUMN "assessmentResultId" SET NOT NULL'); await knex.raw('ALTER TABLE "competence-marks" ALTER COLUMN "level" SET NOT NULL'); await knex.raw('ALTER TABLE "competence-marks" ALTER COLUMN "score" SET NOT NULL'); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('ALTER TABLE "competence-marks" ALTER COLUMN "competenceId" DROP NOT NULL'); await knex.raw('ALTER TABLE "competence-marks" ALTER COLUMN "assessmentResultId" DROP NOT NULL'); await knex.raw('ALTER TABLE "competence-marks" ALTER COLUMN "level" DROP NOT NULL'); await knex.raw('ALTER TABLE "competence-marks" ALTER COLUMN "score" DROP NOT NULL'); }; + +export { up, down }; diff --git a/api/db/migrations/20210506121007_delete_pix_reader_row_in_pix_roles.js b/api/db/migrations/20210506121007_delete_pix_reader_row_in_pix_roles.js index fe9babb9b3f..c7f76743878 100644 --- a/api/db/migrations/20210506121007_delete_pix_reader_row_in_pix_roles.js +++ b/api/db/migrations/20210506121007_delete_pix_reader_row_in_pix_roles.js @@ -1,10 +1,12 @@ const TABLE_NAME = 'pix_roles'; const ROW = { name: 'PIX_READER' }; -exports.up = function (knex) { +const up = function (knex) { return knex.table(TABLE_NAME).where('name', ROW.name).delete(); }; -exports.down = function (knex) { +const down = function (knex) { return knex.table(TABLE_NAME).insert(ROW); }; + +export { up, down }; diff --git a/api/db/migrations/20210506134706_alter_users_pix_roles_add_unique_constraint.js b/api/db/migrations/20210506134706_alter_users_pix_roles_add_unique_constraint.js index f585f95cd70..1fdd576fe73 100644 --- a/api/db/migrations/20210506134706_alter_users_pix_roles_add_unique_constraint.js +++ b/api/db/migrations/20210506134706_alter_users_pix_roles_add_unique_constraint.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users_pix_roles'; const COLUMNS_NAME = ['user_id', 'pix_role_id']; -exports.up = async function (knex) { +const up = async function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.unique(COLUMNS_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(COLUMNS_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210507093056_add-column-certified-image-url-table-badges.js b/api/db/migrations/20210507093056_add-column-certified-image-url-table-badges.js index e23020ac343..44e16c8e522 100644 --- a/api/db/migrations/20210507093056_add-column-certified-image-url-table-badges.js +++ b/api/db/migrations/20210507093056_add-column-certified-image-url-table-badges.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('badges', (table) => { table.string('certifiedImageUrl', 500); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('badges', function (table) { table.dropColumn('certifiedImageUrl'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210517162046_drop-column-color-in-badge-partner-competences.js b/api/db/migrations/20210517162046_drop-column-color-in-badge-partner-competences.js index d6ca71ce77a..84fcf054251 100644 --- a/api/db/migrations/20210517162046_drop-column-color-in-badge-partner-competences.js +++ b/api/db/migrations/20210517162046_drop-column-color-in-badge-partner-competences.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'badge-partner-competences'; const COLUMN_NAME = 'color'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210519150136_add-column-last-challenge-in-assessment.js b/api/db/migrations/20210519150136_add-column-last-challenge-in-assessment.js index ff11d28e913..c4e05813ace 100644 --- a/api/db/migrations/20210519150136_add-column-last-challenge-in-assessment.js +++ b/api/db/migrations/20210519150136_add-column-last-challenge-in-assessment.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('assessments', (table) => { table.string('lastChallengeId', 50); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('assessments', function (table) { table.dropColumn('lastChallengeId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210525140944_add-column-processed-at-table-certification-issue-reports.js b/api/db/migrations/20210525140944_add-column-processed-at-table-certification-issue-reports.js index 30d07811f57..c3be2b5476e 100644 --- a/api/db/migrations/20210525140944_add-column-processed-at-table-certification-issue-reports.js +++ b/api/db/migrations/20210525140944_add-column-processed-at-table-certification-issue-reports.js @@ -1,13 +1,15 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('certification-issue-reports', (table) => { table.dateTime('resolvedAt'); table.string('resolution'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('certification-issue-reports', (table) => { table.dropColumn('resolvedAt'); table.dropColumn('resolution'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210527111219_add-column-sex-in-table-schooling-registrations.js b/api/db/migrations/20210527111219_add-column-sex-in-table-schooling-registrations.js index b3ac91c3a99..ca1ee160ca8 100644 --- a/api/db/migrations/20210527111219_add-column-sex-in-table-schooling-registrations.js +++ b/api/db/migrations/20210527111219_add-column-sex-in-table-schooling-registrations.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('schooling-registrations', (table) => { table.string('sex', 1); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('schooling-registrations', function (table) { table.dropColumn('sex'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210607141627_drop-column-certified-badge-image-url-on-table-badges.js b/api/db/migrations/20210607141627_drop-column-certified-badge-image-url-on-table-badges.js index f2bb71440ce..9b73bdf5db0 100644 --- a/api/db/migrations/20210607141627_drop-column-certified-badge-image-url-on-table-badges.js +++ b/api/db/migrations/20210607141627_drop-column-certified-badge-image-url-on-table-badges.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('badges', function (table) { table.dropColumn('certifiedImageUrl'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('badges', (table) => { table.string('certifiedImageUrl', 500); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210607142018_fix-certifications-version-v2.js b/api/db/migrations/20210607142018_fix-certifications-version-v2.js index 7e02b56611d..df5663d49f5 100644 --- a/api/db/migrations/20210607142018_fix-certifications-version-v2.js +++ b/api/db/migrations/20210607142018_fix-certifications-version-v2.js @@ -1,12 +1,14 @@ const TABLE_NAME = 'certification-courses'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).where('createdAt', '>', '2021-01-01').andWhere('isV2Certification', false).update({ isV2Certification: true, }); }; -exports.down = function (_) { +const down = function (_) { // un rollback serait contre-productif return Promise.resolve(); }; + +export { up, down }; diff --git a/api/db/migrations/20210607163646_add-columns-sex-birthPostalCode-birthINSEECode-in-table-certification-candidates.js b/api/db/migrations/20210607163646_add-columns-sex-birthPostalCode-birthINSEECode-in-table-certification-candidates.js index 45b720ba128..c1b3a01fb7c 100644 --- a/api/db/migrations/20210607163646_add-columns-sex-birthPostalCode-birthINSEECode-in-table-certification-candidates.js +++ b/api/db/migrations/20210607163646_add-columns-sex-birthPostalCode-birthINSEECode-in-table-certification-candidates.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table('certification-candidates', (table) => { table.string('birthPostalCode'); table.string('birthINSEECode'); @@ -10,9 +10,11 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.alterTable('certification-candidates', (table) => { table.dropColumns('birthPostalCode', 'birthINSEECode', 'sex'); table.string('birthCity').notNullable().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210609045948_add-index-on-table-certification-candidates-column-schooling-registration-id.js b/api/db/migrations/20210609045948_add-index-on-table-certification-candidates-column-schooling-registration-id.js index e895b0b4126..2c3aabd8f58 100644 --- a/api/db/migrations/20210609045948_add-index-on-table-certification-candidates-column-schooling-registration-id.js +++ b/api/db/migrations/20210609045948_add-index-on-table-certification-candidates-column-schooling-registration-id.js @@ -1,11 +1,13 @@ -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table('certification-candidates', (table) => { table.index('schoolingRegistrationId'); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table('certification-candidates', (table) => { table.dropIndex('schoolingRegistrationId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210610172018_fill_badge_partner_competence_for_critera.js b/api/db/migrations/20210610172018_fill_badge_partner_competence_for_critera.js index 591b5d54f49..4392a65febd 100644 --- a/api/db/migrations/20210610172018_fill_badge_partner_competence_for_critera.js +++ b/api/db/migrations/20210610172018_fill_badge_partner_competence_for_critera.js @@ -1,7 +1,7 @@ -const bluebird = require('bluebird'); -const _ = require('lodash'); +import bluebird from 'bluebird'; +import _ from 'lodash'; -exports.up = async function (knex) { +const up = async function (knex) { const badgesAndPartnerCompetences = await knex('badges') .select('badges.id as badgeId', 'badge-partner-competences.id as partnerCompetenceId') .leftJoin('badge-criteria', 'badges.id', 'badge-criteria.badgeId') @@ -25,6 +25,8 @@ exports.up = async function (knex) { }); }; -exports.down = function () { +const down = function () { return; }; + +export { up, down }; diff --git a/api/db/migrations/20210611081228_add-columns-sex-birthPostalCode-birthINSEECode-in-table-certification-courses.js b/api/db/migrations/20210611081228_add-columns-sex-birthPostalCode-birthINSEECode-in-table-certification-courses.js index 91ee51f9410..af64296331c 100644 --- a/api/db/migrations/20210611081228_add-columns-sex-birthPostalCode-birthINSEECode-in-table-certification-courses.js +++ b/api/db/migrations/20210611081228_add-columns-sex-birthPostalCode-birthINSEECode-in-table-certification-courses.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table('certification-courses', (table) => { table.string('birthPostalCode'); table.string('birthINSEECode'); @@ -6,8 +6,10 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.alterTable('certification-courses', (table) => { table.dropColumns('birthPostalCode', 'birthINSEECode', 'sex'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210614103332_create-table-certification-cpf-countries.js b/api/db/migrations/20210614103332_create-table-certification-cpf-countries.js index 8f76f481d15..3d77da58058 100644 --- a/api/db/migrations/20210614103332_create-table-certification-cpf-countries.js +++ b/api/db/migrations/20210614103332_create-table-certification-cpf-countries.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-cpf-countries'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('code').notNullable(); @@ -11,6 +11,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20210614103435_create-table-certification-cpf-cities.js b/api/db/migrations/20210614103435_create-table-certification-cpf-cities.js index 583752446d6..a9ed3fe3aa2 100644 --- a/api/db/migrations/20210614103435_create-table-certification-cpf-cities.js +++ b/api/db/migrations/20210614103435_create-table-certification-cpf-cities.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-cpf-cities'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('name').notNullable(); @@ -11,6 +11,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20210614142832_audit-table-for-autojury.js b/api/db/migrations/20210614142832_audit-table-for-autojury.js index 011472d0049..94e387334fc 100644 --- a/api/db/migrations/20210614142832_audit-table-for-autojury.js +++ b/api/db/migrations/20210614142832_audit-table-for-autojury.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'autojury-script-audit'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments('sessionId').primary(); t.text('certificationCenterName'); @@ -13,6 +13,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20210616111928_rename-badge-criteria-scope.js b/api/db/migrations/20210616111928_rename-badge-criteria-scope.js index 0cdaaf4d9f8..d184d3dfc6a 100644 --- a/api/db/migrations/20210616111928_rename-badge-criteria-scope.js +++ b/api/db/migrations/20210616111928_rename-badge-criteria-scope.js @@ -1,7 +1,9 @@ -exports.up = async function (knex) { +const up = async function (knex) { return knex('badge-criteria').update({ scope: 'SkillSet' }).where({ scope: 'SomePartnerCompetences' }); }; -exports.down = function (knex) { +const down = function (knex) { return knex('badge-criteria').update({ scope: 'SomePartnerCompetences' }).where({ scope: 'SkillSet' }); }; + +export { up, down }; diff --git a/api/db/migrations/20210630150224_add_column_updatedAt_to_badge_acquisitions.js b/api/db/migrations/20210630150224_add_column_updatedAt_to_badge_acquisitions.js index 313c86f5e27..7610ecfd808 100644 --- a/api/db/migrations/20210630150224_add_column_updatedAt_to_badge_acquisitions.js +++ b/api/db/migrations/20210630150224_add_column_updatedAt_to_badge_acquisitions.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'badge-acquisitions'; const UPDATED_AT_COLUMN = 'updatedAt'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.dateTime(UPDATED_AT_COLUMN).notNullable().defaultTo(knex.fn.now()); }); @@ -10,8 +10,10 @@ exports.up = async function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(UPDATED_AT_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210706121344_create-account-recovery-demands-table.js b/api/db/migrations/20210706121344_create-account-recovery-demands-table.js index 101a1a67204..e5c00b566f7 100644 --- a/api/db/migrations/20210706121344_create-account-recovery-demands-table.js +++ b/api/db/migrations/20210706121344_create-account-recovery-demands-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'account-recovery-demands'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('userId').index(); @@ -13,6 +13,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20210707082408_update-account-recovery-demands-table.js b/api/db/migrations/20210707082408_update-account-recovery-demands-table.js index 9180a016598..7de81034ee6 100644 --- a/api/db/migrations/20210707082408_update-account-recovery-demands-table.js +++ b/api/db/migrations/20210707082408_update-account-recovery-demands-table.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'account-recovery-demands'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, (t) => { t.integer('userId').alter(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (t) => { t.string('userId').alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210713145931_set-default-target-profile-image.js b/api/db/migrations/20210713145931_set-default-target-profile-image.js index b5eed7ade93..56a7acd78db 100644 --- a/api/db/migrations/20210713145931_set-default-target-profile-image.js +++ b/api/db/migrations/20210713145931_set-default-target-profile-image.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'target-profiles'; const DEFAULT_IMAGE_URL = 'https://images.pix.fr/profil-cible/Illu_GEN.svg'; -exports.up = async function (knex) { +const up = async function (knex) { await updateWithDefaultImageUrl(knex); }; -exports.down = function () { +const down = function () { return; }; +export { up, down }; + async function updateWithDefaultImageUrl(knex) { await knex(TABLE_NAME).whereNull('imageUrl').update({ imageUrl: DEFAULT_IMAGE_URL, diff --git a/api/db/migrations/20210715153308_add-column-schoolingRegistrationId-to-account-recovery-demands-table.js b/api/db/migrations/20210715153308_add-column-schoolingRegistrationId-to-account-recovery-demands-table.js index df61f2fb5ec..2c18063a520 100644 --- a/api/db/migrations/20210715153308_add-column-schoolingRegistrationId-to-account-recovery-demands-table.js +++ b/api/db/migrations/20210715153308_add-column-schoolingRegistrationId-to-account-recovery-demands-table.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'account-recovery-demands'; const TABLE_COLUMN = 'schoolingRegistrationId'; const REFERENCED_COLUMN_NAME = 'schooling-registrations.id'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer(TABLE_COLUMN).unsigned().references(REFERENCED_COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(TABLE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210715184135_add-email-confirmed-at-to-users.js b/api/db/migrations/20210715184135_add-email-confirmed-at-to-users.js index 90cfc2701a0..99b45a0ffb9 100644 --- a/api/db/migrations/20210715184135_add-email-confirmed-at-to-users.js +++ b/api/db/migrations/20210715184135_add-email-confirmed-at-to-users.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'emailConfirmedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210716074232_alter_account-recovery-demand_add_unique_temporary_key.js b/api/db/migrations/20210716074232_alter_account-recovery-demand_add_unique_temporary_key.js index ba3de604438..42615b5b1ae 100644 --- a/api/db/migrations/20210716074232_alter_account-recovery-demand_add_unique_temporary_key.js +++ b/api/db/migrations/20210716074232_alter_account-recovery-demand_add_unique_temporary_key.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.raw( 'ALTER TABLE "account-recovery-demands" ADD CONSTRAINT account_recovery_demands_temporary_key_unique UNIQUE("temporaryKey")' ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw( 'ALTER TABLE "account-recovery-demands" DROP CONSTRAINT account_recovery_demands_temporary_key_unique' ); }; + +export { up, down }; diff --git a/api/db/migrations/20210721084659_add-birthCountry-in-certification-course-table.js b/api/db/migrations/20210721084659_add-birthCountry-in-certification-course-table.js index 5ea2455c761..963a1966305 100644 --- a/api/db/migrations/20210721084659_add-birthCountry-in-certification-course-table.js +++ b/api/db/migrations/20210721084659_add-birthCountry-in-certification-course-table.js @@ -1,11 +1,13 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table('certification-courses', (table) => { table.string('birthCountry'); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.alterTable('certification-courses', (table) => { table.dropColumns('birthCountry'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210722122054_drop-table-autojury-script-audit.js b/api/db/migrations/20210722122054_drop-table-autojury-script-audit.js index c86ebb3801f..3576839ef8d 100644 --- a/api/db/migrations/20210722122054_drop-table-autojury-script-audit.js +++ b/api/db/migrations/20210722122054_drop-table-autojury-script-audit.js @@ -1,10 +1,10 @@ const TABLE_NAME = 'autojury-script-audit'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments('sessionId').primary(); t.text('certificationCenterName'); @@ -16,3 +16,5 @@ exports.down = function (knex) { t.enu('status', ['TO DO', 'DOING', 'DONE', 'TO RETRY']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210726130724_add-isDisabled-column-in-schooling-registrations-table.js b/api/db/migrations/20210726130724_add-isDisabled-column-in-schooling-registrations-table.js index a58cd110989..b57df1a8ea6 100644 --- a/api/db/migrations/20210726130724_add-isDisabled-column-in-schooling-registrations-table.js +++ b/api/db/migrations/20210726130724_add-isDisabled-column-in-schooling-registrations-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'schooling-registrations'; const COLUMN_NAME = 'isDisabled'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210727092407_add-columns-has-seen-focused-and-other-challenge-tooltips.js b/api/db/migrations/20210727092407_add-columns-has-seen-focused-and-other-challenge-tooltips.js index 1e6f46b41eb..28b4a1c6a51 100644 --- a/api/db/migrations/20210727092407_add-columns-has-seen-focused-and-other-challenge-tooltips.js +++ b/api/db/migrations/20210727092407_add-columns-has-seen-focused-and-other-challenge-tooltips.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'hasSeenFocusedChallengeTooltip'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210802093720_add-column-mastery-percentage-on-campaign-participation.js b/api/db/migrations/20210802093720_add-column-mastery-percentage-on-campaign-participation.js index e372fe596e8..7fff725f6a8 100644 --- a/api/db/migrations/20210802093720_add-column-mastery-percentage-on-campaign-participation.js +++ b/api/db/migrations/20210802093720_add-column-mastery-percentage-on-campaign-participation.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaign-participations'; const COLUMN_NAME = 'masteryPercentage'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.decimal(COLUMN_NAME, 3, 2).defaultTo(null); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210802094853_add-column-pix-score-on-campaign-participation.js b/api/db/migrations/20210802094853_add-column-pix-score-on-campaign-participation.js index 3dbc81e1c08..6aef206c53c 100644 --- a/api/db/migrations/20210802094853_add-column-pix-score-on-campaign-participation.js +++ b/api/db/migrations/20210802094853_add-column-pix-score-on-campaign-participation.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaign-participations'; const COLUMN_NAME = 'pixScore'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).defaultTo(null); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210810061837_add-column-createdBy-to-organizations.js b/api/db/migrations/20210810061837_add-column-createdBy-to-organizations.js index 524f927887c..3d64b5bfd49 100644 --- a/api/db/migrations/20210810061837_add-column-createdBy-to-organizations.js +++ b/api/db/migrations/20210810061837_add-column-createdBy-to-organizations.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'createdBy'; const REFERENCED_COLUMN_NAME = 'users.id'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).unsigned().references(REFERENCED_COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210810084355_alter_table_account-recovery-demands_add_not_null_schoolingRegistrationId.js b/api/db/migrations/20210810084355_alter_table_account-recovery-demands_add_not_null_schoolingRegistrationId.js index 51936118d63..1bfe8fe309a 100644 --- a/api/db/migrations/20210810084355_alter_table_account-recovery-demands_add_not_null_schoolingRegistrationId.js +++ b/api/db/migrations/20210810084355_alter_table_account-recovery-demands_add_not_null_schoolingRegistrationId.js @@ -1,7 +1,9 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.raw('ALTER TABLE "account-recovery-demands" ALTER COLUMN "schoolingRegistrationId" SET NOT NULL'); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw('ALTER TABLE "account-recovery-demands" ALTER COLUMN "schoolingRegistrationId" DROP NOT NULL'); }; + +export { up, down }; diff --git a/api/db/migrations/20210811153908_alter_table_account-recovery-demands_add_foreign_key_not_null_userId.js b/api/db/migrations/20210811153908_alter_table_account-recovery-demands_add_foreign_key_not_null_userId.js index e84f65f8830..23f26fd36db 100644 --- a/api/db/migrations/20210811153908_alter_table_account-recovery-demands_add_foreign_key_not_null_userId.js +++ b/api/db/migrations/20210811153908_alter_table_account-recovery-demands_add_foreign_key_not_null_userId.js @@ -1,11 +1,13 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('ALTER TABLE "account-recovery-demands" ALTER COLUMN "userId" SET NOT NULL'); await knex.raw( 'ALTER TABLE "account-recovery-demands" ADD CONSTRAINT "account_recovery_demands_userid_foreign" FOREIGN KEY ("userId") REFERENCES "users" (id)' ); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('ALTER TABLE "account-recovery-demands" ALTER COLUMN "userId" DROP NOT NULL'); await knex.raw('ALTER TABLE "account-recovery-demands" DROP CONSTRAINT "account_recovery_demands_userid_foreign"'); }; + +export { up, down }; diff --git a/api/db/migrations/20210818132942_add-bigintId-to-knowledge-elements.js b/api/db/migrations/20210818132942_add-bigintId-to-knowledge-elements.js index d82cabe5037..45035329d17 100644 --- a/api/db/migrations/20210818132942_add-bigintId-to-knowledge-elements.js +++ b/api/db/migrations/20210818132942_add-bigintId-to-knowledge-elements.js @@ -2,7 +2,7 @@ const TABLE_NAME = 'knowledge-elements'; const COLUMN_NAME = 'bigintId'; const FAKE_VALUE_TO_COMPLY_WITH_NOT_NULL_CONSTRAINT_MANDATORY_FOR_FUTURE_PK = -1; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table .bigInteger(COLUMN_NAME) @@ -25,7 +25,7 @@ exports.up = async function (knex) { EXECUTE FUNCTION copy_int_id_to_bigint_id();`); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('DROP TRIGGER "trg_knowledge-elements" ON "knowledge-elements"'); await knex.raw('DROP FUNCTION copy_int_id_to_bigint_id'); @@ -33,3 +33,5 @@ exports.down = async function (knex) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210818155256_copy_id_to_bigintid_on_knowledge-elements.js b/api/db/migrations/20210818155256_copy_id_to_bigintid_on_knowledge-elements.js index 74f651e60a0..e6be98c2007 100644 --- a/api/db/migrations/20210818155256_copy_id_to_bigintid_on_knowledge-elements.js +++ b/api/db/migrations/20210818155256_copy_id_to_bigintid_on_knowledge-elements.js @@ -1,6 +1,6 @@ const MAX_ROW_COUNT_FOR_SYNCHRONOUS_MIGRATION = 10000000; -exports.up = async function (knex) { +const up = async function (knex) { const nbRows = (await knex('knowledge-elements').max('id').first()).max; if (nbRows < MAX_ROW_COUNT_FOR_SYNCHRONOUS_MIGRATION) { @@ -9,6 +9,8 @@ exports.up = async function (knex) { } }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('DROP INDEX IF EXISTS "knowledge-elements_bigintId_index"'); }; + +export { up, down }; diff --git a/api/db/migrations/20210819161111_use-bigint-for-knowledge-elements-pk.js b/api/db/migrations/20210819161111_use-bigint-for-knowledge-elements-pk.js index 376e3813356..a19a5f5e8e9 100644 --- a/api/db/migrations/20210819161111_use-bigint-for-knowledge-elements-pk.js +++ b/api/db/migrations/20210819161111_use-bigint-for-knowledge-elements-pk.js @@ -1,6 +1,6 @@ const MAX_ROW_COUNT_FOR_CREATING_BACK_PK_IN_DEPLOYMENT = 500000; -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('LOCK TABLE "knowledge-elements" IN ACCESS EXCLUSIVE MODE'); await knex.raw('DROP TRIGGER "trg_knowledge-elements" ON "knowledge-elements"'); await knex.raw('DROP FUNCTION copy_int_id_to_bigint_id'); @@ -19,7 +19,7 @@ exports.up = async function (knex) { await knex.raw('ALTER TABLE "knowledge-elements" RENAME COLUMN "bigintId" TO "id"'); }; -exports.down = async function (knex) { +const down = async function (knex) { const nbRows = (await knex('knowledge-elements').max('id').first()).max; if (nbRows < MAX_ROW_COUNT_FOR_CREATING_BACK_PK_IN_DEPLOYMENT) { @@ -60,3 +60,5 @@ exports.down = async function (knex) { // https://doc.scalingo.com/platform/app/postdeploy-hook#limits } }; + +export { up, down }; diff --git a/api/db/migrations/20210820071611_remove-integer-id-from-knowledge-elements.js b/api/db/migrations/20210820071611_remove-integer-id-from-knowledge-elements.js index 84ebf9ee31c..d712a77f9d4 100644 --- a/api/db/migrations/20210820071611_remove-integer-id-from-knowledge-elements.js +++ b/api/db/migrations/20210820071611_remove-integer-id-from-knowledge-elements.js @@ -1,7 +1,9 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('ALTER TABLE "knowledge-elements" DROP COLUMN "intId"'); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('ALTER TABLE "knowledge-elements" ADD COLUMN "intId" INTEGER'); }; + +export { up, down }; diff --git a/api/db/migrations/20210823142553_add-column-assessment-method-to-campaigns-table.js b/api/db/migrations/20210823142553_add-column-assessment-method-to-campaigns-table.js index 325feda9ed3..b992fd8391f 100644 --- a/api/db/migrations/20210823142553_add-column-assessment-method-to-campaigns-table.js +++ b/api/db/migrations/20210823142553_add-column-assessment-method-to-campaigns-table.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'campaigns'; const COLUMN_NAME = 'assessmentMethod'; const DEFAULT_COLUMN_VALUE = 'SMART_RANDOM'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text(COLUMN_NAME).defaultTo(DEFAULT_COLUMN_VALUE); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210827153245_add-column-last-question-state-in-assessment.js b/api/db/migrations/20210827153245_add-column-last-question-state-in-assessment.js index 7cc19a62367..70ccf6eae83 100644 --- a/api/db/migrations/20210827153245_add-column-last-question-state-in-assessment.js +++ b/api/db/migrations/20210827153245_add-column-last-question-state-in-assessment.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('assessments', (table) => { table.string('lastQuestionState', 50).default('asked'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('assessments', function (table) { table.dropColumn('lastQuestionState'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210830100754_delete-index-on-account-recovery-demands-table.js b/api/db/migrations/20210830100754_delete-index-on-account-recovery-demands-table.js index 17138702b69..8a828f6d5f9 100644 --- a/api/db/migrations/20210830100754_delete-index-on-account-recovery-demands-table.js +++ b/api/db/migrations/20210830100754_delete-index-on-account-recovery-demands-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'account-recovery-demands'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex('oldEmail'); table.dropIndex('newEmail'); @@ -8,10 +8,12 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index('oldEmail'); table.index('newEmail'); table.index('temporaryKey'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210831124754_add-last-logged-at-column-in-users-table.js b/api/db/migrations/20210831124754_add-last-logged-at-column-in-users-table.js index a4810fff7c7..68cb99e50e4 100644 --- a/api/db/migrations/20210831124754_add-last-logged-at-column-in-users-table.js +++ b/api/db/migrations/20210831124754_add-last-logged-at-column-in-users-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'lastLoggedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210831140352_add_certification-courses_abort-reason.js b/api/db/migrations/20210831140352_add_certification-courses_abort-reason.js index 5e4230a75d2..0d5089c8aad 100644 --- a/api/db/migrations/20210831140352_add_certification-courses_abort-reason.js +++ b/api/db/migrations/20210831140352_add_certification-courses_abort-reason.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-courses'; const COLUMN_NAME = 'abortReason'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210831141155_add-columns-for-session-jury-comments.js b/api/db/migrations/20210831141155_add-columns-for-session-jury-comments.js index d8e684a944e..951ed6f25ed 100644 --- a/api/db/migrations/20210831141155_add-columns-for-session-jury-comments.js +++ b/api/db/migrations/20210831141155_add-columns-for-session-jury-comments.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'sessions'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text('juryComment').defaultsTo(null); table.integer('juryCommentAuthorId').unsigned().references('users.id').defaultsTo(null); @@ -8,10 +8,12 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.dropColumn('juryComment'); table.dropColumn('juryCommentAuthorId'); table.dropColumn('juryCommentedAt'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210831141356_create-accreditations-table.js b/api/db/migrations/20210831141356_create-accreditations-table.js index 388570e2f18..eca744be51a 100644 --- a/api/db/migrations/20210831141356_create-accreditations-table.js +++ b/api/db/migrations/20210831141356_create-accreditations-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'accreditations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('name').notNullable(); @@ -8,6 +8,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20210831142318_create-granted-accreditations-table.js b/api/db/migrations/20210831142318_create-granted-accreditations-table.js index c252503c927..53d549bcd42 100644 --- a/api/db/migrations/20210831142318_create-granted-accreditations-table.js +++ b/api/db/migrations/20210831142318_create-granted-accreditations-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'granted-accreditations'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); @@ -9,6 +9,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20210831145630_create-accredited-badges-table.js b/api/db/migrations/20210831145630_create-accredited-badges-table.js index 14acd197ccd..34be6c75b96 100644 --- a/api/db/migrations/20210831145630_create-accredited-badges-table.js +++ b/api/db/migrations/20210831145630_create-accredited-badges-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'accredited-badges'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('accreditationId').references('accreditations.id').notNullable(); @@ -9,6 +9,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20210902135810_add-status-column-on-campaign-participations.js b/api/db/migrations/20210902135810_add-status-column-on-campaign-participations.js index 241d5ed82a5..77aac35dc63 100644 --- a/api/db/migrations/20210902135810_add-status-column-on-campaign-participations.js +++ b/api/db/migrations/20210902135810_add-status-column-on-campaign-participations.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'campaign-participations'; const COLUMN_NAME = 'status'; const DEFAULT_COLUMN_VALUE = 'STARTED'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME).defaultTo(DEFAULT_COLUMN_VALUE); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210907094748_add-column-has-seen-other-challenges-tooltip-to-users-table.js b/api/db/migrations/20210907094748_add-column-has-seen-other-challenges-tooltip-to-users-table.js index be07dd32446..98f56cd7d65 100644 --- a/api/db/migrations/20210907094748_add-column-has-seen-other-challenges-tooltip-to-users-table.js +++ b/api/db/migrations/20210907094748_add-column-has-seen-other-challenges-tooltip-to-users-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'hasSeenOtherChallengesTooltip'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210908085902_add-method-column-in-assessments.js b/api/db/migrations/20210908085902_add-method-column-in-assessments.js index 3733b3f6927..bddd83de99b 100644 --- a/api/db/migrations/20210908085902_add-method-column-in-assessments.js +++ b/api/db/migrations/20210908085902_add-method-column-in-assessments.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'assessments'; const COLUMN_NAME = 'method'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.text(COLUMN_NAME); }); @@ -26,8 +26,10 @@ exports.up = async function (knex) { } }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210916120235_update-badges-imageUrl-to-url-with-pix-domain.js b/api/db/migrations/20210916120235_update-badges-imageUrl-to-url-with-pix-domain.js index 22051a41340..2d4f170ec99 100644 --- a/api/db/migrations/20210916120235_update-badges-imageUrl-to-url-with-pix-domain.js +++ b/api/db/migrations/20210916120235_update-badges-imageUrl-to-url-with-pix-domain.js @@ -3,13 +3,15 @@ const COLUMN_NAME = 'imageUrl'; const OVH_URL = 'https://storage.gra.cloud.ovh.net/v1/AUTH_27c5a6d3d35841a5914c7fb9a8e96345/pix-images'; const PIX_URL = 'https://images.pix.fr'; -exports.up = function (knex) { +const up = function (knex) { // eslint-disable-next-line knex/avoid-injections return knex.raw( `UPDATE ${TABLE_NAME} SET "${COLUMN_NAME}" = REPLACE("${COLUMN_NAME}", '${OVH_URL}', '${PIX_URL}') WHERE "${COLUMN_NAME}" LIKE '${OVH_URL}%';` ); }; -exports.down = function () { +const down = function () { return; }; + +export { up, down }; diff --git a/api/db/migrations/20210917121620_add-hasBeenSkippedAutomatically-in-certification-chalenge-table.js b/api/db/migrations/20210917121620_add-hasBeenSkippedAutomatically-in-certification-chalenge-table.js index 356d7d9588e..7bd760b061c 100644 --- a/api/db/migrations/20210917121620_add-hasBeenSkippedAutomatically-in-certification-chalenge-table.js +++ b/api/db/migrations/20210917121620_add-hasBeenSkippedAutomatically-in-certification-chalenge-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-challenges'; const COLUMN_NAME = 'hasBeenSkippedAutomatically'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210917162014_add-column-visible-to-badges-table.js b/api/db/migrations/20210917162014_add-column-visible-to-badges-table.js index f17cf2f5f38..21bcd11bef9 100644 --- a/api/db/migrations/20210917162014_add-column-visible-to-badges-table.js +++ b/api/db/migrations/20210917162014_add-column-visible-to-badges-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'badges'; const TITLE_COLUMN = 'isAlwaysVisible'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(TITLE_COLUMN).notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(TITLE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210920153452_add-column-focusedout-to-answers.js b/api/db/migrations/20210920153452_add-column-focusedout-to-answers.js index 72c653f49f4..2630f3dfacb 100644 --- a/api/db/migrations/20210920153452_add-column-focusedout-to-answers.js +++ b/api/db/migrations/20210920153452_add-column-focusedout-to-answers.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'answers'; const COLUMN_NAME = 'isFocusedOut'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20210922124114_rename-masteryPercentage-to-masteryRate.js b/api/db/migrations/20210922124114_rename-masteryPercentage-to-masteryRate.js index c09d1827c22..bcf272e06d1 100644 --- a/api/db/migrations/20210922124114_rename-masteryPercentage-to-masteryRate.js +++ b/api/db/migrations/20210922124114_rename-masteryPercentage-to-masteryRate.js @@ -2,10 +2,12 @@ const TABLE_NAME = 'campaign-participations'; const OLD_COLUMN_NAME = 'masteryPercentage'; const NEW_COLUMN_NAME = 'masteryRate'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(OLD_COLUMN_NAME, NEW_COLUMN_NAME)); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20211008153516_remove-is-shared-column.js b/api/db/migrations/20211008153516_remove-is-shared-column.js index cae8afdd1a0..4964104a2bd 100644 --- a/api/db/migrations/20211008153516_remove-is-shared-column.js +++ b/api/db/migrations/20211008153516_remove-is-shared-column.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaign-participations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn('isShared'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string('isShared'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211012123226_rename-badge-partner-competences-to-skillsets.js b/api/db/migrations/20211012123226_rename-badge-partner-competences-to-skillsets.js index 03777572571..c2558ede5c4 100644 --- a/api/db/migrations/20211012123226_rename-badge-partner-competences-to-skillsets.js +++ b/api/db/migrations/20211012123226_rename-badge-partner-competences-to-skillsets.js @@ -4,12 +4,14 @@ const NEW_TABLE_NAME = 'skill-sets'; const OLD_COLUMN_NAME = 'partnerCompetenceIds'; const NEW_COLUMN_NAME = 'skillSetIds'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.renameTable(OLD_TABLE_NAME, NEW_TABLE_NAME); return knex.schema.table('badge-criteria', (t) => t.renameColumn(OLD_COLUMN_NAME, NEW_COLUMN_NAME)); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.renameTable(NEW_TABLE_NAME, OLD_TABLE_NAME); return knex.schema.table('badge-criteria', (t) => t.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20211019121329_add_session_password.js b/api/db/migrations/20211019121329_add_session_password.js index 6bc387fa657..c81826fad7b 100644 --- a/api/db/migrations/20211019121329_add_session_password.js +++ b/api/db/migrations/20211019121329_add_session_password.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME = 'supervisorPassword'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME, 5); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211025132405_create-table-complementary-certifications.js b/api/db/migrations/20211025132405_create-table-complementary-certifications.js index fc060c03ef6..f78fdad1ab3 100644 --- a/api/db/migrations/20211025132405_create-table-complementary-certifications.js +++ b/api/db/migrations/20211025132405_create-table-complementary-certifications.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.createTable('complementary-certifications', (t) => { t.increments().primary(); t.string('name').notNullable(); @@ -17,6 +17,8 @@ exports.up = async function (knex) { } }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable('complementary-certifications'); }; + +export { up, down }; diff --git a/api/db/migrations/20211025155811_create-table-complementary-certification-habilitations.js b/api/db/migrations/20211025155811_create-table-complementary-certification-habilitations.js index bcae57dc214..6d931b269b2 100644 --- a/api/db/migrations/20211025155811_create-table-complementary-certification-habilitations.js +++ b/api/db/migrations/20211025155811_create-table-complementary-certification-habilitations.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.createTable('complementary-certification-habilitations', (t) => { t.increments().primary(); t.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); @@ -30,6 +30,8 @@ exports.up = async function (knex) { } }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable('complementary-certification-habilitations'); }; + +export { up, down }; diff --git a/api/db/migrations/20211025155926_create-table-complementary-certification-badges.js b/api/db/migrations/20211025155926_create-table-complementary-certification-badges.js index 3cd195b6636..23af1a2e2aa 100644 --- a/api/db/migrations/20211025155926_create-table-complementary-certification-badges.js +++ b/api/db/migrations/20211025155926_create-table-complementary-certification-badges.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.createTable('complementary-certification-badges', (t) => { t.increments().primary(); t.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); @@ -26,6 +26,8 @@ exports.up = async function (knex) { } }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable('complementary-certification-badges'); }; + +export { up, down }; diff --git a/api/db/migrations/20211029094139_add-candidate-in-session-status.js b/api/db/migrations/20211029094139_add-candidate-in-session-status.js index 3693d3086e7..e18c487df01 100644 --- a/api/db/migrations/20211029094139_add-candidate-in-session-status.js +++ b/api/db/migrations/20211029094139_add-candidate-in-session-status.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-candidates'; const TITLE_COLUMN = 'authorizedToStart'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(TITLE_COLUMN).notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(TITLE_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211029181054_set-certification-center-type-as-not-null.js b/api/db/migrations/20211029181054_set-certification-center-type-as-not-null.js index 97c1ab56daa..54c41a1e85b 100644 --- a/api/db/migrations/20211029181054_set-certification-center-type-as-not-null.js +++ b/api/db/migrations/20211029181054_set-certification-center-type-as-not-null.js @@ -1,7 +1,9 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.raw('ALTER TABLE "certification-centers" ALTER COLUMN "type" SET NOT NULL'); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw('ALTER TABLE "certification-centers" ALTER COLUMN "type" DROP NOT NULL'); }; + +export { up, down }; diff --git a/api/db/migrations/20211103094329_create-table-supervisor-accesses.js b/api/db/migrations/20211103094329_create-table-supervisor-accesses.js index ebd45ace4f4..aea3c0687c1 100644 --- a/api/db/migrations/20211103094329_create-table-supervisor-accesses.js +++ b/api/db/migrations/20211103094329_create-table-supervisor-accesses.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'supervisor-accesses'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('sessionId').references('sessions.id').notNullable(); @@ -9,6 +9,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20211108140716_create-table-complementary-certification-subscriptions.js b/api/db/migrations/20211108140716_create-table-complementary-certification-subscriptions.js index 53dd03e8923..4b32b6218d7 100644 --- a/api/db/migrations/20211108140716_create-table-complementary-certification-subscriptions.js +++ b/api/db/migrations/20211108140716_create-table-complementary-certification-subscriptions.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'complementary-certification-subscriptions'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.integer('complementaryCertificationId').references('complementary-certifications.id').notNullable(); t.integer('certificationCandidateId').references('certification-candidates.id').notNullable(); @@ -8,6 +8,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20211112093024_add-description-in-target-profiles.js b/api/db/migrations/20211112093024_add-description-in-target-profiles.js index 3f60d6c848e..ae3de3decf0 100644 --- a/api/db/migrations/20211112093024_add-description-in-target-profiles.js +++ b/api/db/migrations/20211112093024_add-description-in-target-profiles.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'target-profiles'; const COLUMN_NAME = 'description'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211112144138_add_updatedAt_column_to_certification_centers_table.js b/api/db/migrations/20211112144138_add_updatedAt_column_to_certification_centers_table.js index 97472b3f553..2ddabbf9923 100644 --- a/api/db/migrations/20211112144138_add_updatedAt_column_to_certification_centers_table.js +++ b/api/db/migrations/20211112144138_add_updatedAt_column_to_certification_centers_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-centers'; const UPDATED_AT_COLUMN = 'updatedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(UPDATED_AT_COLUMN).notNullable().defaultTo(knex.fn.now()); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(UPDATED_AT_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211116091730_add_user_agent_to_feedbacks.js b/api/db/migrations/20211116091730_add_user_agent_to_feedbacks.js index 26efe0b3afc..254b210c74c 100644 --- a/api/db/migrations/20211116091730_add_user_agent_to_feedbacks.js +++ b/api/db/migrations/20211116091730_add_user_agent_to_feedbacks.js @@ -1,11 +1,13 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table('feedbacks', function (table) { table.string('userAgent'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('feedbacks', (table) => { table.dropColumn('userAgent'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211118141612_add-private-comments-on-target-profile.js b/api/db/migrations/20211118141612_add-private-comments-on-target-profile.js index ef9a24fb973..6524f1f7913 100644 --- a/api/db/migrations/20211118141612_add-private-comments-on-target-profile.js +++ b/api/db/migrations/20211118141612_add-private-comments-on-target-profile.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'target-profiles'; const COMMENT = 'comment'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.text(COMMENT); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COMMENT); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211122131317_create-table-complementary-certification-courses.js b/api/db/migrations/20211122131317_create-table-complementary-certification-courses.js index e1e013be634..085c018b3a5 100644 --- a/api/db/migrations/20211122131317_create-table-complementary-certification-courses.js +++ b/api/db/migrations/20211122131317_create-table-complementary-certification-courses.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'complementary-certification-courses'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.integer('complementaryCertificationId').references('complementary-certifications.id').notNullable(); t.integer('certificationCourseId').references('certification-courses.id').notNullable(); @@ -8,6 +8,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20211123133135_resole-existing-certification-issue-reports.js b/api/db/migrations/20211123133135_resole-existing-certification-issue-reports.js index 03621519f95..33624bbbe1c 100644 --- a/api/db/migrations/20211123133135_resole-existing-certification-issue-reports.js +++ b/api/db/migrations/20211123133135_resole-existing-certification-issue-reports.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw(`UPDATE "certification-issue-reports" SET "resolvedAt" = NOW() WHERE id IN @@ -12,6 +12,8 @@ exports.up = async function (knex) { )`); }; -exports.down = function () { +const down = function () { return; }; + +export { up, down }; diff --git a/api/db/migrations/20211126144130_add-disabled-at-column-in-certification-center-memberships-table.js b/api/db/migrations/20211126144130_add-disabled-at-column-in-certification-center-memberships-table.js index 233a9fa7f30..302a298970f 100644 --- a/api/db/migrations/20211126144130_add-disabled-at-column-in-certification-center-memberships-table.js +++ b/api/db/migrations/20211126144130_add-disabled-at-column-in-certification-center-memberships-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-center-memberships'; const DISABLED_AT_COLUMN = 'disabledAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(DISABLED_AT_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(DISABLED_AT_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211130133233_add_lastPixOrgaTermsOfServiceValidatedAt_column_to_users_table.js b/api/db/migrations/20211130133233_add_lastPixOrgaTermsOfServiceValidatedAt_column_to_users_table.js index b1eff9d20d1..a73c1f8d385 100644 --- a/api/db/migrations/20211130133233_add_lastPixOrgaTermsOfServiceValidatedAt_column_to_users_table.js +++ b/api/db/migrations/20211130133233_add_lastPixOrgaTermsOfServiceValidatedAt_column_to_users_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'lastPixOrgaTermsOfServiceValidatedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211201102703_add_lastPixCertifTermsOfServiceValidatedAt_column_to_users_table.js b/api/db/migrations/20211201102703_add_lastPixCertifTermsOfServiceValidatedAt_column_to_users_table.js index fda1cd867e6..192f5d0bee3 100644 --- a/api/db/migrations/20211201102703_add_lastPixCertifTermsOfServiceValidatedAt_column_to_users_table.js +++ b/api/db/migrations/20211201102703_add_lastPixCertifTermsOfServiceValidatedAt_column_to_users_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'lastPixCertifTermsOfServiceValidatedAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211203133335_add_documentation_to_organization.js b/api/db/migrations/20211203133335_add_documentation_to_organization.js index 0ab4be8cddc..436052cf13a 100644 --- a/api/db/migrations/20211203133335_add_documentation_to_organization.js +++ b/api/db/migrations/20211203133335_add_documentation_to_organization.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'documentationUrl'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.text(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211208080142_drop-granted-accreditations-table.js b/api/db/migrations/20211208080142_drop-granted-accreditations-table.js index 9ec31f0c459..0a694800cd3 100644 --- a/api/db/migrations/20211208080142_drop-granted-accreditations-table.js +++ b/api/db/migrations/20211208080142_drop-granted-accreditations-table.js @@ -1,10 +1,10 @@ const TABLE_NAME = 'granted-accreditations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); @@ -12,3 +12,5 @@ exports.down = function (knex) { t.integer('certificationCenterId').references('certification-centers.id').notNullable(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211208080513_drop-accreditated-badges-table.js b/api/db/migrations/20211208080513_drop-accreditated-badges-table.js index 230de87c669..c96d07839ce 100644 --- a/api/db/migrations/20211208080513_drop-accreditated-badges-table.js +++ b/api/db/migrations/20211208080513_drop-accreditated-badges-table.js @@ -1,10 +1,10 @@ const TABLE_NAME = 'accredited-badges'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('accreditationId').references('accreditations.id').notNullable(); @@ -12,3 +12,5 @@ exports.down = (knex) => { t.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211208080645_drop-accreditations-table.js b/api/db/migrations/20211208080645_drop-accreditations-table.js index 7aca5dc7635..5fe3dda7ed9 100644 --- a/api/db/migrations/20211208080645_drop-accreditations-table.js +++ b/api/db/migrations/20211208080645_drop-accreditations-table.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'accreditations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('name').notNullable(); t.dateTime('createdAt').notNullable().defaultTo(knex.fn.now()); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211209130833_add-shownps-to-organization.js b/api/db/migrations/20211209130833_add-shownps-to-organization.js index dbea73d2ed3..2535dfc3c88 100644 --- a/api/db/migrations/20211209130833_add-shownps-to-organization.js +++ b/api/db/migrations/20211209130833_add-shownps-to-organization.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'showNPS'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.boolean(COLUMN_NAME).notNullable().defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211213103138_add-urlNPS-to-organizations.js b/api/db/migrations/20211213103138_add-urlNPS-to-organizations.js index ae66aa823ef..abb4d82eed3 100644 --- a/api/db/migrations/20211213103138_add-urlNPS-to-organizations.js +++ b/api/db/migrations/20211213103138_add-urlNPS-to-organizations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'formNPSUrl'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211220105432_add-ownerId-to-campaigns.js b/api/db/migrations/20211220105432_add-ownerId-to-campaigns.js index 16580e5a2b5..0a4cc8e71ca 100644 --- a/api/db/migrations/20211220105432_add-ownerId-to-campaigns.js +++ b/api/db/migrations/20211220105432_add-ownerId-to-campaigns.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'campaigns'; const COLUMN_NAME = 'ownerId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema .table(TABLE_NAME, function (table) { table.bigInteger(COLUMN_NAME).references('users.id'); @@ -16,8 +16,10 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20211223092838_create-flash-assessment-results.js b/api/db/migrations/20211223092838_create-flash-assessment-results.js index fd6e67d4de1..c518e7d26e0 100644 --- a/api/db/migrations/20211223092838_create-flash-assessment-results.js +++ b/api/db/migrations/20211223092838_create-flash-assessment-results.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'flash-assessment-results'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('assessmentId').references('assessments.id').notNullable().unique(); @@ -9,6 +9,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20211223110017_add-category-to-target-profiles.js b/api/db/migrations/20211223110017_add-category-to-target-profiles.js index 4821a90c831..101ee22ae60 100644 --- a/api/db/migrations/20211223110017_add-category-to-target-profiles.js +++ b/api/db/migrations/20211223110017_add-category-to-target-profiles.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'target-profiles'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string('category').defaultTo('OTHER'); }); @@ -8,8 +8,10 @@ exports.up = async function (knex) { await knex(TABLE_NAME).where({ isPublic: true }).update({ category: 'COMPETENCES' }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('category'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220105132942_alter-creatorId-from-campaigns-to-be-not-nullable.js b/api/db/migrations/20220105132942_alter-creatorId-from-campaigns-to-be-not-nullable.js index d8e679dcf9e..960c4d32bd4 100644 --- a/api/db/migrations/20220105132942_alter-creatorId-from-campaigns-to-be-not-nullable.js +++ b/api/db/migrations/20220105132942_alter-creatorId-from-campaigns-to-be-not-nullable.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaigns'; const COLUMN_NAME = 'creatorId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).notNullable().alter(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.integer(COLUMN_NAME).nullable().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220106130955_add-showskills-to-organizations.js b/api/db/migrations/20220106130955_add-showskills-to-organizations.js index 48c902ad5a3..0e39f4b6db2 100644 --- a/api/db/migrations/20220106130955_add-showskills-to-organizations.js +++ b/api/db/migrations/20220106130955_add-showskills-to-organizations.js @@ -1,14 +1,17 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'showSkills'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).notNullable().defaultTo(false); }); await knex(TABLE_NAME).whereIn('type', ['SUP', 'PRO']).update({ showSkills: true }); }; -exports.down = async function (knex) { + +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220111143029_add-schooling-registration-id-campaign-participation.js b/api/db/migrations/20220111143029_add-schooling-registration-id-campaign-participation.js index bb52d85c360..8b2357ae541 100644 --- a/api/db/migrations/20220111143029_add-schooling-registration-id-campaign-participation.js +++ b/api/db/migrations/20220111143029_add-schooling-registration-id-campaign-participation.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'campaign-participations'; const REFERENCE_TABLE_NAME = 'schooling-registrations'; const COLUMN_NAME = 'schoolingRegistrationId'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.integer(COLUMN_NAME).references(`${REFERENCE_TABLE_NAME}.id`).defaultTo(null); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220118153609_update_pix_edu_badge_keys.js b/api/db/migrations/20220118153609_update_pix_edu_badge_keys.js index 89549583d20..1df45d7eee4 100644 --- a/api/db/migrations/20220118153609_update_pix_edu_badge_keys.js +++ b/api/db/migrations/20220118153609_update_pix_edu_badge_keys.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.alterTable('partner-certifications', (table) => { table.dropForeign(null, 'certification_partner_acquisitions_partnerkey_foreign'); }); @@ -43,7 +43,7 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.alterTable('partner-certifications', (table) => { table.dropForeign('partnerKey'); }); @@ -87,3 +87,5 @@ exports.down = async function (knex) { table.foreign(null, 'certification_partner_acquisitions_partnerkey_foreign').references('key').inTable('badges'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220127154426_add-billing-columns-to-certification-candidate.js b/api/db/migrations/20220127154426_add-billing-columns-to-certification-candidate.js index 51df260ceeb..ffafc2a401f 100644 --- a/api/db/migrations/20220127154426_add-billing-columns-to-certification-candidate.js +++ b/api/db/migrations/20220127154426_add-billing-columns-to-certification-candidate.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-candidates'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.text('billingMode').defaultsTo(null); table.text('prepaymentCode').defaultsTo(null); @@ -11,9 +11,11 @@ exports.up = async function (knex) { ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.dropColumn('billingMode'); table.dropColumn('prepaymentCode'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220128223044_add-certification-center-isSupervisorAccessEnabled.js b/api/db/migrations/20220128223044_add-certification-center-isSupervisorAccessEnabled.js index ed211e55e4e..bae10961180 100644 --- a/api/db/migrations/20220128223044_add-certification-center-isSupervisorAccessEnabled.js +++ b/api/db/migrations/20220128223044_add-certification-center-isSupervisorAccessEnabled.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-centers'; const COLUMN_NAME = 'isSupervisorAccessEnabled'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).notNullable().defaultTo(false); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220202140419_flash-assessment-result-history.js b/api/db/migrations/20220202140419_flash-assessment-result-history.js index fd03d39429f..89ae0f249f8 100644 --- a/api/db/migrations/20220202140419_flash-assessment-result-history.js +++ b/api/db/migrations/20220202140419_flash-assessment-result-history.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'flash-assessment-results'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.raw('alter table "flash-assessment-results" alter column id type bigint'); await knex.schema.table(TABLE_NAME, (t) => { @@ -22,7 +22,7 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex(TABLE_NAME) .whereIn( 'answerId', @@ -59,3 +59,5 @@ exports.down = async function (knex) { t.dropColumn('answerId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220204111119_replace-empty-string-by-null-for-custom-landing-page-text.js b/api/db/migrations/20220204111119_replace-empty-string-by-null-for-custom-landing-page-text.js index 756fc610d38..59bff1029e0 100644 --- a/api/db/migrations/20220204111119_replace-empty-string-by-null-for-custom-landing-page-text.js +++ b/api/db/migrations/20220204111119_replace-empty-string-by-null-for-custom-landing-page-text.js @@ -1,7 +1,9 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex('campaigns').where({ customLandingPageText: '' }).update({ customLandingPageText: null }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex('campaigns').where({ customLandingPageText: null }).update({ customLandingPageText: '' }); }; + +export { up, down }; diff --git a/api/db/migrations/20220209161348_drop-birthdate-constraint-on-schooling-registrations.js b/api/db/migrations/20220209161348_drop-birthdate-constraint-on-schooling-registrations.js index 16d9bd44c22..e9594a7ec30 100644 --- a/api/db/migrations/20220209161348_drop-birthdate-constraint-on-schooling-registrations.js +++ b/api/db/migrations/20220209161348_drop-birthdate-constraint-on-schooling-registrations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'schooling-registrations'; const COLUMN_NAME = 'birthdate'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.date(COLUMN_NAME).nullable().alter(); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.date(COLUMN_NAME).notNullable().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220221103255_update-unique-constraint-on-certification-center-memberships.js b/api/db/migrations/20220221103255_update-unique-constraint-on-certification-center-memberships.js index d3202a88d64..f45f2dca1b2 100644 --- a/api/db/migrations/20220221103255_update-unique-constraint-on-certification-center-memberships.js +++ b/api/db/migrations/20220221103255_update-unique-constraint-on-certification-center-memberships.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table('certification-center-memberships', function (table) { table.dropUnique(['userId', 'certificationCenterId']); }); @@ -7,9 +7,11 @@ exports.up = async function (knex) { ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table('certification-center-memberships', function (table) { table.dropUnique(null, 'certification-center-memberships_userid_certificationcenterid_disabledAt_unique'); table.unique(['userId', 'certificationCenterId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220225130743_rename-user-tutorials-to-user-saved-tutorials.js b/api/db/migrations/20220225130743_rename-user-tutorials-to-user-saved-tutorials.js index ae35f688427..cba234e7b59 100644 --- a/api/db/migrations/20220225130743_rename-user-tutorials-to-user-saved-tutorials.js +++ b/api/db/migrations/20220225130743_rename-user-tutorials-to-user-saved-tutorials.js @@ -1,24 +1,28 @@ -/* eslint-disable knex/avoid-injections */ const OLD_TABLE_NAME = 'user_tutorials'; const NEW_TABLE_NAME = 'user-saved-tutorials'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.renameTable(OLD_TABLE_NAME, NEW_TABLE_NAME); + // eslint-disable-next-line knex/avoid-injections await knex.raw( `ALTER TABLE "${NEW_TABLE_NAME}" RENAME CONSTRAINT "${OLD_TABLE_NAME}_pkey" TO "${NEW_TABLE_NAME}_pkey"` ); + // eslint-disable-next-line knex/avoid-injections await knex.raw( `ALTER TABLE "${NEW_TABLE_NAME}" RENAME CONSTRAINT "${OLD_TABLE_NAME}_userid_tutorialid_unique" TO "${NEW_TABLE_NAME}_userid_tutorialid_unique"` ); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.renameTable(NEW_TABLE_NAME, OLD_TABLE_NAME); + // eslint-disable-next-line knex/avoid-injections await knex.raw( `ALTER TABLE "${OLD_TABLE_NAME}" RENAME CONSTRAINT "${NEW_TABLE_NAME}_pkey" TO "${OLD_TABLE_NAME}_pkey"` ); + // eslint-disable-next-line knex/avoid-injections await knex.raw( `ALTER TABLE "${OLD_TABLE_NAME}" RENAME CONSTRAINT "${NEW_TABLE_NAME}_userid_tutorialid_unique" TO "${OLD_TABLE_NAME}_userid_tutorialid_unique"` ); }; -/* eslint-enable knex/avoid-injections */ + +export { up, down }; diff --git a/api/db/migrations/20220225145933_add-skillid-in-user-saved-tutorials.js b/api/db/migrations/20220225145933_add-skillid-in-user-saved-tutorials.js index aa6105871de..70c691b06b1 100644 --- a/api/db/migrations/20220225145933_add-skillid-in-user-saved-tutorials.js +++ b/api/db/migrations/20220225145933_add-skillid-in-user-saved-tutorials.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'user-saved-tutorials'; const COLUMN_NAME = 'skillId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.string(COLUMN_NAME).defaultTo(null); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220228135813_add-archived-at-and-archived-by-columns-on-organizations-table.js b/api/db/migrations/20220228135813_add-archived-at-and-archived-by-columns-on-organizations-table.js index 3cdf7114818..5ca78ffba72 100644 --- a/api/db/migrations/20220228135813_add-archived-at-and-archived-by-columns-on-organizations-table.js +++ b/api/db/migrations/20220228135813_add-archived-at-and-archived-by-columns-on-organizations-table.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'organizations'; const ARCHIVED_AT = 'archivedAt'; const ARCHIVED_BY = 'archivedBy'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => { table.dateTime(ARCHIVED_AT).nullable(); table.bigInteger(ARCHIVED_BY).nullable().references('users.id'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(ARCHIVED_AT); table.dropColumn(ARCHIVED_BY); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220228150453_delete-can-collect-profile-column.js b/api/db/migrations/20220228150453_delete-can-collect-profile-column.js index 7eb4e9c3be3..2d3e04a551e 100644 --- a/api/db/migrations/20220228150453_delete-can-collect-profile-column.js +++ b/api/db/migrations/20220228150453_delete-can-collect-profile-column.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organizations'; const COLUMN = 'canCollectProfiles'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => { table.dropColumn(COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => { table.boolean(COLUMN).notNullable().defaultTo(false); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220228154928_rename-table-schooling-registrations-by-organization-learners.js b/api/db/migrations/20220228154928_rename-table-schooling-registrations-by-organization-learners.js index 5dc0521898c..a852218db27 100644 --- a/api/db/migrations/20220228154928_rename-table-schooling-registrations-by-organization-learners.js +++ b/api/db/migrations/20220228154928_rename-table-schooling-registrations-by-organization-learners.js @@ -1,10 +1,12 @@ const OLD_TABLE_NAME = 'schooling-registrations'; const NEW_TABLE_NAME = 'organization-learners'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.renameTable(OLD_TABLE_NAME, NEW_TABLE_NAME); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.renameTable(NEW_TABLE_NAME, OLD_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220302101303_add-deletedat-deletedby-on-campaign-participations.js b/api/db/migrations/20220302101303_add-deletedat-deletedby-on-campaign-participations.js index 646d0db83bc..28eace84eba 100644 --- a/api/db/migrations/20220302101303_add-deletedat-deletedby-on-campaign-participations.js +++ b/api/db/migrations/20220302101303_add-deletedat-deletedby-on-campaign-participations.js @@ -8,7 +8,7 @@ const CAMPAIGNID_COLUMN = 'campaignId'; const NEW_CONSTRAINT_NAME = 'campaign_participations_campaignid_userid_isimproved_deleted'; const OLD_CONSTRAINT_NAME = 'campaign_participations_campaignid_userid_isimproved'; -exports.up = async function (knex) { +const up = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw(`DROP INDEX ${OLD_CONSTRAINT_NAME};`); @@ -23,7 +23,7 @@ exports.up = async function (knex) { ); }; -exports.down = async function (knex) { +const down = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw(`DROP INDEX ${NEW_CONSTRAINT_NAME};`); @@ -37,3 +37,5 @@ exports.down = async function (knex) { `CREATE UNIQUE INDEX ${OLD_CONSTRAINT_NAME} ON "${TABLE_NAME}" ("${CAMPAIGNID_COLUMN}", "${USERID_COLUMN}" ) WHERE "${ISIMPROVED_COLUMN}" IS FALSE;` ); }; + +export { up, down }; diff --git a/api/db/migrations/20220303094934_add-column-temporary-partner-key-in-partner-certifications-and-populate-it.js b/api/db/migrations/20220303094934_add-column-temporary-partner-key-in-partner-certifications-and-populate-it.js index d1e8ca23606..ccaac07ca0d 100644 --- a/api/db/migrations/20220303094934_add-column-temporary-partner-key-in-partner-certifications-and-populate-it.js +++ b/api/db/migrations/20220303094934_add-column-temporary-partner-key-in-partner-certifications-and-populate-it.js @@ -1,10 +1,11 @@ +import { badges } from '../constants.js'; const { PIX_EDU_FORMATION_INITIALE_2ND_DEGRE_INITIE, PIX_EDU_FORMATION_INITIALE_2ND_DEGRE_CONFIRME, PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_CONFIRME, PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_AVANCE, PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_EXPERT, -} = require('../constants').badges.keys; +} = badges.keys; const pixEduBadges = [ PIX_EDU_FORMATION_INITIALE_2ND_DEGRE_INITIE, @@ -16,7 +17,7 @@ const pixEduBadges = [ .map((badge) => `'${badge}'`) .join(','); -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.alterTable('partner-certifications', function (table) { table.string('partnerKey').nullable().alter(); table.string('temporaryPartnerKey').references('badges.key').nullable(); @@ -28,7 +29,7 @@ exports.up = async function (knex) { ); }; -exports.down = async function (knex) { +const down = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw( `UPDATE "partner-certifications" SET "partnerKey" = "temporaryPartnerKey" WHERE "temporaryPartnerKey" IN (${pixEduBadges})` @@ -39,3 +40,5 @@ exports.down = async function (knex) { table.string('partnerKey').notNullable().alter(); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220303102116_rename-schooling-registration-id-to-organization-learner-id.js b/api/db/migrations/20220303102116_rename-schooling-registration-id-to-organization-learner-id.js index a203a9f46a6..59df819322d 100644 --- a/api/db/migrations/20220303102116_rename-schooling-registration-id-to-organization-learner-id.js +++ b/api/db/migrations/20220303102116_rename-schooling-registration-id-to-organization-learner-id.js @@ -4,7 +4,7 @@ const CAMPAIGN_PARTICIPATIONS = 'campaign-participations'; const OLD_COLUMN_NAME = 'schoolingRegistrationId'; const NEW_COLUMN_NAME = 'organizationLearnerId'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(ACCOUNT_RECOVERY_DEMANDS, (table) => table.renameColumn(OLD_COLUMN_NAME, NEW_COLUMN_NAME)); await knex.schema.table(CERTIFICATION_CANDIDATES, (table) => { @@ -19,7 +19,7 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(ACCOUNT_RECOVERY_DEMANDS, (table) => table.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME)); await knex.schema.table(CERTIFICATION_CANDIDATES, (table) => { @@ -33,3 +33,5 @@ exports.down = async function (knex) { table.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220325144812_add-complementary-certification-courses-table.js b/api/db/migrations/20220325144812_add-complementary-certification-courses-table.js index 49a9d037ea2..94e32adc894 100644 --- a/api/db/migrations/20220325144812_add-complementary-certification-courses-table.js +++ b/api/db/migrations/20220325144812_add-complementary-certification-courses-table.js @@ -1,13 +1,15 @@ const COMPLEMENTARY_CERTIFICATION_COURSES_TABLE_NAME = 'complementary-certification-courses'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(COMPLEMENTARY_CERTIFICATION_COURSES_TABLE_NAME, async (table) => { table.increments('id').primary(); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(COMPLEMENTARY_CERTIFICATION_COURSES_TABLE_NAME, async (table) => { table.dropColumn('id'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220328102300_rename_partner-certification.js b/api/db/migrations/20220328102300_rename_partner-certification.js index 07347ce1c54..6d730c9c285 100644 --- a/api/db/migrations/20220328102300_rename_partner-certification.js +++ b/api/db/migrations/20220328102300_rename_partner-certification.js @@ -1,10 +1,12 @@ const OLD_TABLE_NAME = 'partner-certifications'; const COMPLEMENTARY_CERTIFICATION_COURSE_RESULTS_TABLE = 'complementary-certification-course-results'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.renameTable(OLD_TABLE_NAME, COMPLEMENTARY_CERTIFICATION_COURSE_RESULTS_TABLE); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.renameTable(COMPLEMENTARY_CERTIFICATION_COURSE_RESULTS_TABLE, OLD_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220328102301_link-complementary-certification-course-results-to-complementary-certification-courses.js b/api/db/migrations/20220328102301_link-complementary-certification-course-results-to-complementary-certification-courses.js index a59ddd0f364..2ee0002481d 100644 --- a/api/db/migrations/20220328102301_link-complementary-certification-course-results-to-complementary-certification-courses.js +++ b/api/db/migrations/20220328102301_link-complementary-certification-course-results-to-complementary-certification-courses.js @@ -3,8 +3,10 @@ const COMPLEMENTARY_CERTIFICATION_COURSES_TABLE = 'complementary-certification-c const COMPLEMENTARY_CERTIFICATION_COURSE_RESULTS_TABLE = 'complementary-certification-course-results'; const COMPLEMENTARY_CERTIFICATION_COURSE_ID_COLUMN = 'complementaryCertificationCourseId'; const CERTIFICATION_COURSE_ID = 'certificationCourseId'; -const uniqBy = require('lodash/uniqBy'); -const bluebird = require('bluebird'); +import lodash from 'lodash'; +const { uniqBy } = lodash; +import bluebird from 'bluebird'; +import { badges } from '../constants.js'; const { PIX_EMPLOI_CLEA, PIX_EMPLOI_CLEA_V2, @@ -15,13 +17,13 @@ const { PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_CONFIRME, PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_AVANCE, PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_EXPERT, -} = require('../constants').badges.keys; +} = badges.keys; const PIX_PLUS_EDU = 'Pix+ Édu'; const PIX_PLUS_DROIT = 'Pix+ Droit'; const CLEA = 'CléA Numérique'; -exports.up = async function (knex) { +const up = async function (knex) { const complementaryCertifications = await knex(COMPLEMENTARY_CERTIFICATIONS_TABLE).select('*'); await _alterComplementaryCertificationCourseResultsForeignKey(); await _addMissingComplementaryCertificationCourses(); @@ -151,7 +153,7 @@ exports.up = async function (knex) { } }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(COMPLEMENTARY_CERTIFICATION_COURSE_RESULTS_TABLE, async (table) => { table .dropColumn(COMPLEMENTARY_CERTIFICATION_COURSE_ID_COLUMN) @@ -159,3 +161,5 @@ exports.down = async function (knex) { .references('complementary-certification-courses.id'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220406083222_add_index_for_table_knowledge_elements_on_column_assessmentId.js b/api/db/migrations/20220406083222_add_index_for_table_knowledge_elements_on_column_assessmentId.js index 53ec65026f3..9aa17c160b4 100644 --- a/api/db/migrations/20220406083222_add_index_for_table_knowledge_elements_on_column_assessmentId.js +++ b/api/db/migrations/20220406083222_add_index_for_table_knowledge_elements_on_column_assessmentId.js @@ -1,9 +1,11 @@ -exports.up = (knex) => { +const up = function (knex) { return knex.raw( 'CREATE INDEX IF NOT EXISTS "knowledge-elements_assessmentId_idx" on "knowledge-elements" ("assessmentId")' ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw('DROP INDEX "knowledge-elements_assessmentId_idx"'); }; + +export { up, down }; diff --git a/api/db/migrations/20220406140150_drop-unused-index-on-userid-table-user-orga-settings.js b/api/db/migrations/20220406140150_drop-unused-index-on-userid-table-user-orga-settings.js index dfe72738836..8e31ffb7e55 100644 --- a/api/db/migrations/20220406140150_drop-unused-index-on-userid-table-user-orga-settings.js +++ b/api/db/migrations/20220406140150_drop-unused-index-on-userid-table-user-orga-settings.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'user-orga-settings'; const USERID_COLUMN = 'userId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropIndex(USERID_COLUMN); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.index(USERID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220406140553_drop-unused-index-on-owner-organization-id-table-target-profiles.js b/api/db/migrations/20220406140553_drop-unused-index-on-owner-organization-id-table-target-profiles.js index 023ec097f37..2b9c1de28bd 100644 --- a/api/db/migrations/20220406140553_drop-unused-index-on-owner-organization-id-table-target-profiles.js +++ b/api/db/migrations/20220406140553_drop-unused-index-on-owner-organization-id-table-target-profiles.js @@ -2,14 +2,16 @@ const TABLE_NAME = 'target-profiles'; const USERID_COLUMN = 'ownerOrganizationId'; const INDEX_NAME = 'target_profiles_organizationid_index'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(USERID_COLUMN, INDEX_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(USERID_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220407193857_add-column-reproducibility-rate-in-assessment-results-table.js b/api/db/migrations/20220407193857_add-column-reproducibility-rate-in-assessment-results-table.js index 06460ad558f..f2fbd3bb6dd 100644 --- a/api/db/migrations/20220407193857_add-column-reproducibility-rate-in-assessment-results-table.js +++ b/api/db/migrations/20220407193857_add-column-reproducibility-rate-in-assessment-results-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'assessment-results'; const COLUMN_NAME = 'reproducibilityRate'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.decimal(COLUMN_NAME, 5, 2).defaultTo(null); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220411134827_add-column-source-to-complementary-certification-results.js b/api/db/migrations/20220411134827_add-column-source-to-complementary-certification-results.js index 4e75af74c66..d3029a9700f 100644 --- a/api/db/migrations/20220411134827_add-column-source-to-complementary-certification-results.js +++ b/api/db/migrations/20220411134827_add-column-source-to-complementary-certification-results.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'complementary-certification-course-results'; const COLUMN_NAME = 'source'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME).defaultTo('PIX').notNullable(); }); @@ -12,8 +12,10 @@ exports.up = async function (knex) { `); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220411140819_migrate-complementary-certification-results-sources.js b/api/db/migrations/20220411140819_migrate-complementary-certification-results-sources.js index d8537e8f428..b43276e71f4 100644 --- a/api/db/migrations/20220411140819_migrate-complementary-certification-results-sources.js +++ b/api/db/migrations/20220411140819_migrate-complementary-certification-results-sources.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'complementary-certification-course-results'; const TEMPORARY_PARTNER_KEY_COLUMN_NAME = 'temporaryPartnerKey'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw(` INSERT INTO "complementary-certification-course-results" ("partnerKey", "complementaryCertificationCourseId", "acquired", "source") SELECT "partnerKey", "complementaryCertificationCourseId", "acquired", 'EXTERNAL' @@ -21,7 +21,7 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string(TEMPORARY_PARTNER_KEY_COLUMN_NAME).references('badges.key').nullable(); }); @@ -56,3 +56,5 @@ exports.down = async function (knex) { WHERE "source" = 'EXTERNAL' `); }; + +export { up, down }; diff --git a/api/db/migrations/20220412085737_update-table-from-users-pix-roles-to-pix-admin-roles.js b/api/db/migrations/20220412085737_update-table-from-users-pix-roles-to-pix-admin-roles.js index be5020ed973..832d0c711c9 100644 --- a/api/db/migrations/20220412085737_update-table-from-users-pix-roles-to-pix-admin-roles.js +++ b/api/db/migrations/20220412085737_update-table-from-users-pix-roles-to-pix-admin-roles.js @@ -8,7 +8,7 @@ const OLD_COLUMN_NAME = 'user_id'; const NEW_COLUMN_NAME = 'userId'; const COLUMN_TO_DELETE = 'pix_role_id'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.renameTable(OLD_TABLE_NAME, NEW_TABLE_NAME); await knex.schema.table(NEW_TABLE_NAME, (table) => { table.string(ROLE_COLUMN); @@ -31,7 +31,7 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.renameTable(NEW_TABLE_NAME, OLD_TABLE_NAME); await knex.schema.table(OLD_TABLE_NAME, (table) => { @@ -42,3 +42,5 @@ exports.down = async function (knex) { table.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220412092214_delete-pix-roles-table.js b/api/db/migrations/20220412092214_delete-pix-roles-table.js index f69c1ce0a0a..cdb318230a7 100644 --- a/api/db/migrations/20220412092214_delete-pix-roles-table.js +++ b/api/db/migrations/20220412092214_delete-pix-roles-table.js @@ -2,11 +2,11 @@ const TABLE_NAME_TO_DELETE = 'pix_roles'; const TABLE_NAME_TO_UPDATE = 'pix-admin-roles'; const COLUMN_TO_DELETE = 'pix_role_id'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.dropTable(TABLE_NAME_TO_DELETE); }; -exports.down = async (knex) => { +const down = async function (knex) { await knex.schema.createTable(TABLE_NAME_TO_DELETE, (table) => { table.increments('id').primary(); table.string('name').notNull(); @@ -18,3 +18,5 @@ exports.down = async (knex) => { table.bigInteger(COLUMN_TO_DELETE).defaultTo(pixRoleId).references(`${TABLE_NAME_TO_DELETE}.id`); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220415083318_add-organization-places-table.js b/api/db/migrations/20220415083318_add-organization-places-table.js index 27ceb989d7a..8ab98bc5fe2 100644 --- a/api/db/migrations/20220415083318_add-organization-places-table.js +++ b/api/db/migrations/20220415083318_add-organization-places-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'organization-places'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('count'); @@ -14,6 +14,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220415140322_add-extension-for-pgboss.js b/api/db/migrations/20220415140322_add-extension-for-pgboss.js index ab352a38793..8cad2a8a3af 100644 --- a/api/db/migrations/20220415140322_add-extension-for-pgboss.js +++ b/api/db/migrations/20220415140322_add-extension-for-pgboss.js @@ -1,7 +1,9 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('CREATE EXTENSION IF NOT EXISTS pgcrypto;'); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('DROP EXTENSION IF EXISTS pgcrypto;'); }; + +export { up, down }; diff --git a/api/db/migrations/20220427094148_add-check-constraint-on-pix-admin-roles.js b/api/db/migrations/20220427094148_add-check-constraint-on-pix-admin-roles.js index 1229cac37d6..ede61a9d17c 100644 --- a/api/db/migrations/20220427094148_add-check-constraint-on-pix-admin-roles.js +++ b/api/db/migrations/20220427094148_add-check-constraint-on-pix-admin-roles.js @@ -1,9 +1,11 @@ -exports.up = function (knex) { +const up = function (knex) { return knex.raw( "ALTER TABLE \"pix-admin-roles\" ADD CONSTRAINT \"pix-admin-roles_role_check\" CHECK ( \"role\" IN ('SUPER_ADMIN', 'SUPPORT', 'METIER', 'CERTIF') )" ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.raw('ALTER TABLE "pix-admin-roles" DROP CONSTRAINT "pix-admin-roles_role_check"'); }; + +export { up, down }; diff --git a/api/db/migrations/20220429143417_add-scoring-columns-to-table-complementary-certifications.js b/api/db/migrations/20220429143417_add-scoring-columns-to-table-complementary-certifications.js index f2390a3f38f..390425593ba 100644 --- a/api/db/migrations/20220429143417_add-scoring-columns-to-table-complementary-certifications.js +++ b/api/db/migrations/20220429143417_add-scoring-columns-to-table-complementary-certifications.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table('complementary-certifications', (table) => { table.decimal('minimumReproducibilityRate', 5, 2).nullable(); table.integer('minimumEarnedPix').nullable(); @@ -12,9 +12,11 @@ exports.up = async function (knex) { .where({ name: 'CléA Numérique' }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table('complementary-certifications', (table) => { table.dropColumn('minimumReproducibilityRate'); table.dropColumn('minimumEarnedPix'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220504150638_add-extension-pg-trgm.js b/api/db/migrations/20220504150638_add-extension-pg-trgm.js index cf02874d151..8c7546b1d31 100644 --- a/api/db/migrations/20220504150638_add-extension-pg-trgm.js +++ b/api/db/migrations/20220504150638_add-extension-pg-trgm.js @@ -1,7 +1,9 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('CREATE EXTENSION IF NOT EXISTS pg_trgm;'); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('DROP EXTENSION IF EXISTS pg_trgm;'); }; + +export { up, down }; diff --git a/api/db/migrations/20220506091338_add_cnav_identity_provider_to_authentication_methods_table.js b/api/db/migrations/20220506091338_add_cnav_identity_provider_to_authentication_methods_table.js index 4ce78387608..1e40b2a60c8 100644 --- a/api/db/migrations/20220506091338_add_cnav_identity_provider_to_authentication_methods_table.js +++ b/api/db/migrations/20220506091338_add_cnav_identity_provider_to_authentication_methods_table.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw( 'ALTER TABLE "authentication-methods" DROP CONSTRAINT "authentication_methods_identityProvider_check" ' ); @@ -7,7 +7,7 @@ exports.up = async function (knex) { ); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw( 'ALTER TABLE "authentication-methods" DROP CONSTRAINT "authentication_methods_identityProvider_check" ' ); @@ -15,3 +15,5 @@ exports.down = async function (knex) { 'ALTER TABLE "authentication-methods" ADD CONSTRAINT "authentication_methods_identityProvider_check" CHECK ( "identityProvider" IN (\'PIX\', \'GAR\', \'POLE_EMPLOI\') )' ); }; + +export { up, down }; diff --git a/api/db/migrations/20220510124351_create-target-profile-template-table.js b/api/db/migrations/20220510124351_create-target-profile-template-table.js index 06d38182a76..4217cc8b0d0 100644 --- a/api/db/migrations/20220510124351_create-target-profile-template-table.js +++ b/api/db/migrations/20220510124351_create-target-profile-template-table.js @@ -2,7 +2,7 @@ const TEMPLATE_TABLE_NAME = 'target-profile-templates'; const TEMPLATE_TUBES_TABLE_NAME = 'target-profile-templates_tubes'; const TARGET_PROFILE_TABLE_NAME = 'target-profiles'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.createTable(TEMPLATE_TABLE_NAME, (t) => { t.increments().primary(); }); @@ -19,10 +19,12 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TARGET_PROFILE_TABLE_NAME, (t) => { t.dropColumn('targetProfileTemplateId'); }); await knex.schema.dropTable(TEMPLATE_TUBES_TABLE_NAME); await knex.schema.dropTable(TEMPLATE_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220510152417_fix-index-knowledge-elements-assessment-id-not-compliant-knex-convention.js b/api/db/migrations/20220510152417_fix-index-knowledge-elements-assessment-id-not-compliant-knex-convention.js index ea5671d4c8c..cae5cb0b5a4 100644 --- a/api/db/migrations/20220510152417_fix-index-knowledge-elements-assessment-id-not-compliant-knex-convention.js +++ b/api/db/migrations/20220510152417_fix-index-knowledge-elements-assessment-id-not-compliant-knex-convention.js @@ -1,9 +1,8 @@ -exports.up = (knex) => { +const up = function (knex) { return knex.raw( 'ALTER INDEX IF EXISTS "knowledge-elements_assessmentId_idx" RENAME TO "knowledge_elements_assessmentid_index"' ); }; - -exports.down = function () { - // no rollback for this case -}; +// eslint-disable-next-line no-empty-function +const down = function () {}; +export { up, down }; diff --git a/api/db/migrations/20220512143417_add-unique-to-table-complementary-certification-results.js b/api/db/migrations/20220512143417_add-unique-to-table-complementary-certification-results.js index d796368e49a..b8b439f5a7e 100644 --- a/api/db/migrations/20220512143417_add-unique-to-table-complementary-certification-results.js +++ b/api/db/migrations/20220512143417_add-unique-to-table-complementary-certification-results.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'complementary-certification-course-results'; const CONSTRAINT_NAME = 'complementary-certification-course-results-cccrId-source-unique'; -exports.up = async (knex) => { +const up = async function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.unique(['complementaryCertificationCourseId', 'source'], CONSTRAINT_NAME); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['complementaryCertificationCourseId', 'source'], CONSTRAINT_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220516142918_split-pix-edu-complementary-certifications.js b/api/db/migrations/20220516142918_split-pix-edu-complementary-certifications.js index 94e46b5f887..2d090cb2ae5 100644 --- a/api/db/migrations/20220516142918_split-pix-edu-complementary-certifications.js +++ b/api/db/migrations/20220516142918_split-pix-edu-complementary-certifications.js @@ -1,12 +1,13 @@ +import { badges } from '../constants.js'; const { PIX_EDU_FORMATION_INITIALE_1ER_DEGRE_INITIE, PIX_EDU_FORMATION_INITIALE_1ER_DEGRE_CONFIRME, PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_CONFIRME, PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_AVANCE, PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_EXPERT, -} = require('../constants').badges.keys; +} = badges.keys; -exports.up = async function (knex) { +const up = async function (knex) { await knex('complementary-certifications').update({ name: 'Pix+ Édu 2nd degré' }).where({ name: 'Pix+ Édu' }); const [{ id: pixEdu1erDegreComplementaryCertificationId }] = await knex('complementary-certifications') @@ -36,7 +37,7 @@ exports.up = async function (knex) { ); }; -exports.down = async function (knex) { +const down = async function (knex) { const pixEdu1erDegreComplementaryCertificationCourseIds = await knex('complementary-certification-course-results') .select('complementaryCertificationCourseId') .distinct() @@ -70,3 +71,5 @@ exports.down = async function (knex) { await knex('complementary-certifications').update({ name: 'Pix+ Édu' }).where({ name: 'Pix+ Édu 2nd degré' }); }; + +export { up, down }; diff --git a/api/db/migrations/20220517113336_update-contraints-names-to-remove-schooling-registration-mention.js b/api/db/migrations/20220517113336_update-contraints-names-to-remove-schooling-registration-mention.js index cfb9bbf67d9..7effcbcf469 100644 --- a/api/db/migrations/20220517113336_update-contraints-names-to-remove-schooling-registration-mention.js +++ b/api/db/migrations/20220517113336_update-contraints-names-to-remove-schooling-registration-mention.js @@ -45,7 +45,7 @@ const OLD_UNIQUE_ORGANIZATION_ID_STUDENT_NUMBER_CONSTRAINT_NAME = const NEW_UNIQUE_ORGANIZATION_ID_STUDENT_NUMBER_CONSTRAINT_NAME = 'organization_learners_organizationid_studentnumber_unique'; -exports.up = async (knex) => { +const up = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw( `ALTER TABLE "${CAMPAIGN_PARTICIPATIONS_TABLE}" RENAME CONSTRAINT "${OLD_FOREIGN_KEY_IN_CAMPAIGN_PARTICIPATIONS_CONSTRAINT_NAME}" TO "${NEW_FOREIGN_KEY_IN_CAMPAIGN_PARTICIPATIONS_CONSTRAINT_NAME}";` @@ -89,7 +89,7 @@ exports.up = async (knex) => { ); }; -exports.down = async (knex) => { +const down = async function (knex) { // eslint-disable-next-line knex/avoid-injections await knex.raw( `ALTER TABLE "${CAMPAIGN_PARTICIPATIONS_TABLE}" RENAME CONSTRAINT "${NEW_FOREIGN_KEY_IN_CAMPAIGN_PARTICIPATIONS_CONSTRAINT_NAME}" TO "${OLD_FOREIGN_KEY_IN_CAMPAIGN_PARTICIPATIONS_CONSTRAINT_NAME}";` @@ -132,3 +132,5 @@ exports.down = async (knex) => { `ALTER TABLE "${ORGANIZATION_LEARNERS_TABLE}" RENAME CONSTRAINT "${NEW_UNIQUE_ORGANIZATION_ID_STUDENT_NUMBER_CONSTRAINT_NAME}" TO "${OLD_UNIQUE_ORGANIZATION_ID_STUDENT_NUMBER_CONSTRAINT_NAME}";` ); }; + +export { up, down }; diff --git a/api/db/migrations/20220517131951_update-constraint-campaign-participations-organizationLearnerId-not-null.js b/api/db/migrations/20220517131951_update-constraint-campaign-participations-organizationLearnerId-not-null.js index 4dd3e51a2b6..4760dbfc40f 100644 --- a/api/db/migrations/20220517131951_update-constraint-campaign-participations-organizationLearnerId-not-null.js +++ b/api/db/migrations/20220517131951_update-constraint-campaign-participations-organizationLearnerId-not-null.js @@ -6,7 +6,7 @@ const ORGANIZATIONLEARNERID_COLUMN = 'organizationLearnerId'; const CAMPAIGNID_COLUMN = 'campaignId'; const NEW_CONSTRAINT_NAME = 'one_active_participation_by_learner'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.alterTable(CAMPAIGN_PARTICIPATIONS_TABLE, function (table) { table.integer(ORGANIZATIONLEARNERID_COLUMN).notNullable().alter(); }); @@ -25,7 +25,7 @@ exports.up = async (knex) => { ); }; -exports.down = async (knex) => { +const down = async function (knex) { await knex.schema.alterTable(CAMPAIGN_PARTICIPATIONS_TABLE, function (table) { table.integer(ORGANIZATIONLEARNERID_COLUMN).nullable().alter(); }); @@ -33,3 +33,5 @@ exports.down = async (knex) => { // eslint-disable-next-line knex/avoid-injections return knex.raw(`DROP INDEX ${NEW_CONSTRAINT_NAME};`); }; + +export { up, down }; diff --git a/api/db/migrations/20220610085239_add-columns-incident-and-joining-issue-to-session.js b/api/db/migrations/20220610085239_add-columns-incident-and-joining-issue-to-session.js index 27d5584d418..1dcfe9462e7 100644 --- a/api/db/migrations/20220610085239_add-columns-incident-and-joining-issue-to-session.js +++ b/api/db/migrations/20220610085239_add-columns-incident-and-joining-issue-to-session.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'sessions'; const COLUMN_NAME_INCIDENT = 'hasIncident'; const COLUMN_NAME_JOINING_ISSUE = 'hasJoiningIssue'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME_INCIDENT).notNullable().defaultTo(false); table.boolean(COLUMN_NAME_JOINING_ISSUE).notNullable().defaultTo(false); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME_INCIDENT); table.dropColumn(COLUMN_NAME_JOINING_ISSUE); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220616131338_add-column-status-to-tutorial-evaluations.js b/api/db/migrations/20220616131338_add-column-status-to-tutorial-evaluations.js index a3a9c1ddae0..b39d457a761 100644 --- a/api/db/migrations/20220616131338_add-column-status-to-tutorial-evaluations.js +++ b/api/db/migrations/20220616131338_add-column-status-to-tutorial-evaluations.js @@ -4,14 +4,17 @@ const EVALUATION_STATUS = { LIKED: 'LIKED', NEUTRAL: 'NEUTRAL', }; -exports.up = async function (knex) { + +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.enu(COLUMN_NAME, [EVALUATION_STATUS.LIKED, EVALUATION_STATUS.NEUTRAL]).defaultTo('LIKED'); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220617144325-rename-expiredDate-in-expirationDate-in-organization-places-table.js b/api/db/migrations/20220617144325-rename-expiredDate-in-expirationDate-in-organization-places-table.js index 7ff6ff4cf6d..42a3d2c6556 100644 --- a/api/db/migrations/20220617144325-rename-expiredDate-in-expirationDate-in-organization-places-table.js +++ b/api/db/migrations/20220617144325-rename-expiredDate-in-expirationDate-in-organization-places-table.js @@ -2,10 +2,12 @@ const TABLE_NAME = 'organization-places'; const OLD_COLUMN_NAME = 'expiredDate'; const NEW_COLUMN_NAME = 'expirationDate'; -exports.up = async function (knex) { +const up = async function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(OLD_COLUMN_NAME, NEW_COLUMN_NAME)); }; -exports.down = async function (knex) { +const down = async function (knex) { return knex.schema.table(TABLE_NAME, (t) => t.renameColumn(NEW_COLUMN_NAME, OLD_COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20220620123740_add-identity-provider-for-campaigns-column-in-organizations-table.js b/api/db/migrations/20220620123740_add-identity-provider-for-campaigns-column-in-organizations-table.js index 93af0261f45..f4c3fc94b68 100644 --- a/api/db/migrations/20220620123740_add-identity-provider-for-campaigns-column-in-organizations-table.js +++ b/api/db/migrations/20220620123740_add-identity-provider-for-campaigns-column-in-organizations-table.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'organizations'; const COLUMN_NAME = 'identityProviderForCampaigns'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { table.string(COLUMN_NAME).nullable(); }); @@ -11,8 +11,10 @@ exports.up = async function (knex) { ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220629091212_drop-target-profile-template-table.js b/api/db/migrations/20220629091212_drop-target-profile-template-table.js index 5ff6d53cf40..ce4f3658a19 100644 --- a/api/db/migrations/20220629091212_drop-target-profile-template-table.js +++ b/api/db/migrations/20220629091212_drop-target-profile-template-table.js @@ -1,11 +1,11 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; const TEMPLATE_TABLE_NAME = 'target-profile-templates'; const OLD_TEMPLATE_TUBES_TABLE_NAME = 'target-profile-templates_tubes'; const TARGET_PROFILE_TUBES_TABLE_NAME = 'target-profile_tubes'; const TARGET_PROFILE_TABLE_NAME = 'target-profiles'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.renameTable(OLD_TEMPLATE_TUBES_TABLE_NAME, TARGET_PROFILE_TUBES_TABLE_NAME); await knex.schema.table(TARGET_PROFILE_TUBES_TABLE_NAME, (t) => { @@ -30,7 +30,7 @@ exports.up = async function (knex) { await knex.schema.dropTable(TEMPLATE_TABLE_NAME); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.createTable(TEMPLATE_TABLE_NAME, (t) => { t.increments().primary(); }); @@ -59,3 +59,5 @@ exports.down = async function (knex) { await knex.schema.renameTable(TARGET_PROFILE_TUBES_TABLE_NAME, OLD_TEMPLATE_TUBES_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220711194824_add-level-to-complementary-certification-badges.js b/api/db/migrations/20220711194824_add-level-to-complementary-certification-badges.js index b7c8b0c4441..cdbe3dbe6f5 100644 --- a/api/db/migrations/20220711194824_add-level-to-complementary-certification-badges.js +++ b/api/db/migrations/20220711194824_add-level-to-complementary-certification-badges.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'complementary-certification-badges'; const COLUMN_NAME = 'level'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.integer(COLUMN_NAME).notNullable().defaultTo(1); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220712082535_insert-complementary-certification-badges.js b/api/db/migrations/20220712082535_insert-complementary-certification-badges.js index 59eb1ad4181..b1c7d6c800b 100644 --- a/api/db/migrations/20220712082535_insert-complementary-certification-badges.js +++ b/api/db/migrations/20220712082535_insert-complementary-certification-badges.js @@ -1,5 +1,10 @@ const TABLE_NAME = 'complementary-certification-badges'; -const { noop } = require('lodash'); +import lodash from 'lodash'; + +const { noop } = lodash; + +import { badges } from '../constants.js'; + const { PIX_EMPLOI_CLEA_V1, PIX_EMPLOI_CLEA_V2, @@ -20,7 +25,7 @@ const { PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_CONFIRME, PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_AVANCE, PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_EXPERT, -} = require('../constants').badges.keys; +} = badges.keys; const DROIT = 'Pix+ Droit'; const CLEA = 'CléA Numérique'; @@ -73,7 +78,7 @@ const data = [ { keys: [PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_EXPERT], level: 5, complementaryCourseKey: EDU_2 }, ]; -exports.up = async function (knex) { +const up = async function (knex) { await _insertComplementaryCertifications(); await knex(TABLE_NAME).del(); @@ -131,6 +136,8 @@ exports.up = async function (knex) { } }; -exports.down = async function () { +const down = async function () { noop; }; + +export { up, down }; diff --git a/api/db/migrations/20220712125907_add-hasBeenAutomaticallyResolved-column-to-certification-issue-reports.js b/api/db/migrations/20220712125907_add-hasBeenAutomaticallyResolved-column-to-certification-issue-reports.js index 96b3d1ff91e..de8ebe54c1f 100644 --- a/api/db/migrations/20220712125907_add-hasBeenAutomaticallyResolved-column-to-certification-issue-reports.js +++ b/api/db/migrations/20220712125907_add-hasBeenAutomaticallyResolved-column-to-certification-issue-reports.js @@ -11,7 +11,7 @@ const autoResolveSentences = [ 'Cette réponse a été acceptée automatiquement', ]; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table('certification-issue-reports', (table) => { table.boolean('hasBeenAutomaticallyResolved').nullable(); }); @@ -24,8 +24,10 @@ exports.up = async function (knex) { .update({ hasBeenAutomaticallyResolved: true }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table('certification-issue-reports', (table) => { table.dropColumn('hasBeenAutomaticallyResolved'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220721115757_alter-answers-id-from-int-to-bigint.js b/api/db/migrations/20220721115757_alter-answers-id-from-int-to-bigint.js index 26a6dea9b52..f4d30327a8e 100644 --- a/api/db/migrations/20220721115757_alter-answers-id-from-int-to-bigint.js +++ b/api/db/migrations/20220721115757_alter-answers-id-from-int-to-bigint.js @@ -9,7 +9,7 @@ const changeAnswerIdTypeToBigint = async (knex) => { }); }; -exports.up = async function (knex) { +const up = async function (knex) { const { rows: answersCheckDataTypeQueryResult } = await knex.raw(` SELECT "column_name","data_type" FROM "information_schema"."columns" @@ -33,7 +33,6 @@ exports.up = async function (knex) { } } }; - -exports.down = function () { - // no need for rollback -}; +// eslint-disable-next-line no-empty-function +const down = function () {}; +export { up, down }; diff --git a/api/db/migrations/20220729092523_add-column-key-and-rename-name-as-label-to-complemantary-certifications.js b/api/db/migrations/20220729092523_add-column-key-and-rename-name-as-label-to-complemantary-certifications.js index 65f81f7d155..b68252816c8 100644 --- a/api/db/migrations/20220729092523_add-column-key-and-rename-name-as-label-to-complemantary-certifications.js +++ b/api/db/migrations/20220729092523_add-column-key-and-rename-name-as-label-to-complemantary-certifications.js @@ -3,7 +3,7 @@ const COLUMN_NAME_NAME = 'name'; const COLUMN_NAME_LABEL = 'label'; const COLUMN_NAME_KEY = 'key'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME_KEY); }); @@ -19,9 +19,11 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME_KEY); table.renameColumn(COLUMN_NAME_LABEL, COLUMN_NAME_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220802093742_add-imageUrl-to-complementary-certification-badges.js b/api/db/migrations/20220802093742_add-imageUrl-to-complementary-certification-badges.js index 126274d8573..0129ee6a20d 100644 --- a/api/db/migrations/20220802093742_add-imageUrl-to-complementary-certification-badges.js +++ b/api/db/migrations/20220802093742_add-imageUrl-to-complementary-certification-badges.js @@ -1,3 +1,4 @@ +import { badges } from '../constants.js'; const TABLE_NAME = 'complementary-certification-badges'; const COLUMN_NAME = 'imageUrl'; const { @@ -16,11 +17,11 @@ const { PIX_EMPLOI_CLEA_V1, PIX_EMPLOI_CLEA_V2, PIX_EMPLOI_CLEA_V3, -} = require('../constants').badges.keys; +} = badges.keys; -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME); }); @@ -95,8 +96,10 @@ exports.up = async function (knex) { } }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220802141209_set-isCertifiable-to-true-on-clea-badges.js b/api/db/migrations/20220802141209_set-isCertifiable-to-true-on-clea-badges.js index 1d8d8eaa6f5..498aa7f2c29 100644 --- a/api/db/migrations/20220802141209_set-isCertifiable-to-true-on-clea-badges.js +++ b/api/db/migrations/20220802141209_set-isCertifiable-to-true-on-clea-badges.js @@ -1,12 +1,15 @@ -const { PIX_EMPLOI_CLEA_V1, PIX_EMPLOI_CLEA_V2, PIX_EMPLOI_CLEA_V3 } = require('../constants').badges.keys; +import { badges } from '../constants.js'; +const { PIX_EMPLOI_CLEA_V1, PIX_EMPLOI_CLEA_V2, PIX_EMPLOI_CLEA_V3 } = badges.keys; const TABLE_NAME = 'badges'; const CLEA_KEYS = [PIX_EMPLOI_CLEA_V1, PIX_EMPLOI_CLEA_V2, PIX_EMPLOI_CLEA_V3]; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).update({ isCertifiable: true }).whereIn('key', CLEA_KEYS); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).update({ isCertifiable: false }).whereIn('key', CLEA_KEYS); }; + +export { up, down }; diff --git a/api/db/migrations/20220802143639_add-level-to-clea-certif-badges.js b/api/db/migrations/20220802143639_add-level-to-clea-certif-badges.js index a77b0a86cee..4f9af04a079 100644 --- a/api/db/migrations/20220802143639_add-level-to-clea-certif-badges.js +++ b/api/db/migrations/20220802143639_add-level-to-clea-certif-badges.js @@ -1,7 +1,8 @@ +import { badges } from '../constants.js'; const TABLE_NAME = 'complementary-certification-badges'; -const { PIX_EMPLOI_CLEA_V2, PIX_EMPLOI_CLEA_V3 } = require('../constants').badges.keys; +const { PIX_EMPLOI_CLEA_V2, PIX_EMPLOI_CLEA_V3 } = badges.keys; -exports.up = async function (knex) { +const up = async function (knex) { await knex(TABLE_NAME) .update({ level: 2 }) .where({ badgeId: knex('badges').select('id').where({ key: PIX_EMPLOI_CLEA_V2 }) }); @@ -10,7 +11,7 @@ exports.up = async function (knex) { .where({ badgeId: knex('badges').select('id').where({ key: PIX_EMPLOI_CLEA_V3 }) }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex(TABLE_NAME) .update({ level: 1 }) .where({ badgeId: knex('badges').select('id').where({ key: PIX_EMPLOI_CLEA_V2 }) }); @@ -18,3 +19,5 @@ exports.down = async function (knex) { .update({ level: 1 }) .where({ badgeId: knex('badges').select('id').where({ key: PIX_EMPLOI_CLEA_V3 }) }); }; + +export { up, down }; diff --git a/api/db/migrations/20220808152543_add-label-column-to-complementary-certification-badges-table.js b/api/db/migrations/20220808152543_add-label-column-to-complementary-certification-badges-table.js index e9a81b98033..e50d451a14b 100644 --- a/api/db/migrations/20220808152543_add-label-column-to-complementary-certification-badges-table.js +++ b/api/db/migrations/20220808152543_add-label-column-to-complementary-certification-badges-table.js @@ -1,3 +1,5 @@ +import { badges } from '../constants.js'; + const TABLE_NAME = 'complementary-certification-badges'; const COLUMN_NAME = 'label'; const { @@ -16,11 +18,11 @@ const { PIX_EMPLOI_CLEA_V1, PIX_EMPLOI_CLEA_V2, PIX_EMPLOI_CLEA_V3, -} = require('../constants').badges.keys; +} = badges.keys; -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME); }); @@ -95,8 +97,10 @@ exports.up = async function (knex) { } }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220811152439_add-archived-by-to-campaigns.js b/api/db/migrations/20220811152439_add-archived-by-to-campaigns.js index b3f3cfa17cb..e0773b32bd5 100644 --- a/api/db/migrations/20220811152439_add-archived-by-to-campaigns.js +++ b/api/db/migrations/20220811152439_add-archived-by-to-campaigns.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'campaigns'; const ARCHIVEDBY_COLUMN = 'archivedBy'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { table.bigInteger(ARCHIVEDBY_COLUMN).index().references('users.id'); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { table.dropColumn(ARCHIVEDBY_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220816125246_add-deleted-at-and-deleted-by-to-organization-places.js b/api/db/migrations/20220816125246_add-deleted-at-and-deleted-by-to-organization-places.js index 57208bcd569..4cc47a4dcad 100644 --- a/api/db/migrations/20220816125246_add-deleted-at-and-deleted-by-to-organization-places.js +++ b/api/db/migrations/20220816125246_add-deleted-at-and-deleted-by-to-organization-places.js @@ -2,24 +2,18 @@ const TABLE_NAME = 'organization-places'; const DELETEDAT_COLUMN = 'deletedAt'; const DELETEDBY_COLUMN = 'deletedBy'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { table.dateTime(DELETEDAT_COLUMN).nullable(); table.bigInteger(DELETEDBY_COLUMN).index().references('users.id').nullable(); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { table.dropColumn(DELETEDAT_COLUMN); table.dropColumn(DELETEDBY_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220816143731_add-isCertifiable-to-campaign-participations.js b/api/db/migrations/20220816143731_add-isCertifiable-to-campaign-participations.js index 3d15702996f..38249a49f1f 100644 --- a/api/db/migrations/20220816143731_add-isCertifiable-to-campaign-participations.js +++ b/api/db/migrations/20220816143731_add-isCertifiable-to-campaign-participations.js @@ -1,22 +1,16 @@ const TABLE_NAME = 'campaign-participations'; const COLUMN = 'isCertifiable'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { table.boolean(COLUMN).nullable().defaultTo(null); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { table.dropColumn(COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220824131510_create-campaign-skill-relationship-table.js b/api/db/migrations/20220824131510_create-campaign-skill-relationship-table.js index 519a7d7737d..ebfc5590578 100644 --- a/api/db/migrations/20220824131510_create-campaign-skill-relationship-table.js +++ b/api/db/migrations/20220824131510_create-campaign-skill-relationship-table.js @@ -3,7 +3,7 @@ const CAMPAIGN_SKILL_TABLE_NAME = 'campaign_skills'; const CAMPAIGN_ID_COLUMN = 'campaignId'; const SKILL_ID_COLUMN = 'skillId'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.createTable(CAMPAIGN_SKILL_TABLE_NAME, (t) => { t.integer(CAMPAIGN_ID_COLUMN).notNullable().references(`${CAMPAIGN_TABLE_NAME}.id`); t.string(SKILL_ID_COLUMN).notNullable(); @@ -11,6 +11,8 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.dropTable(CAMPAIGN_SKILL_TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220830082750_add-gar-identity-provider-for-campaigns-in-organizations-table.js b/api/db/migrations/20220830082750_add-gar-identity-provider-for-campaigns-in-organizations-table.js index 6fbea122644..6328a339e85 100644 --- a/api/db/migrations/20220830082750_add-gar-identity-provider-for-campaigns-in-organizations-table.js +++ b/api/db/migrations/20220830082750_add-gar-identity-provider-for-campaigns-in-organizations-table.js @@ -1,13 +1,15 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('ALTER TABLE "organizations" DROP CONSTRAINT "organizations_identityProviderForCampaigns_check" '); return knex.raw( 'ALTER TABLE "organizations" ADD CONSTRAINT "organizations_identityProviderForCampaigns_check" CHECK ( "identityProviderForCampaigns" IN (\'POLE_EMPLOI\', \'CNAV\', \'GAR\') )' ); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('ALTER TABLE "organizations" DROP CONSTRAINT "organizations_identityProviderForCampaigns_check" '); return knex.raw( 'ALTER TABLE "organizations" ADD CONSTRAINT "organizations_identityProviderForCampaigns_check" CHECK ( "identityProviderForCampaigns" IN (\'POLE_EMPLOI\', \'CNAV\') )' ); }; + +export { up, down }; diff --git a/api/db/migrations/20220830093334_add-minimum-reproducibility-rate-in-complementary-certifications-table.js b/api/db/migrations/20220830093334_add-minimum-reproducibility-rate-in-complementary-certifications-table.js index 4e908725cbf..401bdc5fe01 100644 --- a/api/db/migrations/20220830093334_add-minimum-reproducibility-rate-in-complementary-certifications-table.js +++ b/api/db/migrations/20220830093334_add-minimum-reproducibility-rate-in-complementary-certifications-table.js @@ -1,11 +1,7 @@ const TABLE_NAME = 'complementary-certifications'; const COLUMN = 'minimumReproducibilityRate'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = async function (knex) { +const up = async function (knex) { await knex(TABLE_NAME).update({ minimumReproducibilityRate: 50.0, minimumEarnedPix: 70 }).where({ key: 'CLEA' }); await knex(TABLE_NAME).update(COLUMN, 75.0).where({ key: 'DROIT' }); @@ -17,14 +13,12 @@ exports.up = async function (knex) { }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.alterTable(TABLE_NAME, async (table) => { await table.decimal(COLUMN, 5, 2).nullable().alter(); }); await knex(TABLE_NAME).update(COLUMN, null).whereIn('key', ['DROIT', 'EDU_1ER_DEGRE', 'EDU_2ND_DEGRE']); }; + +export { up, down }; diff --git a/api/db/migrations/20220830132314_add-column-has-complementary-referential-to-complementary-certifications.js b/api/db/migrations/20220830132314_add-column-has-complementary-referential-to-complementary-certifications.js index 0fd0435ef45..eec8a22acbe 100644 --- a/api/db/migrations/20220830132314_add-column-has-complementary-referential-to-complementary-certifications.js +++ b/api/db/migrations/20220830132314_add-column-has-complementary-referential-to-complementary-certifications.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'complementary-certifications'; const COLUMN_NAME = 'hasComplementaryReferential'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME); }); @@ -16,8 +16,10 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220831084146_add-complementary-certification-badges-fk-to-complementary-certification-courses.js b/api/db/migrations/20220831084146_add-complementary-certification-badges-fk-to-complementary-certification-courses.js index cf0c004a59a..725ed7c313a 100644 --- a/api/db/migrations/20220831084146_add-complementary-certification-badges-fk-to-complementary-certification-courses.js +++ b/api/db/migrations/20220831084146_add-complementary-certification-badges-fk-to-complementary-certification-courses.js @@ -1,8 +1,8 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; const TABLE_NAME = 'complementary-certification-courses'; const COLUMN = 'complementaryCertificationBadgeId'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { await table.integer(COLUMN).references('complementary-certification-badges.id'); }); @@ -24,8 +24,10 @@ exports.up = async function (knex) { }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => { table.dropColumn(COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220906131043_add-level-column-to-stages-table.js b/api/db/migrations/20220906131043_add-level-column-to-stages-table.js index aeb99e8afa7..59e25025e51 100644 --- a/api/db/migrations/20220906131043_add-level-column-to-stages-table.js +++ b/api/db/migrations/20220906131043_add-level-column-to-stages-table.js @@ -2,15 +2,17 @@ const TABLE_NAME = 'stages'; const LEVEL_COLUMN = 'level'; const THRESHOLD_COLUMN = 'threshold'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.integer(LEVEL_COLUMN).nullable().defaultTo(null); table.integer(THRESHOLD_COLUMN).nullable().alter(); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, (table) => { table.dropColumn(LEVEL_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220906142048_add-assessmentId-in-flash-assessments-results.js b/api/db/migrations/20220906142048_add-assessmentId-in-flash-assessments-results.js index 77ab4d819f2..0209872ffab 100644 --- a/api/db/migrations/20220906142048_add-assessmentId-in-flash-assessments-results.js +++ b/api/db/migrations/20220906142048_add-assessmentId-in-flash-assessments-results.js @@ -1,8 +1,8 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; const TABLE_NAME = 'flash-assessment-results'; const COLUMN_NAME = 'assessmentId'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, async (table) => table.integer(COLUMN_NAME).references('assessments.id')); const flashAssessmentResults = await knex(TABLE_NAME) @@ -18,6 +18,8 @@ exports.up = async function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => table.dropColumn(COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20220907144932_add-column-exported-in-file-in-table-certification-courses.js b/api/db/migrations/20220907144932_add-column-exported-in-file-in-table-certification-courses.js index f4612a8cc43..e101c5065a3 100644 --- a/api/db/migrations/20220907144932_add-column-exported-in-file-in-table-certification-courses.js +++ b/api/db/migrations/20220907144932_add-column-exported-in-file-in-table-certification-courses.js @@ -1,22 +1,16 @@ const TABLE_NAME = 'certification-courses'; const COLUMN_NAME = 'cpfFilename'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.text(COLUMN_NAME).nullable(); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220913073642_add-has-external-jury-column-to-complementary-certifications-table.js b/api/db/migrations/20220913073642_add-has-external-jury-column-to-complementary-certifications-table.js index 7a7ed64ac72..493676c938d 100644 --- a/api/db/migrations/20220913073642_add-has-external-jury-column-to-complementary-certifications-table.js +++ b/api/db/migrations/20220913073642_add-has-external-jury-column-to-complementary-certifications-table.js @@ -1,11 +1,8 @@ const TABLE_NAME = 'complementary-certifications'; const COLUMN_NAME = 'hasExternalJury'; -const { - PIX_PLUS_EDU_1ER_DEGRE, - PIX_PLUS_EDU_2ND_DEGRE, -} = require('../../lib/domain/models/ComplementaryCertification'); +import { PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE } from '../../lib/domain/models/ComplementaryCertification.js'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).notNullable().default(false); }); @@ -15,6 +12,8 @@ exports.up = async function (knex) { .whereIn('key', [PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE]); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, async (table) => table.dropColumn(COLUMN_NAME)); }; + +export { up, down }; diff --git a/api/db/migrations/20220914125923_replace-clea-image-url.js b/api/db/migrations/20220914125923_replace-clea-image-url.js index b850b1ebfd2..40b14b682a8 100644 --- a/api/db/migrations/20220914125923_replace-clea-image-url.js +++ b/api/db/migrations/20220914125923_replace-clea-image-url.js @@ -2,10 +2,12 @@ const TABLE_NAME = 'complementary-certification-badges'; const newUrl = 'https://images.pix.fr/badges/CleA_Num_certif.svg'; const oldUrl = 'https://images.pix.fr/badges/Pix-emploi.svg'; -exports.up = async function (knex) { +const up = async function (knex) { await knex(TABLE_NAME).update({ imageUrl: newUrl }).where({ imageUrl: oldUrl }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex(TABLE_NAME).update({ imageUrl: oldUrl }).where({ imageUrl: newUrl }); }; + +export { up, down }; diff --git a/api/db/migrations/20220915083737_add-new-column-referer-to-certification-centers-memberships.js b/api/db/migrations/20220915083737_add-new-column-referer-to-certification-centers-memberships.js index d320667dcf0..0e8112a677d 100644 --- a/api/db/migrations/20220915083737_add-new-column-referer-to-certification-centers-memberships.js +++ b/api/db/migrations/20220915083737_add-new-column-referer-to-certification-centers-memberships.js @@ -1,22 +1,16 @@ const TABLE_NAME = 'certification-center-memberships'; const COLUMN_NAME = 'isReferer'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(COLUMN_NAME).defaultTo(false); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220920091611_add-message-columns-to-complementary-certification-badges.js b/api/db/migrations/20220920091611_add-message-columns-to-complementary-certification-badges.js index 5c8887ca2c4..29b072ae9fc 100644 --- a/api/db/migrations/20220920091611_add-message-columns-to-complementary-certification-badges.js +++ b/api/db/migrations/20220920091611_add-message-columns-to-complementary-certification-badges.js @@ -1,10 +1,10 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; const TABLE_NAME = 'complementary-certification-badges'; const MESSAGE_COLUMN_NAME = 'certificateMessage'; const TEMP_MESSAGE_COLUMN_NAME = 'temporaryCertificateMessage'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string(MESSAGE_COLUMN_NAME).nullable(); table.string(TEMP_MESSAGE_COLUMN_NAME).nullable(); @@ -29,9 +29,11 @@ exports.up = async function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(MESSAGE_COLUMN_NAME); table.dropColumn(TEMP_MESSAGE_COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220922141959_modify-messages-in-complementary-certification-badges.js b/api/db/migrations/20220922141959_modify-messages-in-complementary-certification-badges.js index f361ea60b0f..d11274f155e 100644 --- a/api/db/migrations/20220922141959_modify-messages-in-complementary-certification-badges.js +++ b/api/db/migrations/20220922141959_modify-messages-in-complementary-certification-badges.js @@ -1,4 +1,6 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; +import { badges } from '../constants.js'; + const { PIX_EDU_FORMATION_INITIALE_2ND_DEGRE_INITIE, PIX_EDU_FORMATION_INITIALE_2ND_DEGRE_CONFIRME, @@ -10,12 +12,9 @@ const { PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_CONFIRME, PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_AVANCE, PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_EXPERT, -} = require('../constants').badges.keys; -/** - * @param { import('knex').Knex } knex - * @returns { Promise } - */ -exports.up = async function (knex) { +} = badges.keys; + +const up = async function (knex) { const badges = await knex('complementary-certification-badges') .select('complementary-certification-badges.id', 'key') .join('badges', 'badges.id', 'complementary-certification-badges.badgeId') @@ -61,11 +60,6 @@ exports.up = async function (knex) { .where({ id }); }); }; - -/** - * @param { import('knex').Knex } knex - * @returns { Promise } - */ -exports.down = function () { - // do nothing. -}; +// eslint-disable-next-line no-empty-function +const down = function () {}; +export { up, down }; diff --git a/api/db/migrations/20220923141951_create-data-protection-officers-table.js b/api/db/migrations/20220923141951_create-data-protection-officers-table.js index cac80553675..c4030566e23 100644 --- a/api/db/migrations/20220923141951_create-data-protection-officers-table.js +++ b/api/db/migrations/20220923141951_create-data-protection-officers-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'data-protection-officers'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.bigIncrements().primary(); t.string('firstName').nullable(); @@ -19,6 +19,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220926084112_create_trainings_table.js b/api/db/migrations/20220926084112_create_trainings_table.js index 90282eeea8e..35c443688bc 100644 --- a/api/db/migrations/20220926084112_create_trainings_table.js +++ b/api/db/migrations/20220926084112_create_trainings_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'trainings'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('title').notNullable(); @@ -13,6 +13,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220926091617_create_target_profile_trainings_table.js b/api/db/migrations/20220926091617_create_target_profile_trainings_table.js index f6910c98ebb..525a0518cbb 100644 --- a/api/db/migrations/20220926091617_create_target_profile_trainings_table.js +++ b/api/db/migrations/20220926091617_create_target_profile_trainings_table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'target-profile-trainings'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('targetProfileId').references('target-profiles.id').notNullable(); @@ -10,6 +10,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20220927073844_add-column-sticker-url-to-table-complementary-certification-badges.js b/api/db/migrations/20220927073844_add-column-sticker-url-to-table-complementary-certification-badges.js index 77bc2a07490..07e86ba7978 100644 --- a/api/db/migrations/20220927073844_add-column-sticker-url-to-table-complementary-certification-badges.js +++ b/api/db/migrations/20220927073844_add-column-sticker-url-to-table-complementary-certification-badges.js @@ -1,4 +1,4 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; const STICKERS_URL_BY_BADGE_KEY = { PIX_EMPLOI_CLEA: 'https://images.pix.fr/stickers/macaron_clea.pdf', @@ -19,11 +19,7 @@ const STICKERS_URL_BY_BADGE_KEY = { PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_EXPERT: 'https://images.pix.fr/stickers/macaron_edu_1er_expert.pdf', }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.alterTable('complementary-certification-badges', (table) => { table.string('stickerUrl'); }); @@ -39,12 +35,10 @@ exports.up = async function (knex) { }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.alterTable('complementary-certification-badges', (table) => { table.dropColumn('stickerUrl'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20220927130058_create-certification-center-invitations-table.js b/api/db/migrations/20220927130058_create-certification-center-invitations-table.js index 95487c63132..fa31793d03a 100644 --- a/api/db/migrations/20220927130058_create-certification-center-invitations-table.js +++ b/api/db/migrations/20220927130058_create-certification-center-invitations-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-center-invitations'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (table) => { table.bigIncrements('id').primary(); table.bigInteger('certificationCenterId').references('certification-centers.id').index(); @@ -13,6 +13,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20221010075029_add-index-to-target-profile-tube.js b/api/db/migrations/20221010075029_add-index-to-target-profile-tube.js index 3617b8931bd..c922759619e 100644 --- a/api/db/migrations/20221010075029_add-index-to-target-profile-tube.js +++ b/api/db/migrations/20221010075029_add-index-to-target-profile-tube.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'target-profile_tubes'; const COLUMN_NAME = 'targetProfileId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221014135401_add-column-capped-tubes-json-in-badge-criteria-table.js b/api/db/migrations/20221014135401_add-column-capped-tubes-json-in-badge-criteria-table.js index 88b2083ae39..87ca569404a 100644 --- a/api/db/migrations/20221014135401_add-column-capped-tubes-json-in-badge-criteria-table.js +++ b/api/db/migrations/20221014135401_add-column-capped-tubes-json-in-badge-criteria-table.js @@ -1,22 +1,16 @@ const TABLE_NAME = 'badge-criteria'; const COLUMN_NAME = 'cappedTubes'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.jsonb(COLUMN_NAME); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221017085933_create-user-recommended-trainings.js b/api/db/migrations/20221017085933_create-user-recommended-trainings.js index a5598a9f5d5..f1a36cc7fe3 100644 --- a/api/db/migrations/20221017085933_create-user-recommended-trainings.js +++ b/api/db/migrations/20221017085933_create-user-recommended-trainings.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'user-recommended-trainings'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('userId').references('users.id').notNullable(); @@ -12,6 +12,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20221018192501_add-column-pix-certification-status-in-certification-courses-table.js b/api/db/migrations/20221018192501_add-column-pix-certification-status-in-certification-courses-table.js index 5125c7bca51..9071c67bf65 100644 --- a/api/db/migrations/20221018192501_add-column-pix-certification-status-in-certification-courses-table.js +++ b/api/db/migrations/20221018192501_add-column-pix-certification-status-in-certification-courses-table.js @@ -1,22 +1,16 @@ const TABLE_NAME = 'certification-courses'; const COLUMN_NAME = 'pixCertificationStatus'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME).defaultTo(null); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221121154233_cpf-import-status-migration.js b/api/db/migrations/20221121154233_cpf-import-status-migration.js index 39eff5d7eed..87e6a377682 100644 --- a/api/db/migrations/20221121154233_cpf-import-status-migration.js +++ b/api/db/migrations/20221121154233_cpf-import-status-migration.js @@ -1,22 +1,16 @@ const TABLE_NAME = 'certification-courses'; const COLUMN_NAME = 'cpfImportStatus'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME).defaultTo(null); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221123110348_remove-NULL-postalCodes.js b/api/db/migrations/20221123110348_remove-NULL-postalCodes.js index 6fac3cd8042..4f1477d4593 100644 --- a/api/db/migrations/20221123110348_remove-NULL-postalCodes.js +++ b/api/db/migrations/20221123110348_remove-NULL-postalCodes.js @@ -1,8 +1,7 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex('certification-candidates').where({ birthPostalCode: 'NULL' }).update({ birthPostalCode: null }); await knex('certification-candidates').where({ birthINSEECode: 'NULL' }).update({ birthINSEECode: null }); }; - -exports.down = function () { - // do nothing. -}; +// eslint-disable-next-line no-empty-function +const down = function () {}; +export { up, down }; diff --git a/api/db/migrations/20221123144416_add-fwb-identity-provider-to-authentication-methods-table.js b/api/db/migrations/20221123144416_add-fwb-identity-provider-to-authentication-methods-table.js index cd4dc5eda7c..27b710d3e4d 100644 --- a/api/db/migrations/20221123144416_add-fwb-identity-provider-to-authentication-methods-table.js +++ b/api/db/migrations/20221123144416_add-fwb-identity-provider-to-authentication-methods-table.js @@ -1,4 +1,4 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw( 'ALTER TABLE "authentication-methods" DROP CONSTRAINT "authentication_methods_identityProvider_check" ' ); @@ -7,7 +7,7 @@ exports.up = async function (knex) { ); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw( 'ALTER TABLE "authentication-methods" DROP CONSTRAINT "authentication_methods_identityProvider_check" ' ); @@ -15,3 +15,5 @@ exports.down = async function (knex) { "ALTER TABLE \"authentication-methods\" ADD CONSTRAINT \"authentication_methods_identityProvider_check\" CHECK ( \"identityProvider\" IN ('PIX', 'GAR', 'POLE_EMPLOI', 'CNAV') )" ); }; + +export { up, down }; diff --git a/api/db/migrations/20221124093117_create-user-logins-table.js b/api/db/migrations/20221124093117_create-user-logins-table.js index 06d0782ca9a..34aa7fecd0a 100644 --- a/api/db/migrations/20221124093117_create-user-logins-table.js +++ b/api/db/migrations/20221124093117_create-user-logins-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'user-logins'; -exports.up = (knex) => { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.bigIncrements().primary(); t.bigInteger('userId').references('users.id').notNullable().unique(); @@ -12,6 +12,8 @@ exports.up = (knex) => { }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20221130100911_add-issue-report-categories.js b/api/db/migrations/20221130100911_add-issue-report-categories.js index bac266f5196..34300921564 100644 --- a/api/db/migrations/20221130100911_add-issue-report-categories.js +++ b/api/db/migrations/20221130100911_add-issue-report-categories.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'issue-report-categories'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.string('name').notNullable(); @@ -158,6 +158,8 @@ exports.up = async (knex) => { ]); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20221130143941_add-last-assessment-result-id-to-certif-course.js b/api/db/migrations/20221130143941_add-last-assessment-result-id-to-certif-course.js index 3f20d4acd2b..eb876758744 100644 --- a/api/db/migrations/20221130143941_add-last-assessment-result-id-to-certif-course.js +++ b/api/db/migrations/20221130143941_add-last-assessment-result-id-to-certif-course.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'certification-courses-last-assessment-results'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, function (table) { table .integer('certificationCourseId') @@ -11,6 +11,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20221205153130_add-column-updatedByUserId-to-certification-center-memberships-table.js b/api/db/migrations/20221205153130_add-column-updatedByUserId-to-certification-center-memberships-table.js index e277632cd48..019c1b6dcdb 100644 --- a/api/db/migrations/20221205153130_add-column-updatedByUserId-to-certification-center-memberships-table.js +++ b/api/db/migrations/20221205153130_add-column-updatedByUserId-to-certification-center-memberships-table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'certification-center-memberships'; const COLUMN_NAME = 'updatedByUserId'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.bigInteger(COLUMN_NAME).index().references('users.id'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221207095714_add-badge-criteria-name-column.js b/api/db/migrations/20221207095714_add-badge-criteria-name-column.js index 6d531f68489..f87279e9f17 100644 --- a/api/db/migrations/20221207095714_add-badge-criteria-name-column.js +++ b/api/db/migrations/20221207095714_add-badge-criteria-name-column.js @@ -1,22 +1,16 @@ const TABLE_NAME = 'badge-criteria'; const COLUMN_NAME = 'name'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME).defaultTo(null); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221208141139_update-certification-issue-report.js b/api/db/migrations/20221208141139_update-certification-issue-report.js index 20f9c12e657..614d179ada7 100644 --- a/api/db/migrations/20221208141139_update-certification-issue-report.js +++ b/api/db/migrations/20221208141139_update-certification-issue-report.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'certification-issue-reports'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.alterTable(TABLE_NAME, (table) => { table.integer('categoryId').references('issue-report-categories.id'); }); }; -exports.down = async function (knex) { +const down = async function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('categoryId'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221209101502_add_lastDataProtectionPolicySeenAt_to_users_table.js b/api/db/migrations/20221209101502_add_lastDataProtectionPolicySeenAt_to_users_table.js index 3bfd76f593b..506c254ad61 100644 --- a/api/db/migrations/20221209101502_add_lastDataProtectionPolicySeenAt_to_users_table.js +++ b/api/db/migrations/20221209101502_add_lastDataProtectionPolicySeenAt_to_users_table.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'lastDataProtectionPolicySeenAt'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dateTime(COLUMN_NAME); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221212100331_add-training-editor-name-logo-column.js b/api/db/migrations/20221212100331_add-training-editor-name-logo-column.js index 49a89836630..97dfe78ffd9 100644 --- a/api/db/migrations/20221212100331_add-training-editor-name-logo-column.js +++ b/api/db/migrations/20221212100331_add-training-editor-name-logo-column.js @@ -5,24 +5,18 @@ const editorName = "Ministère de l'Éducation nationale et de la Jeunesse. Libe const editorLogoUrl = 'https://images.pix.fr/contenu-formatif/editeur/logo-ministere-education-nationale-et-jeunesse.svg'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.string(EDITOR_NAME_COLUMN).default(editorName).notNullable(); table.string(EDITOR_LOGO_URL_COLUMN).default(editorLogoUrl).notNullable(); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(EDITOR_NAME_COLUMN); table.dropColumn(EDITOR_LOGO_URL_COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221226100427_add-column-migration-status-on-target-profiles-table.js b/api/db/migrations/20221226100427_add-column-migration-status-on-target-profiles-table.js index bcd063c6d2a..a62f2d046ae 100644 --- a/api/db/migrations/20221226100427_add-column-migration-status-on-target-profiles-table.js +++ b/api/db/migrations/20221226100427_add-column-migration-status-on-target-profiles-table.js @@ -1,11 +1,7 @@ const TABLE_NAME = 'target-profiles'; const COLUMN = 'migration_status'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN).default('N/A').notNullable(); }); @@ -16,12 +12,10 @@ exports.up = async function (knex) { }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN); }); }; + +export { up, down }; diff --git a/api/db/migrations/20221228135724_add-hasBeenAnonymised-and-hasBeenAnonymisedBy-to-users-table.js b/api/db/migrations/20221228135724_add-hasBeenAnonymised-and-hasBeenAnonymisedBy-to-users-table.js index cc12b15cdc2..ad1d127ad8d 100644 --- a/api/db/migrations/20221228135724_add-hasBeenAnonymised-and-hasBeenAnonymisedBy-to-users-table.js +++ b/api/db/migrations/20221228135724_add-hasBeenAnonymised-and-hasBeenAnonymisedBy-to-users-table.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'users'; const HAS_BEEN_ANONYMISED_COLUMN_NAME = 'hasBeenAnonymised'; const HAS_BEEN_ANONYMISED_BY_COLUMN_NAME = 'hasBeenAnonymisedBy'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(HAS_BEEN_ANONYMISED_COLUMN_NAME).defaultTo(false); table.integer(HAS_BEEN_ANONYMISED_BY_COLUMN_NAME).defaultTo(null); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(HAS_BEEN_ANONYMISED_COLUMN_NAME); table.dropColumn(HAS_BEEN_ANONYMISED_BY_COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230103093529_set-date-for-hasBeenAnonymised-column-on-users-table.js b/api/db/migrations/20230103093529_set-date-for-hasBeenAnonymised-column-on-users-table.js index 021a6c92db0..dfc91cdeada 100644 --- a/api/db/migrations/20230103093529_set-date-for-hasBeenAnonymised-column-on-users-table.js +++ b/api/db/migrations/20230103093529_set-date-for-hasBeenAnonymised-column-on-users-table.js @@ -1,9 +1,11 @@ const TABLE_NAME = 'users'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).whereILike('email', 'email\\_%@example.net').update({ hasBeenAnonymised: true }); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).whereILike('email', 'email\\_%@example.net').update({ hasBeenAnonymised: false }); }; + +export { up, down }; diff --git a/api/db/migrations/20230110144114_add_columns_prerequisiteThreshold_goalThreshold_to_trainings_table.js b/api/db/migrations/20230110144114_add_columns_prerequisiteThreshold_goalThreshold_to_trainings_table.js index e14fd089bbc..4202738da97 100644 --- a/api/db/migrations/20230110144114_add_columns_prerequisiteThreshold_goalThreshold_to_trainings_table.js +++ b/api/db/migrations/20230110144114_add_columns_prerequisiteThreshold_goalThreshold_to_trainings_table.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'trainings'; const COLUMN_NAME_PREREQUISITE_THRESHOLD = 'prerequisiteThreshold'; const COLUMN_NAME_GOAL_THRESHOLD = 'goalThreshold'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.integer(COLUMN_NAME_PREREQUISITE_THRESHOLD).nullable().defaultTo(null); table.integer(COLUMN_NAME_GOAL_THRESHOLD).nullable().defaultTo(null); }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME_PREREQUISITE_THRESHOLD); table.dropColumn(COLUMN_NAME_GOAL_THRESHOLD); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230112103200_cancel-pending-organization-invitations-with-an-updatedAt-greater-than-a-year.js b/api/db/migrations/20230112103200_cancel-pending-organization-invitations-with-an-updatedAt-greater-than-a-year.js index 14e0fd8bf86..d6f0de2c9ef 100644 --- a/api/db/migrations/20230112103200_cancel-pending-organization-invitations-with-an-updatedAt-greater-than-a-year.js +++ b/api/db/migrations/20230112103200_cancel-pending-organization-invitations-with-an-updatedAt-greater-than-a-year.js @@ -1,13 +1,13 @@ -const dayjs = require('dayjs'); -const { StatusType } = require('../../lib/domain/models/OrganizationInvitation'); +import dayjs from 'dayjs'; +import { statuses as StatusType } from '../../lib/domain/models/OrganizationInvitation.js'; -exports.up = function (knex) { +const up = function (knex) { return knex('organization-invitations') .update({ status: StatusType.CANCELLED, updatedAt: new Date() }) .where('status', StatusType.PENDING) .andWhere('updatedAt', '<', dayjs().subtract(1, 'year')); }; -exports.down = function () { - // do nothing. -}; +// eslint-disable-next-line no-empty-function +const down = function () {}; +export { up, down }; diff --git a/api/db/migrations/20230112224527_drop-column-end-test-screen-removal.js b/api/db/migrations/20230112224527_drop-column-end-test-screen-removal.js index 62938b16c01..a199be239f6 100644 --- a/api/db/migrations/20230112224527_drop-column-end-test-screen-removal.js +++ b/api/db/migrations/20230112224527_drop-column-end-test-screen-removal.js @@ -1,12 +1,12 @@ const TABLE_NAME = 'certification-centers'; const COLUMN_NAME = 'isSupervisorAccessEnabled'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; -exports.down = async function () { - // do nothing. -}; +// eslint-disable-next-line no-empty-function +const down = async function () {}; +export { up, down }; diff --git a/api/db/migrations/20230124090916_add-fwb-identity-provider-to-organization-table.js b/api/db/migrations/20230124090916_add-fwb-identity-provider-to-organization-table.js index 27a0033a6fc..fc0e682f898 100644 --- a/api/db/migrations/20230124090916_add-fwb-identity-provider-to-organization-table.js +++ b/api/db/migrations/20230124090916_add-fwb-identity-provider-to-organization-table.js @@ -1,13 +1,15 @@ -exports.up = async function (knex) { +const up = async function (knex) { await knex.raw('ALTER TABLE "organizations" DROP CONSTRAINT "organizations_identityProviderForCampaigns_check" '); return knex.raw( "ALTER TABLE \"organizations\" ADD CONSTRAINT \"organizations_identityProviderForCampaigns_check\" CHECK ( \"identityProviderForCampaigns\" IN ('POLE_EMPLOI', 'CNAV', 'GAR', 'FWB') )" ); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.raw('ALTER TABLE "organizations" DROP CONSTRAINT "organizations_identityProviderForCampaigns_check" '); return knex.raw( 'ALTER TABLE "organizations" ADD CONSTRAINT "organizations_identityProviderForCampaigns_check" CHECK ( "identityProviderForCampaigns" IN (\'POLE_EMPLOI\', \'CNAV\', \'GAR\') )' ); }; + +export { up, down }; diff --git a/api/db/migrations/20230124103059_update-connection-or-end-screen-category-to-deprecated.js b/api/db/migrations/20230124103059_update-connection-or-end-screen-category-to-deprecated.js index 16351f1c7b6..69c93993370 100644 --- a/api/db/migrations/20230124103059_update-connection-or-end-screen-category-to-deprecated.js +++ b/api/db/migrations/20230124103059_update-connection-or-end-screen-category-to-deprecated.js @@ -1,9 +1,11 @@ const TABLE_NAME = 'issue-report-categories'; -exports.up = function (knex) { +const up = function (knex) { return knex(TABLE_NAME).update({ isDeprecated: true }).where('name', 'CONNECTION_OR_END_SCREEN'); }; -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).update({ isDeprecated: false }).where('name', 'CONNECTION_OR_END_SCREEN'); }; + +export { up, down }; diff --git a/api/db/migrations/20230201130836_create-training-triggers-table.js b/api/db/migrations/20230201130836_create-training-triggers-table.js index ab6678f4f9c..2c261294125 100644 --- a/api/db/migrations/20230201130836_create-training-triggers-table.js +++ b/api/db/migrations/20230201130836_create-training-triggers-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'training-triggers'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('trainingId').references('trainings.id').notNullable(); @@ -12,6 +12,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20230201130846_create-training-trigger-tubes-table.js b/api/db/migrations/20230201130846_create-training-trigger-tubes-table.js index bc61cf7c955..698a39ee870 100644 --- a/api/db/migrations/20230201130846_create-training-trigger-tubes-table.js +++ b/api/db/migrations/20230201130846_create-training-trigger-tubes-table.js @@ -1,6 +1,6 @@ const TABLE_NAME = 'training-trigger-tubes'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.createTable(TABLE_NAME, (t) => { t.increments().primary(); t.integer('trainingTriggerId').references('training-triggers.id').notNullable(); @@ -12,6 +12,8 @@ exports.up = function (knex) { }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropTable(TABLE_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20230209132840_add-created-at-index-on-pole-emploi-sendings.js b/api/db/migrations/20230209132840_add-created-at-index-on-pole-emploi-sendings.js index c14dfc3a4b4..563847c3661 100644 --- a/api/db/migrations/20230209132840_add-created-at-index-on-pole-emploi-sendings.js +++ b/api/db/migrations/20230209132840_add-created-at-index-on-pole-emploi-sendings.js @@ -1,22 +1,16 @@ const TABLE_NAME = 'pole-emploi-sendings'; const COLUMN_NAME = 'createdAt'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.index(COLUMN_NAME); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropIndex(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230209172400_create-unique-constrain-for-target-profile-trainings-table.js b/api/db/migrations/20230209172400_create-unique-constrain-for-target-profile-trainings-table.js index fc5ae3aa9eb..f84ae0be6ce 100644 --- a/api/db/migrations/20230209172400_create-unique-constrain-for-target-profile-trainings-table.js +++ b/api/db/migrations/20230209172400_create-unique-constrain-for-target-profile-trainings-table.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'target-profile-trainings'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (t) { t.unique(['targetProfileId', 'trainingId']); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['targetProfileId', 'trainingId']); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230301100017_add-is-first-skill-column-on-stage.js b/api/db/migrations/20230301100017_add-is-first-skill-column-on-stage.js index d05d620590b..cc28b1e012f 100644 --- a/api/db/migrations/20230301100017_add-is-first-skill-column-on-stage.js +++ b/api/db/migrations/20230301100017_add-is-first-skill-column-on-stage.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'stages'; const IS_FIRST_SKILL = 'isFirstSkill'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.boolean(IS_FIRST_SKILL).defaultTo(false); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(IS_FIRST_SKILL); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230307144120_add-locale-column-to-users-table.js b/api/db/migrations/20230307144120_add-locale-column-to-users-table.js index fe9c4154624..1cafe779f1b 100644 --- a/api/db/migrations/20230307144120_add-locale-column-to-users-table.js +++ b/api/db/migrations/20230307144120_add-locale-column-to-users-table.js @@ -1,7 +1,7 @@ const TABLE_NAME = 'users'; const COLUMN_NAME = 'locale'; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.string(COLUMN_NAME).defaultTo(null); }); @@ -11,8 +11,10 @@ exports.up = async function (knex) { ); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230316155007_add-unicity-constraint-on-column-code-campaign.js b/api/db/migrations/20230316155007_add-unicity-constraint-on-column-code-campaign.js index 255aff7b3d6..f1ce6eff10e 100644 --- a/api/db/migrations/20230316155007_add-unicity-constraint-on-column-code-campaign.js +++ b/api/db/migrations/20230316155007_add-unicity-constraint-on-column-code-campaign.js @@ -1,13 +1,15 @@ const TABLE_NAME = 'campaigns'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.alterTable(TABLE_NAME, function (t) { t.unique('code'); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique('code'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230404075638_add-constraint-on-lang-column-from-users-table.js b/api/db/migrations/20230404075638_add-constraint-on-lang-column-from-users-table.js index 4dc9e13d97e..eaca05d23f4 100644 --- a/api/db/migrations/20230404075638_add-constraint-on-lang-column-from-users-table.js +++ b/api/db/migrations/20230404075638_add-constraint-on-lang-column-from-users-table.js @@ -1,7 +1,9 @@ -exports.up = async function (knex) { +const up = async function (knex) { return knex.raw('ALTER TABLE "users" ADD CONSTRAINT "users_lang_check" CHECK ( "lang" IN (\'fr\', \'en\') )'); }; -exports.down = async function (knex) { +const down = async function (knex) { return knex.raw('ALTER TABLE "users" DROP CONSTRAINT "users_lang_check"'); }; + +export { up, down }; diff --git a/api/db/migrations/20230404151231_add-features-table.js b/api/db/migrations/20230404151231_add-features-table.js index ca1d13472d2..f204ef9516a 100644 --- a/api/db/migrations/20230404151231_add-features-table.js +++ b/api/db/migrations/20230404151231_add-features-table.js @@ -1,7 +1,7 @@ const TABLE_NAME_FEATURES = 'features'; const TABLE_NAME_ORGANIZATION_FEATURES = 'organization-features'; -exports.up = async (knex) => { +const up = async function (knex) { await knex.schema.createTable(TABLE_NAME_FEATURES, (t) => { t.bigIncrements().primary(); t.string('key').notNullable().unique(); @@ -15,8 +15,10 @@ exports.up = async (knex) => { }); }; -exports.down = async (knex) => { +const down = async function (knex) { await knex.schema.dropTable(TABLE_NAME_FEATURES); return knex.schema.dropTable(TABLE_NAME_ORGANIZATION_FEATURES); }; + +export { up, down }; diff --git a/api/db/migrations/20230407090348_add-multiple-sending-feature.js b/api/db/migrations/20230407090348_add-multiple-sending-feature.js index edbbf9ca7f4..a5a333f464c 100644 --- a/api/db/migrations/20230407090348_add-multiple-sending-feature.js +++ b/api/db/migrations/20230407090348_add-multiple-sending-feature.js @@ -1,20 +1,15 @@ const TABLE_NAME = 'features'; const MULTIPLE_SENDING_KEY = 'MULTIPLE_SENDING_ASSESSMENT'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = function (knex) { + +const up = function (knex) { return knex(TABLE_NAME).insert({ key: MULTIPLE_SENDING_KEY, description: "Permet d'activer l'envoi multiple sur les campagnes d'évaluation", }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex(TABLE_NAME).where({ key: MULTIPLE_SENDING_KEY }).delete(); }; + +export { up, down }; diff --git a/api/db/migrations/20230413141704_add-deleted-on-organization-learners.js b/api/db/migrations/20230413141704_add-deleted-on-organization-learners.js index 2aba2da16b6..32ff55e1ef7 100644 --- a/api/db/migrations/20230413141704_add-deleted-on-organization-learners.js +++ b/api/db/migrations/20230413141704_add-deleted-on-organization-learners.js @@ -1,22 +1,17 @@ const TABLE_NAME = 'organization-learners'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = async function (knex) { + +const up = async function (knex) { await knex.schema.table(TABLE_NAME, function (table) { table.dateTime('deletedAt').nullable(); table.bigInteger('deletedBy').index().references('users.id').nullable(); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn('deletedAt'); table.dropColumn('deletedBy'); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230419155621_add-view-for-not-deleted-learners.js b/api/db/migrations/20230419155621_add-view-for-not-deleted-learners.js index 2541ee377db..3f9e384dec5 100644 --- a/api/db/migrations/20230419155621_add-view-for-not-deleted-learners.js +++ b/api/db/migrations/20230419155621_add-view-for-not-deleted-learners.js @@ -1,20 +1,14 @@ const VIEW_NAME = 'view-active-organization-learners'; const REFERENCE_TABLE_NAME = 'organization-learners'; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.createView(VIEW_NAME, function (view) { view.as(knex(REFERENCE_TABLE_NAME).whereNull('deletedAt')); }); }; -/** - * @param { import("knex").Knex } knex - * @returns { Promise } - */ -exports.down = function (knex) { +const down = function (knex) { return knex.schema.dropView(VIEW_NAME); }; + +export { up, down }; diff --git a/api/db/migrations/20230425073218_remove-useless-trainings-columns.js b/api/db/migrations/20230425073218_remove-useless-trainings-columns.js index d4d47d30438..67da8e7b990 100644 --- a/api/db/migrations/20230425073218_remove-useless-trainings-columns.js +++ b/api/db/migrations/20230425073218_remove-useless-trainings-columns.js @@ -2,16 +2,18 @@ const TABLE_NAME = 'trainings'; const COLUMN_NAME_PREREQUISITE_THRESHOLD = 'prerequisiteThreshold'; const COLUMN_NAME_GOAL_THRESHOLD = 'goalThreshold'; -exports.up = function (knex) { +const up = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.dropColumn(COLUMN_NAME_PREREQUISITE_THRESHOLD); table.dropColumn(COLUMN_NAME_GOAL_THRESHOLD); }); }; -exports.down = function (knex) { +const down = function (knex) { return knex.schema.table(TABLE_NAME, function (table) { table.integer(COLUMN_NAME_PREREQUISITE_THRESHOLD).nullable().defaultTo(null); table.integer(COLUMN_NAME_GOAL_THRESHOLD).nullable().defaultTo(null); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230428085103_add-constraint-feature-organizations.js b/api/db/migrations/20230428085103_add-constraint-feature-organizations.js index 3eb6e033a0a..fd2ba77c82e 100644 --- a/api/db/migrations/20230428085103_add-constraint-feature-organizations.js +++ b/api/db/migrations/20230428085103_add-constraint-feature-organizations.js @@ -1,14 +1,16 @@ const TABLE_NAME = 'organization-features'; const CONSTRAINT_NAME = 'organizationId_featureId_unique'; -exports.up = async (knex) => { +const up = async function (knex) { return knex.schema.alterTable(TABLE_NAME, (table) => { table.unique(['organizationId', 'featureId'], CONSTRAINT_NAME); }); }; -exports.down = (knex) => { +const down = function (knex) { return knex.schema.table(TABLE_NAME, (table) => { table.dropUnique(['organizationId', 'featureId'], CONSTRAINT_NAME); }); }; + +export { up, down }; diff --git a/api/db/migrations/20230509103000_add-complementary-certifications-extratime.js b/api/db/migrations/20230509103000_add-complementary-certifications-extratime.js index b297639d89a..d8ad426a440 100644 --- a/api/db/migrations/20230509103000_add-complementary-certifications-extratime.js +++ b/api/db/migrations/20230509103000_add-complementary-certifications-extratime.js @@ -4,7 +4,7 @@ const COLUMN_CERTIFICATION_EXTRATIME = 'certificationExtraTime'; const VALUE_PIXPLUS_KEYS = ['DROIT', 'EDU_1ER_DEGRE', 'EDU_2ND_DEGRE']; const VALUE_PIX_PLUS_EXTRATIME_MINUTES = 45; -exports.up = async function (knex) { +const up = async function (knex) { await knex.schema.table(TABLE_COMPLEMENTARY_CERTIFICATIONS, function (table) { table.integer(COLUMN_CERTIFICATION_EXTRATIME).defaultTo(0).notNullable(); }); @@ -14,8 +14,10 @@ exports.up = async function (knex) { .update({ [COLUMN_CERTIFICATION_EXTRATIME]: VALUE_PIX_PLUS_EXTRATIME_MINUTES }); }; -exports.down = async function (knex) { +const down = async function (knex) { await knex.schema.table(TABLE_COMPLEMENTARY_CERTIFICATIONS, function (table) { table.dropColumn(COLUMN_CERTIFICATION_EXTRATIME); }); }; + +export { up, down }; diff --git a/api/db/pgsql-errors.js b/api/db/pgsql-errors.js index 30db02610d0..bd24c2cf6c0 100644 --- a/api/db/pgsql-errors.js +++ b/api/db/pgsql-errors.js @@ -3,7 +3,7 @@ const PGSQL_NON_EXISTENT_DATABASE_ERROR = '3D000'; const PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR = '23505'; const PGSQL_FOREIGN_KEY_VIOLATION_ERROR = '23503'; -module.exports = { +export { PGSQL_DUPLICATE_DATABASE_ERROR, PGSQL_NON_EXISTENT_DATABASE_ERROR, PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR, diff --git a/api/db/seeds/.eslintrc.yaml b/api/db/seeds/.eslintrc.yaml index 2cb0fd7ff33..de2e8530ad6 100644 --- a/api/db/seeds/.eslintrc.yaml +++ b/api/db/seeds/.eslintrc.yaml @@ -1,4 +1,4 @@ -extends: ../../../.eslintrc.yaml +extends: ../../.eslintrc.yaml rules: no-restricted-syntax: off diff --git a/api/db/seeds/data/answers-builder.js b/api/db/seeds/data/answers-builder.js index 6ede6644910..67e83c30d05 100644 --- a/api/db/seeds/data/answers-builder.js +++ b/api/db/seeds/data/answers-builder.js @@ -1,7 +1,6 @@ -module.exports = function answersBuilder({ databaseBuilder }) { - +const answersBuilder = function ({ databaseBuilder }) { databaseBuilder.factory.buildAnswer({ - value: 'Num1: \'4\'\nNum2: \'1\'\nNum3: \'5\'\n', + value: "Num1: '4'\nNum2: '1'\nNum3: '5'\n", result: 'ok', assessmentId: 1, challengeId: 'recLJCLC2oFbCmcxB', @@ -29,7 +28,7 @@ module.exports = function answersBuilder({ databaseBuilder }) { resultDetails: 'null', }); databaseBuilder.factory.buildAnswer({ - value: 'num1: \'2\'\nnum2: \'6\'\nnum3: \'7\'\nnum4: \'11\'\nnum5: \'12\'\nnum6: \'14\'\n', + value: "num1: '2'\nnum2: '6'\nnum3: '7'\nnum4: '11'\nnum5: '12'\nnum6: '14'\n", result: 'ok', assessmentId: 1, challengeId: 'recQk6B0xxvvorRzr', @@ -43,7 +42,7 @@ module.exports = function answersBuilder({ databaseBuilder }) { resultDetails: 'null', }); databaseBuilder.factory.buildAnswer({ - value: 'nb1: \'3\'\nnb2: \'2\'\nnb3: \'3\'\n', + value: "nb1: '3'\nnb2: '2'\nnb3: '3'\n", result: 'ok', assessmentId: 1, challengeId: 'recukHSP5ieZyB196', @@ -57,7 +56,7 @@ module.exports = function answersBuilder({ databaseBuilder }) { resultDetails: 'null', }); databaseBuilder.factory.buildAnswer({ - value: 'marc: \'2\'\ndeborah: B\n', + value: "marc: '2'\ndeborah: B\n", result: 'ok', assessmentId: 1, challengeId: 'recyz0bzFhouQl4I7', @@ -85,14 +84,14 @@ module.exports = function answersBuilder({ databaseBuilder }) { resultDetails: 'null', }); databaseBuilder.factory.buildAnswer({ - value: 'Penses-tu que \xe7a l\'emb\xeatera ?', + value: "Penses-tu que \xe7a l'emb\xeatera ?", result: 'ok', assessmentId: 2, challengeId: 'recd5XFUKpLcIdQsS', resultDetails: 'null', }); databaseBuilder.factory.buildAnswer({ - value: 'retrait: \'2\'\navant: \'9\'\napres: \'9\'\n', + value: "retrait: '2'\navant: '9'\napres: '9'\n", result: 'ok', assessmentId: 2, challengeId: 'recbTdMpoiALypx17', @@ -242,7 +241,8 @@ module.exports = function answersBuilder({ databaseBuilder }) { resultDetails: 'null', }); databaseBuilder.factory.buildAnswer({ - value: 'directeur: Emmanuel Giannesini\nresponsable: Mission de la communication du CNOUS\nhebergeur: V-Technologies\n', + value: + 'directeur: Emmanuel Giannesini\nresponsable: Mission de la communication du CNOUS\nhebergeur: V-Technologies\n', result: 'ok', assessmentId: 3, challengeId: 'reccAbZXt0i5NH4cL', @@ -305,7 +305,7 @@ module.exports = function answersBuilder({ databaseBuilder }) { resultDetails: 'station1: true\nstation2: true\n', }); databaseBuilder.factory.buildAnswer({ - value: 'an: \'2006\'\ntit: F\xe9d\xe9ration Hospitali\xe8re de France\n', + value: "an: '2006'\ntit: F\xe9d\xe9ration Hospitali\xe8re de France\n", result: 'ok', assessmentId: 3, challengeId: 'recTstqP2DAooIwOk', @@ -410,7 +410,8 @@ module.exports = function answersBuilder({ databaseBuilder }) { resultDetails: 'null', }); databaseBuilder.factory.buildAnswer({ - value: 'nb1: fausse r\xe9ponse\nnb2: fausse r\xe9ponse\nnb3: fausse r\xe9ponse\nnb4: fausse r\xe9ponse\nnb5: fausse r\xe9ponse\n', + value: + 'nb1: fausse r\xe9ponse\nnb2: fausse r\xe9ponse\nnb3: fausse r\xe9ponse\nnb4: fausse r\xe9ponse\nnb5: fausse r\xe9ponse\n', result: 'ko', assessmentId: 4, challengeId: 'receT1FE9cfqn6C4V', @@ -564,3 +565,5 @@ module.exports = function answersBuilder({ databaseBuilder }) { resultDetails: 'null', }); }; + +export { answersBuilder }; diff --git a/api/db/seeds/data/assessments-builder.js b/api/db/seeds/data/assessments-builder.js index b84b6409b3a..e6da673e445 100644 --- a/api/db/seeds/data/assessments-builder.js +++ b/api/db/seeds/data/assessments-builder.js @@ -1,5 +1,4 @@ -module.exports = function assessmentsBuilder({ databaseBuilder }) { - +const assessmentsBuilder = function ({ databaseBuilder }) { // PLACEMENT databaseBuilder.factory.buildAssessment({ id: 1, @@ -62,3 +61,5 @@ module.exports = function assessmentsBuilder({ databaseBuilder }) { state: 'started', }); }; + +export { assessmentsBuilder }; diff --git a/api/db/seeds/data/badges-builder.js b/api/db/seeds/data/badges-builder.js index 6c66e901750..69d646410b4 100644 --- a/api/db/seeds/data/badges-builder.js +++ b/api/db/seeds/data/badges-builder.js @@ -19,9 +19,10 @@ const PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_AVANCE_BADGE_ID = 127; const PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_EXPERT_BADGE_ID = 128; const PIX_EMPLOI_CLEA_BADGE_ID_V3 = 129; -const BadgeCriterion = require('../../../lib/domain/models/BadgeCriterion'); -const { badges } = require('../../constants'); -const { +import { BadgeCriterion } from '../../../lib/domain/models/BadgeCriterion.js'; +import { badges } from '../../constants.js'; + +import { targetProfileSkillIdsForCleaBadgeV1, targetProfileSkillIdsForCleaBadgeV2, targetProfileSkillIdsForCleaBadgeV3, @@ -35,7 +36,7 @@ const { TARGET_PROFILE_PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE, TARGET_PROFILE_PIX_EDU_FORMATION_INITIALE_1ER_DEGRE, TARGET_PROFILE_PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE, -} = require('./target-profiles-builder'); +} from './target-profiles-builder.js'; function badgesBuilder({ databaseBuilder }) { _createBasicsBadge(databaseBuilder); @@ -113,7 +114,7 @@ function _createBasicsBadge(databaseBuilder) { imageUrl: 'https://images.pix.fr/badges/socle-de-base.svg', key: 'Basics', message: - 'Bravo ! Vous maîtrisez quelques bases du numérique comme le vocabulaire, la manipulation basique ou l\'utilisation d\'outils', + "Bravo ! Vous maîtrisez quelques bases du numérique comme le vocabulaire, la manipulation basique ou l'utilisation d'outils", targetProfileId: TARGET_PROFILE_STAGES_BADGES_ID, }); @@ -159,7 +160,7 @@ function _createManipBadge(databaseBuilder) { imageUrl: 'https://images.pix.fr/badges/office.svg', key: 'Manip', message: - 'Vous maîtrisez les gestes de base : le clic, la saisie de texte et la navigation entre onglets d\'un navigateur WEB', + "Vous maîtrisez les gestes de base : le clic, la saisie de texte et la navigation entre onglets d'un navigateur WEB", targetProfileId: TARGET_PROFILE_STAGES_BADGES_ID, }); @@ -398,14 +399,14 @@ function _createPixDroitBadge(databaseBuilder) { const skillSetsMasterIds = _associatePixDroitMasterSkillSets( databaseBuilder, targetProfileSkillIdsForPixDroitBadge, - pixDroitMasterBadge, + pixDroitMasterBadge ); _associatePixDroitMasterBadgeCriteria(databaseBuilder, pixDroitMasterBadge, skillSetsMasterIds); const skillSetsExpertIds = _associatePixDroitExpertSkillSets( databaseBuilder, targetProfileSkillIdsForPixDroitBadge, - pixDroitExpertBadge, + pixDroitExpertBadge ); _associatePixDroitExpertBadgeCriteria(databaseBuilder, pixDroitExpertBadge, skillSetsExpertIds); } @@ -512,7 +513,7 @@ function _createPixEduBadges(databaseBuilder) { databaseBuilder, skillIdsForPixEduDomain1, skillIdsForPixEduDomain2, - pixEduFormationInitiale2ndDegreInitieBadge, + pixEduFormationInitiale2ndDegreInitieBadge ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, @@ -541,7 +542,7 @@ function _createPixEduBadges(databaseBuilder) { databaseBuilder, skillIdsForPixEduDomain1, skillIdsForPixEduDomain2, - pixEduFormationInitiale1erDegreInitieBadge, + pixEduFormationInitiale1erDegreInitieBadge ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, @@ -566,12 +567,13 @@ function _createPixEduBadges(databaseBuilder) { isCertifiable: true, targetProfileId: TARGET_PROFILE_PIX_EDU_FORMATION_INITIALE_2ND_DEGRE, }); - const [domain1Confirme2ndDegreSkillSetId, domain2Confirme2ndDegreSkillSetId] = _associatePixEduFormationInitialeSkillSets( - databaseBuilder, - skillIdsForPixEduDomain1, - skillIdsForPixEduDomain2, - pixEduFormationInitiale2ndDegreConfirmeBadge, - ); + const [domain1Confirme2ndDegreSkillSetId, domain2Confirme2ndDegreSkillSetId] = + _associatePixEduFormationInitialeSkillSets( + databaseBuilder, + skillIdsForPixEduDomain1, + skillIdsForPixEduDomain2, + pixEduFormationInitiale2ndDegreConfirmeBadge + ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, threshold: 60, @@ -595,12 +597,13 @@ function _createPixEduBadges(databaseBuilder) { isCertifiable: true, targetProfileId: TARGET_PROFILE_PIX_EDU_FORMATION_INITIALE_1ER_DEGRE, }); - const [domain1Confirme1erDegreSkillSetId, domain2Confirme1erDegreSkillSetId] = _associatePixEduFormationInitialeSkillSets( - databaseBuilder, - skillIdsForPixEduDomain1, - skillIdsForPixEduDomain2, - pixEduFormationInitiale1erDegreConfirmeBadge, - ); + const [domain1Confirme1erDegreSkillSetId, domain2Confirme1erDegreSkillSetId] = + _associatePixEduFormationInitialeSkillSets( + databaseBuilder, + skillIdsForPixEduDomain1, + skillIdsForPixEduDomain2, + pixEduFormationInitiale1erDegreConfirmeBadge + ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, threshold: 60, @@ -627,7 +630,7 @@ function _createPixEduBadges(databaseBuilder) { const [domain3Confirme2ndDegreSkillSetId] = _associatePixEduFormationContinueSkillSets( databaseBuilder, skillIdsForPixEduDomain3, - pixEduFormationContinue2ndDegreConfirmeBadge, + pixEduFormationContinue2ndDegreConfirmeBadge ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, @@ -649,7 +652,7 @@ function _createPixEduBadges(databaseBuilder) { const [domain3Confirme1erDegreSkillSetId] = _associatePixEduFormationContinueSkillSets( databaseBuilder, skillIdsForPixEduDomain3, - pixEduFormationContinue1erDegreConfirmeBadge, + pixEduFormationContinue1erDegreConfirmeBadge ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, @@ -671,7 +674,7 @@ function _createPixEduBadges(databaseBuilder) { const [domain3Avance2ndDegreSkillSetId] = _associatePixEduFormationContinueSkillSets( databaseBuilder, skillIdsForPixEduDomain3, - pixEduFormationContinue2ndDegreAvanceBadge, + pixEduFormationContinue2ndDegreAvanceBadge ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, @@ -693,7 +696,7 @@ function _createPixEduBadges(databaseBuilder) { const [domain3Avance1erDegreSkillSetId] = _associatePixEduFormationContinueSkillSets( databaseBuilder, skillIdsForPixEduDomain3, - pixEduFormationContinue1erDegreAvanceBadge, + pixEduFormationContinue1erDegreAvanceBadge ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, @@ -715,7 +718,7 @@ function _createPixEduBadges(databaseBuilder) { const [domain3Expert2ndDegreSkillSetId] = _associatePixEduFormationContinueSkillSets( databaseBuilder, skillIdsForPixEduDomain3, - pixEduFormationContinue2ndDegreExpertBadge, + pixEduFormationContinue2ndDegreExpertBadge ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, @@ -737,7 +740,7 @@ function _createPixEduBadges(databaseBuilder) { const [domain3Expert1erDegreSkillSetId] = _associatePixEduFormationContinueSkillSets( databaseBuilder, skillIdsForPixEduDomain3, - pixEduFormationContinue1erDegreExpertBadge, + pixEduFormationContinue1erDegreExpertBadge ); databaseBuilder.factory.buildBadgeCriterion({ scope: BadgeCriterion.SCOPES.SKILL_SET, @@ -772,7 +775,7 @@ function _associateSkillSets(databaseBuilder, targetProfileSkillIds, badge) { name: 'Partager sur les réseaux sociaux', skillIds: targetProfileSkillIds[3].map((id) => id), badgeId: badge.id, - }), + }) ); } @@ -815,7 +818,7 @@ function _associatePixDroitMasterSkillSets(databaseBuilder, targetProfileSkillId name: 'Domaine Pix+ Droit Domaine 10', skillIds: targetProfileSkillIds[3].map((id) => id), badgeId: badge.id, - }), + }) ); } @@ -843,7 +846,7 @@ function _associatePixDroitExpertSkillSets(databaseBuilder, targetProfileSkillId name: 'Domaine Pix+ Droit Domaine 10', skillIds: targetProfileSkillIds[3].map((id) => id), badgeId: badge.id, - }), + }) ); } @@ -893,7 +896,7 @@ function _associatePixEduFormationInitialeSkillSets( databaseBuilder, skillIdsForPixEduDomain1, skillIdsForPixEduDomain2, - badge, + badge ) { return _returnIds( databaseBuilder.factory.buildSkillSet({ @@ -905,7 +908,7 @@ function _associatePixEduFormationInitialeSkillSets( name: 'Domaine Pix+ Édu Domaine 2', skillIds: skillIdsForPixEduDomain2.map((id) => id), badgeId: badge.id, - }), + }) ); } @@ -915,11 +918,11 @@ function _associatePixEduFormationContinueSkillSets(databaseBuilder, skillIdsFor name: 'Domaine Pix+ Édu Domaine 3', skillIds: skillIdsForPixEduDomain3.map((id) => id), badgeId: badge.id, - }), + }) ); } -module.exports = { +export { badgesBuilder, PIX_EMPLOI_CLEA_BADGE_ID_V1, PIX_EMPLOI_CLEA_BADGE_ID_V2, diff --git a/api/db/seeds/data/campaign-participations-builder.js b/api/db/seeds/data/campaign-participations-builder.js index 955035fd876..30c2a41f82d 100644 --- a/api/db/seeds/data/campaign-participations-builder.js +++ b/api/db/seeds/data/campaign-participations-builder.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const Assessment = require('../../../lib/domain/models/Assessment'); -const CampaignParticipationStatuses = require('../../../lib/domain/models/CampaignParticipationStatuses'); -const KnowledgeElement = require('../../../lib/domain/models/KnowledgeElement'); -const { PIX_SUPER_ADMIN_ID } = require('./users-builder'); +import _ from 'lodash'; +import { Assessment } from '../../../lib/domain/models/Assessment.js'; +import { CampaignParticipationStatuses } from '../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { KnowledgeElement } from '../../../lib/domain/models/KnowledgeElement.js'; +import { PIX_SUPER_ADMIN_ID } from './users-builder.js'; const { SHARED, STARTED } = CampaignParticipationStatuses; @@ -89,7 +89,15 @@ function _buildAssessmentAndAnswer({ databaseBuilder, userId, campaignParticipat }); } -function participateToAssessmentCampaign({ databaseBuilder, campaignId, user, organizationLearnerId, status, isImprovingOldParticipation = false, deleted = false }) { +function participateToAssessmentCampaign({ + databaseBuilder, + campaignId, + user, + organizationLearnerId, + status, + isImprovingOldParticipation = false, + deleted = false, +}) { const today = new Date(); const sharedAt = status === SHARED ? today : null; const deletedAt = deleted ? today : null; @@ -108,7 +116,13 @@ function participateToAssessmentCampaign({ databaseBuilder, campaignId, user, or deletedBy, }); - _buildAssessmentAndAnswer({ databaseBuilder, userId, campaignParticipationId, status, hasSomeFailures: _.sample([true, false]) }); + _buildAssessmentAndAnswer({ + databaseBuilder, + userId, + campaignParticipationId, + status, + hasSomeFailures: _.sample([true, false]), + }); if (isImprovingOldParticipation) { const { id: oldCampaignParticipationId } = databaseBuilder.factory.buildCampaignParticipation({ @@ -121,12 +135,28 @@ function participateToAssessmentCampaign({ databaseBuilder, campaignId, user, or sharedAt: user.createdAt, isImproved: true, }); - _buildAssessmentAndAnswer({ databaseBuilder, userId, campaignParticipationId: oldCampaignParticipationId, status: SHARED, hasSomeFailures: true }); + _buildAssessmentAndAnswer({ + databaseBuilder, + userId, + campaignParticipationId: oldCampaignParticipationId, + status: SHARED, + hasSomeFailures: true, + }); } return campaignParticipationId; } -function participateToProfilesCollectionCampaign({ databaseBuilder, campaignId, user, organizationLearnerId, status, isImprovingOldParticipation = false, deleted = false, isCertifiable = null, sharedAt = null }) { +function participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId, + user, + organizationLearnerId, + status, + isImprovingOldParticipation = false, + deleted = false, + isCertifiable = null, + sharedAt = null, +}) { const today = new Date(); sharedAt = status === SHARED && sharedAt === null ? today : sharedAt; const deletedAt = deleted ? today : null; @@ -161,7 +191,4 @@ function participateToProfilesCollectionCampaign({ databaseBuilder, campaignId, } } -module.exports = { - participateToAssessmentCampaign, - participateToProfilesCollectionCampaign, -}; +export { participateToAssessmentCampaign, participateToProfilesCollectionCampaign }; diff --git a/api/db/seeds/data/campaigns-pro-builder.js b/api/db/seeds/data/campaigns-pro-builder.js index fd7f927dfca..fddf4130400 100644 --- a/api/db/seeds/data/campaigns-pro-builder.js +++ b/api/db/seeds/data/campaigns-pro-builder.js @@ -1,4 +1,4 @@ -const { +import { TARGET_PROFILE_PIC_DIAG_INITIAL_ID, TARGET_PROFILE_STAGES_BADGES_ID, TARGET_PROFILE_ONE_COMPETENCE_ID, @@ -6,30 +6,29 @@ const { TARGET_PROFILE_PIX_EMPLOI_CLEA_ID_V3, TARGET_PROFILE_PIX_DROIT_ID, TARGET_PROFILE_CNAV_ID, -} = require('./target-profiles-builder'); -const { +} from './target-profiles-builder.js'; + +import { CERTIF_REGULAR_USER1_ID, CERTIF_REGULAR_USER2_ID, CERTIF_REGULAR_USER3_ID, CERTIF_REGULAR_USER4_ID, CERTIF_REGULAR_USER5_ID, -} = require('./certification/users'); -const { PRO_BASICS_BADGE_ID, PRO_TOOLS_BADGE_ID } = require('./badges-builder'); -const { PRO_COMPANY_ID, PRO_POLE_EMPLOI_ID, PRO_MED_NUM_ID, PRO_CNAV_ID } = require('./organizations-pro-builder'); -const { DEFAULT_PASSWORD } = require('./users-builder'); -const { +} from './certification/users.js'; + +import { PRO_BASICS_BADGE_ID, PRO_TOOLS_BADGE_ID } from './badges-builder.js'; +import { PRO_COMPANY_ID, PRO_POLE_EMPLOI_ID, PRO_MED_NUM_ID, PRO_CNAV_ID } from './organizations-pro-builder.js'; +import { DEFAULT_PASSWORD } from './users-builder.js'; +import { participateToAssessmentCampaign, participateToProfilesCollectionCampaign, -} = require('./campaign-participations-builder'); -const CampaignParticipationStatuses = require('../../../lib/domain/models/CampaignParticipationStatuses'); +} from './campaign-participations-builder.js'; +import { CampaignParticipationStatuses } from '../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED, TO_SHARE, STARTED } = CampaignParticipationStatuses; const POLE_EMPLOI_CAMPAIGN_ID = 5; -module.exports = { - campaignsProBuilder, - POLE_EMPLOI_CAMPAIGN_ID, -}; +export { campaignsProBuilder, POLE_EMPLOI_CAMPAIGN_ID }; function campaignsProBuilder({ databaseBuilder }) { _buildCampaigns({ databaseBuilder }); @@ -350,23 +349,32 @@ __Plus d'infos :)__ } function _buildParticipations({ databaseBuilder }) { - const users = _buildUsers({ databaseBuilder, users: [ - { firstName: 'Jaune', lastName: 'Attend', email: 'jaune.attend@example.net', createdAt: new Date('2022-01-01') }, - { firstName: 'Mélanie', lastName: 'Darboo', createdAt: new Date('2022-01-02') }, - { firstName: 'Matteo', lastName: 'Lorenzio', createdAt: new Date('2022-01-03') }, - { firstName: 'Jérémy', lastName: 'Bugietta', createdAt: new Date('2022-01-03') }, - { firstName: 'Léo', lastName: 'Subzéro', createdAt: new Date('2022-01-05') }, - { firstName: 'Forster', lastName: 'Gillay Djones', createdAt: new Date('2022-01-05') }, - { firstName: 'Thierry', lastName: 'Donckele', createdAt: new Date('2022-01-07') }, - { firstName: 'Stéphan', lastName: 'Deumonaco', createdAt: new Date('2022-01-08') }, - { firstName: 'Lise', lastName: 'Nelkay', createdAt: new Date('2022-01-09') }, - { firstName: 'Sébastien', lastName: 'Serra Oupas', createdAt: new Date('2022-02-03') }, - { firstName: 'Thomas', lastName: 'Whiskas', createdAt: new Date('2022-02-06') }, - { firstName: 'Antoine', lastName: 'Boiduvin', createdAt: new Date('2022-02-07') }, - { firstName: 'Brandone', lastName: 'Bro', createdAt: new Date('2022-02-07') }, - { firstName: 'Jean', lastName: 'Sérien', createdAt: new Date('2022-02-07') }, - { firstName: 'Alex', lastName: 'Deleted', createdAt: new Date('2022-02-07'), deletedBy: 1, deletedAt: new Date('2023-05-01') }, - ] }); + const users = _buildUsers({ + databaseBuilder, + users: [ + { firstName: 'Jaune', lastName: 'Attend', email: 'jaune.attend@example.net', createdAt: new Date('2022-01-01') }, + { firstName: 'Mélanie', lastName: 'Darboo', createdAt: new Date('2022-01-02') }, + { firstName: 'Matteo', lastName: 'Lorenzio', createdAt: new Date('2022-01-03') }, + { firstName: 'Jérémy', lastName: 'Bugietta', createdAt: new Date('2022-01-03') }, + { firstName: 'Léo', lastName: 'Subzéro', createdAt: new Date('2022-01-05') }, + { firstName: 'Forster', lastName: 'Gillay Djones', createdAt: new Date('2022-01-05') }, + { firstName: 'Thierry', lastName: 'Donckele', createdAt: new Date('2022-01-07') }, + { firstName: 'Stéphan', lastName: 'Deumonaco', createdAt: new Date('2022-01-08') }, + { firstName: 'Lise', lastName: 'Nelkay', createdAt: new Date('2022-01-09') }, + { firstName: 'Sébastien', lastName: 'Serra Oupas', createdAt: new Date('2022-02-03') }, + { firstName: 'Thomas', lastName: 'Whiskas', createdAt: new Date('2022-02-06') }, + { firstName: 'Antoine', lastName: 'Boiduvin', createdAt: new Date('2022-02-07') }, + { firstName: 'Brandone', lastName: 'Bro', createdAt: new Date('2022-02-07') }, + { firstName: 'Jean', lastName: 'Sérien', createdAt: new Date('2022-02-07') }, + { + firstName: 'Alex', + lastName: 'Deleted', + createdAt: new Date('2022-02-07'), + deletedBy: 1, + deletedAt: new Date('2023-05-01'), + }, + ], + }); _buildParticipationsInDifferentStatus({ databaseBuilder, user: users[0] }); _buildAssessmentParticipations({ databaseBuilder, users }); @@ -378,19 +386,71 @@ function _buildParticipations({ databaseBuilder }) { function _buildUsers({ databaseBuilder, users }) { return users.map((user) => { const databaseUser = databaseBuilder.factory.buildUser.withRawPassword({ ...user, rawPassword: DEFAULT_PASSWORD }); - databaseBuilder.factory.buildOrganizationLearner({ firstName: user.firstName + '-Prescrit', lastName: user.lastName + '-Prescrit', id: databaseUser.id, userId: databaseUser.id, organizationId: PRO_COMPANY_ID, deletedBy: user.deletedBy, deletedAt: user.deletedAt }); + databaseBuilder.factory.buildOrganizationLearner({ + firstName: user.firstName + '-Prescrit', + lastName: user.lastName + '-Prescrit', + id: databaseUser.id, + userId: databaseUser.id, + organizationId: PRO_COMPANY_ID, + deletedBy: user.deletedBy, + deletedAt: user.deletedAt, + }); return databaseUser; }); } function _buildParticipationsInDifferentStatus({ databaseBuilder, user }) { - participateToAssessmentCampaign({ databaseBuilder, campaignId: 22, user, organizationLearnerId: user.id, status: STARTED, deleted: true }); //deleted + started - participateToAssessmentCampaign({ databaseBuilder, campaignId: 21, user, organizationLearnerId: user.id, status: SHARED, deleted: true }); //deleted + shared - participateToAssessmentCampaign({ databaseBuilder, campaignId: 2, user, organizationLearnerId: user.id, status: STARTED }); //started - participateToAssessmentCampaign({ databaseBuilder, campaignId: 12, user, organizationLearnerId: user.id, status: TO_SHARE }); //to share - participateToAssessmentCampaign({ databaseBuilder, campaignId: 13, user, organizationLearnerId: user.id, status: SHARED });//archived + shared - participateToAssessmentCampaign({ databaseBuilder, campaignId: 14, user, organizationLearnerId: user.id, status: STARTED });//archived + started - participateToAssessmentCampaign({ databaseBuilder, campaignId: 15, user, organizationLearnerId: user.id, status: SHARED });//archived + shared + badges + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 22, + user, + organizationLearnerId: user.id, + status: STARTED, + deleted: true, + }); //deleted + started + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 21, + user, + organizationLearnerId: user.id, + status: SHARED, + deleted: true, + }); //deleted + shared + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 2, + user, + organizationLearnerId: user.id, + status: STARTED, + }); //started + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 12, + user, + organizationLearnerId: user.id, + status: TO_SHARE, + }); //to share + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 13, + user, + organizationLearnerId: user.id, + status: SHARED, + }); //archived + shared + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 14, + user, + organizationLearnerId: user.id, + status: STARTED, + }); //archived + started + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 15, + user, + organizationLearnerId: user.id, + status: SHARED, + }); //archived + shared + badges } function _buildAssessmentParticipations({ databaseBuilder, users }) { @@ -401,29 +461,129 @@ function _buildAssessmentParticipations({ databaseBuilder, users }) { const userIdsCompletedShared2 = [users[0], users[9]]; const userIdsCompletedSharedWith2Badges = [users[3], users[11]]; - userIdsNotCompleted.forEach((user) => participateToAssessmentCampaign({ databaseBuilder, campaignId: 1, user, organizationLearnerId: user.id, status: STARTED })); - userIdsNotShared.forEach((user) => participateToAssessmentCampaign({ databaseBuilder, campaignId: 1, user, organizationLearnerId: user.id, status: TO_SHARE })); + userIdsNotCompleted.forEach((user) => + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 1, + user, + organizationLearnerId: user.id, + status: STARTED, + }) + ); + userIdsNotShared.forEach((user) => + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 1, + user, + organizationLearnerId: user.id, + status: TO_SHARE, + }) + ); userIdsNotShared2.forEach((user) => { - const campaignParticipationId = participateToAssessmentCampaign({ databaseBuilder, campaignId: 1, user, organizationLearnerId: user.id, status: TO_SHARE }); - databaseBuilder.factory.buildBadgeAcquisition({ userId: user.id, badgeId: PRO_BASICS_BADGE_ID, campaignParticipationId }); + const campaignParticipationId = participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 1, + user, + organizationLearnerId: user.id, + status: TO_SHARE, + }); + databaseBuilder.factory.buildBadgeAcquisition({ + userId: user.id, + badgeId: PRO_BASICS_BADGE_ID, + campaignParticipationId, + }); }); - userIdsCompletedShared.forEach((user) => participateToAssessmentCampaign({ databaseBuilder, campaignId: 1, user, organizationLearnerId: user.id, status: SHARED })); + userIdsCompletedShared.forEach((user) => + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 1, + user, + organizationLearnerId: user.id, + status: SHARED, + }) + ); userIdsCompletedShared2.forEach((user) => { - const campaignParticipationId = participateToAssessmentCampaign({ databaseBuilder, campaignId: 1, user, organizationLearnerId: user.id, status: SHARED }); - databaseBuilder.factory.buildBadgeAcquisition({ userId: user.id, badgeId: PRO_TOOLS_BADGE_ID, campaignParticipationId }); + const campaignParticipationId = participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 1, + user, + organizationLearnerId: user.id, + status: SHARED, + }); + databaseBuilder.factory.buildBadgeAcquisition({ + userId: user.id, + badgeId: PRO_TOOLS_BADGE_ID, + campaignParticipationId, + }); }); userIdsCompletedSharedWith2Badges.forEach((user) => { - const campaignParticipationId = participateToAssessmentCampaign({ databaseBuilder, campaignId: 1, user, organizationLearnerId: user.id, status: SHARED }); - databaseBuilder.factory.buildBadgeAcquisition({ userId: user.id, badgeId: PRO_BASICS_BADGE_ID, campaignParticipationId }); - databaseBuilder.factory.buildBadgeAcquisition({ userId: user.id, badgeId: PRO_TOOLS_BADGE_ID, campaignParticipationId }); + const campaignParticipationId = participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 1, + user, + organizationLearnerId: user.id, + status: SHARED, + }); + databaseBuilder.factory.buildBadgeAcquisition({ + userId: user.id, + badgeId: PRO_BASICS_BADGE_ID, + campaignParticipationId, + }); + databaseBuilder.factory.buildBadgeAcquisition({ + userId: user.id, + badgeId: PRO_TOOLS_BADGE_ID, + campaignParticipationId, + }); }); //multiple sendings profiles collection campaign - userIdsNotCompleted.forEach((user) => participateToAssessmentCampaign({ databaseBuilder, campaignId: 16, user, organizationLearnerId: user.id, status: STARTED })); - userIdsNotShared.forEach((user) => participateToAssessmentCampaign({ databaseBuilder, campaignId: 16, user, organizationLearnerId: user.id, status: TO_SHARE })); - userIdsNotShared2.forEach((user) => participateToAssessmentCampaign({ databaseBuilder, campaignId: 16, user, organizationLearnerId: user.id, status: TO_SHARE, isImprovingOldParticipation: true })); - userIdsCompletedShared.forEach((user) => participateToAssessmentCampaign({ databaseBuilder, campaignId: 16, user, organizationLearnerId: user.id, status: SHARED })); - userIdsCompletedShared2.forEach((user) => participateToAssessmentCampaign({ databaseBuilder, campaignId: 16, user, organizationLearnerId: user.id, status: SHARED, isImprovingOldParticipation: true })); + userIdsNotCompleted.forEach((user) => + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 16, + user, + organizationLearnerId: user.id, + status: STARTED, + }) + ); + userIdsNotShared.forEach((user) => + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 16, + user, + organizationLearnerId: user.id, + status: TO_SHARE, + }) + ); + userIdsNotShared2.forEach((user) => + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 16, + user, + organizationLearnerId: user.id, + status: TO_SHARE, + isImprovingOldParticipation: true, + }) + ); + userIdsCompletedShared.forEach((user) => + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 16, + user, + organizationLearnerId: user.id, + status: SHARED, + }) + ); + userIdsCompletedShared2.forEach((user) => + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 16, + user, + organizationLearnerId: user.id, + status: SHARED, + isImprovingOldParticipation: true, + }) + ); } function _buildProfilesCollectionParticipations({ databaseBuilder, users }) { @@ -436,26 +596,106 @@ function _buildProfilesCollectionParticipations({ databaseBuilder, users }) { const certifRegularUser5 = { id: CERTIF_REGULAR_USER5_ID, createdAt: new Date('2022-02-07') }; const userIdsNotShared = [users[1], users[2], users[3], users[4], users[5], users[6], users[7], users[8]]; const userIdsShared = [users[0], users[9], users[10], users[11], users[12]]; - const userIdsCertifiable = [users[10].id, users[11].id, users[12].id, certifRegularUser1.id, certifRegularUser2.id, certifRegularUser3.id]; - - [certifRegularUser1, certifRegularUser2, certifRegularUser3, certifRegularUser4, certifRegularUser5].forEach((certifUser, index) => { - databaseBuilder.factory.buildOrganizationLearner({ lastName: `Certif${index}`, firstName: `User${index}`, id: certifUser.id, userId: certifUser.id, organizationId: PRO_COMPANY_ID }); - }); - - [...userIdsNotShared, certifRegularUser4, certifRegularUser5].forEach((user) => participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 6, user, organizationLearnerId: user.id, status: TO_SHARE })); - [...userIdsShared, certifRegularUser1, certifRegularUser2, certifRegularUser3].forEach((user) => participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 6, user, organizationLearnerId: user.id, status: SHARED, sharedAt })); + const userIdsCertifiable = [ + users[10].id, + users[11].id, + users[12].id, + certifRegularUser1.id, + certifRegularUser2.id, + certifRegularUser3.id, + ]; + + [certifRegularUser1, certifRegularUser2, certifRegularUser3, certifRegularUser4, certifRegularUser5].forEach( + (certifUser, index) => { + databaseBuilder.factory.buildOrganizationLearner({ + lastName: `Certif${index}`, + firstName: `User${index}`, + id: certifUser.id, + userId: certifUser.id, + organizationId: PRO_COMPANY_ID, + }); + } + ); + + [...userIdsNotShared, certifRegularUser4, certifRegularUser5].forEach((user) => + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 6, + user, + organizationLearnerId: user.id, + status: TO_SHARE, + }) + ); + [...userIdsShared, certifRegularUser1, certifRegularUser2, certifRegularUser3].forEach((user) => + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 6, + user, + organizationLearnerId: user.id, + status: SHARED, + sharedAt, + }) + ); //multiple sendings profiles collection campaign - userIdsShared.forEach((user) => participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 18, user, organizationLearnerId: user.id, status: SHARED, isCertifiable: userIdsCertifiable.includes(user.id) })); - userIdsNotShared.forEach((user) => participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 18, user, organizationLearnerId: user.id, status: TO_SHARE, isImprovingOldParticipation: true, isCertifiable: null })); - [certifRegularUser1, certifRegularUser2, certifRegularUser3, certifRegularUser4, certifRegularUser5].forEach((user) => participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 18, user, organizationLearnerId: user.id, status: SHARED, isImprovingOldParticipation: true })); + userIdsShared.forEach((user) => + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 18, + user, + organizationLearnerId: user.id, + status: SHARED, + isCertifiable: userIdsCertifiable.includes(user.id), + }) + ); + userIdsNotShared.forEach((user) => + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 18, + user, + organizationLearnerId: user.id, + status: TO_SHARE, + isImprovingOldParticipation: true, + isCertifiable: null, + }) + ); + [certifRegularUser1, certifRegularUser2, certifRegularUser3, certifRegularUser4, certifRegularUser5].forEach((user) => + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 18, + user, + organizationLearnerId: user.id, + status: SHARED, + isImprovingOldParticipation: true, + }) + ); //deleted participations - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 25, user: users[0], organizationLearnerId: users[0].id, status: TO_SHARE, deleted: true }); - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 26, user: users[0], organizationLearnerId: users[0].id, status: TO_SHARE, deleted: true }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 25, + user: users[0], + organizationLearnerId: users[0].id, + status: TO_SHARE, + deleted: true, + }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 26, + user: users[0], + organizationLearnerId: users[0].id, + status: TO_SHARE, + deleted: true, + }); //certificability not shared - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 18, user: users[13], organizationLearnerId: users[13].id, status: TO_SHARE }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 18, + user: users[13], + organizationLearnerId: users[13].id, + status: TO_SHARE, + }); } function _buildMedNumAssessmentParticipations({ databaseBuilder }) { @@ -473,5 +713,11 @@ function _buildMedNumAssessmentParticipations({ databaseBuilder }) { userId: anonymousUser.id, organizationId: PRO_MED_NUM_ID, }); - participateToAssessmentCampaign({ databaseBuilder, campaignId: 11, user: anonymousUser, organizationLearnerId: anonymousOrganizationLearner.id, status: SHARED }); + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 11, + user: anonymousUser, + organizationLearnerId: anonymousOrganizationLearner.id, + status: SHARED, + }); } diff --git a/api/db/seeds/data/campaigns-sco-builder.js b/api/db/seeds/data/campaigns-sco-builder.js index d155ed29e10..5eafaa216e8 100644 --- a/api/db/seeds/data/campaigns-sco-builder.js +++ b/api/db/seeds/data/campaigns-sco-builder.js @@ -1,17 +1,32 @@ -const { +import { TARGET_PROFILE_STAGES_BADGES_ID, TARGET_PROFILE_PIX_EDU_FORMATION_INITIALE_2ND_DEGRE, TARGET_PROFILE_PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE, -} = require('./target-profiles-builder'); -const { PRO_BASICS_BADGE_ID, PRO_TOOLS_BADGE_ID } = require('./badges-builder'); -const { SCO_MIDDLE_SCHOOL_ID, SCO_HIGH_SCHOOL_ID, SCO_AGRI_ID, SCO_AEFE_ID, SCO_STUDENT_ID, SCO_FRENCH_USER_ID, SCO_FOREIGNER_USER_ID, SCO_FOREIGNER_USER_ID_IN_ANOTHER_ORGANIZATION, SCO_DISABLED_USER_ID, SCO_STUDENT_NOT_CERTIFIABLE_ID } = require('./organizations-sco-builder'); -const { participateToAssessmentCampaign, participateToProfilesCollectionCampaign } = require('./campaign-participations-builder'); -const CampaignParticipationStatuses = require('../../../lib/domain/models/CampaignParticipationStatuses'); +} from './target-profiles-builder.js'; + +import { PRO_BASICS_BADGE_ID, PRO_TOOLS_BADGE_ID } from './badges-builder.js'; + +import { + SCO_MIDDLE_SCHOOL_ID, + SCO_HIGH_SCHOOL_ID, + SCO_AGRI_ID, + SCO_AEFE_ID, + SCO_STUDENT_ID, + SCO_FRENCH_USER_ID, + SCO_FOREIGNER_USER_ID, + SCO_FOREIGNER_USER_ID_IN_ANOTHER_ORGANIZATION, + SCO_DISABLED_USER_ID, + SCO_STUDENT_NOT_CERTIFIABLE_ID, +} from './organizations-sco-builder.js'; + +import { + participateToAssessmentCampaign, + participateToProfilesCollectionCampaign, +} from './campaign-participations-builder.js'; +import { CampaignParticipationStatuses } from '../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED, TO_SHARE, STARTED } = CampaignParticipationStatuses; -module.exports = { - campaignsScoBuilder, -}; +export { campaignsScoBuilder }; function campaignsScoBuilder({ databaseBuilder }) { _buildCampaigns({ databaseBuilder }); @@ -136,15 +151,53 @@ function _buildScoAssessmentParticipations({ databaseBuilder }) { const scoStudentForeigner = { id: SCO_FOREIGNER_USER_ID, createdAt: new Date('2022-02-05') }; const scoStudentDisabled = { id: SCO_DISABLED_USER_ID, createdAt: new Date('2022-02-06') }; - const campaignParticipationId = participateToAssessmentCampaign({ databaseBuilder, campaignId: 4, user: scoStudent, organizationLearnerId: SCO_STUDENT_ID, status: SHARED }); - databaseBuilder.factory.buildBadgeAcquisition({ userId: SCO_STUDENT_ID, badgeId: PRO_BASICS_BADGE_ID, campaignParticipationId }); - databaseBuilder.factory.buildBadgeAcquisition({ userId: SCO_STUDENT_ID, badgeId: PRO_TOOLS_BADGE_ID, campaignParticipationId }); + const campaignParticipationId = participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 4, + user: scoStudent, + organizationLearnerId: SCO_STUDENT_ID, + status: SHARED, + }); + databaseBuilder.factory.buildBadgeAcquisition({ + userId: SCO_STUDENT_ID, + badgeId: PRO_BASICS_BADGE_ID, + campaignParticipationId, + }); + databaseBuilder.factory.buildBadgeAcquisition({ + userId: SCO_STUDENT_ID, + badgeId: PRO_TOOLS_BADGE_ID, + campaignParticipationId, + }); - participateToAssessmentCampaign({ databaseBuilder, campaignId: 4, user: scoStudentFrench, organizationLearnerId: SCO_FRENCH_USER_ID, status: TO_SHARE }); - participateToAssessmentCampaign({ databaseBuilder, campaignId: 4, user: scoStudentForeigner, organizationLearnerId: SCO_FOREIGNER_USER_ID, status: STARTED }); - participateToAssessmentCampaign({ databaseBuilder, campaignId: 4, user: scoStudentDisabled, organizationLearnerId: SCO_DISABLED_USER_ID, status: SHARED }); + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 4, + user: scoStudentFrench, + organizationLearnerId: SCO_FRENCH_USER_ID, + status: TO_SHARE, + }); + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 4, + user: scoStudentForeigner, + organizationLearnerId: SCO_FOREIGNER_USER_ID, + status: STARTED, + }); + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 4, + user: scoStudentDisabled, + organizationLearnerId: SCO_DISABLED_USER_ID, + status: SHARED, + }); - participateToAssessmentCampaign({ databaseBuilder, campaignId: 8, user: scoStudentForeigner, organizationLearnerId: SCO_FOREIGNER_USER_ID_IN_ANOTHER_ORGANIZATION, status: SHARED }); + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 8, + user: scoStudentForeigner, + organizationLearnerId: SCO_FOREIGNER_USER_ID_IN_ANOTHER_ORGANIZATION, + status: SHARED, + }); } function _buildScoProfilesCollectionParticipations({ databaseBuilder }) { @@ -154,9 +207,39 @@ function _buildScoProfilesCollectionParticipations({ databaseBuilder }) { const scoStudentDisabled = { id: SCO_DISABLED_USER_ID, createdAt: new Date('2022-02-07') }; const scoStudentNotCertifiable = { id: SCO_STUDENT_NOT_CERTIFIABLE_ID, createdAt: new Date('2022-02-08') }; - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 7, user: scoStudent, organizationLearnerId: SCO_STUDENT_ID, status: SHARED }); - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 7, user: scoStudentFrench, organizationLearnerId: SCO_FRENCH_USER_ID, status: SHARED }); - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 7, user: scoStudentForeigner, organizationLearnerId: SCO_FOREIGNER_USER_ID, status: TO_SHARE }); - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 7, user: scoStudentDisabled, organizationLearnerId: SCO_DISABLED_USER_ID, status: SHARED }); - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 7, user: scoStudentNotCertifiable, organizationLearnerId: SCO_STUDENT_NOT_CERTIFIABLE_ID, status: SHARED }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 7, + user: scoStudent, + organizationLearnerId: SCO_STUDENT_ID, + status: SHARED, + }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 7, + user: scoStudentFrench, + organizationLearnerId: SCO_FRENCH_USER_ID, + status: SHARED, + }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 7, + user: scoStudentForeigner, + organizationLearnerId: SCO_FOREIGNER_USER_ID, + status: TO_SHARE, + }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 7, + user: scoStudentDisabled, + organizationLearnerId: SCO_DISABLED_USER_ID, + status: SHARED, + }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 7, + user: scoStudentNotCertifiable, + organizationLearnerId: SCO_STUDENT_NOT_CERTIFIABLE_ID, + status: SHARED, + }); } diff --git a/api/db/seeds/data/campaigns-sup-builder.js b/api/db/seeds/data/campaigns-sup-builder.js index f879de08adb..20999d88ec3 100644 --- a/api/db/seeds/data/campaigns-sup-builder.js +++ b/api/db/seeds/data/campaigns-sup-builder.js @@ -1,15 +1,20 @@ -const { - TARGET_PROFILE_PIC_DIAG_INITIAL_ID, - TARGET_PROFILE_PIX_DROIT_ID, -} = require('./target-profiles-builder'); -const { SUP_UNIVERSITY_ID, SUP_STUDENT_ASSOCIATED_ID, SUP_STUDENT_DISABLED_ID, SUP_STUDENT_CERTIFIABLE } = require('./organizations-sup-builder'); -const { participateToAssessmentCampaign, participateToProfilesCollectionCampaign } = require('./campaign-participations-builder'); -const CampaignParticipationStatuses = require('../../../lib/domain/models/CampaignParticipationStatuses'); +import { TARGET_PROFILE_PIC_DIAG_INITIAL_ID, TARGET_PROFILE_PIX_DROIT_ID } from './target-profiles-builder.js'; + +import { + SUP_UNIVERSITY_ID, + SUP_STUDENT_ASSOCIATED_ID, + SUP_STUDENT_DISABLED_ID, + SUP_STUDENT_CERTIFIABLE, +} from './organizations-sup-builder.js'; + +import { + participateToAssessmentCampaign, + participateToProfilesCollectionCampaign, +} from './campaign-participations-builder.js'; +import { CampaignParticipationStatuses } from '../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED, TO_SHARE, STARTED } = CampaignParticipationStatuses; -module.exports = { - campaignsSupBuilder, -}; +export { campaignsSupBuilder }; function campaignsSupBuilder({ databaseBuilder }) { _buildCampaigns({ databaseBuilder }); @@ -50,7 +55,7 @@ function _buildCampaigns({ databaseBuilder }) { databaseBuilder.factory.buildCampaign({ id: 20, - name: 'Sup - Campagne d\'évaluation Pix+ Droit', + name: "Sup - Campagne d'évaluation Pix+ Droit", code: 'SUPDROIT1', type: 'ASSESSMENT', organizationId: SUP_UNIVERSITY_ID, @@ -68,15 +73,46 @@ function _buildCampaigns({ databaseBuilder }) { function _buildSupAssessmentParticipations({ databaseBuilder }) { const supStudentAssociated = { id: SUP_STUDENT_ASSOCIATED_ID, createdAt: new Date('2022-02-04') }; const supStudentDisabled = { id: SUP_STUDENT_DISABLED_ID, createdAt: new Date('2022-02-05') }; - participateToAssessmentCampaign({ databaseBuilder, campaignId: 3, user: supStudentAssociated, organizationLearnerId: SUP_STUDENT_ASSOCIATED_ID, status: SHARED }); - participateToAssessmentCampaign({ databaseBuilder, campaignId: 3, user: supStudentDisabled, organizationLearnerId: SUP_STUDENT_DISABLED_ID, status: STARTED }); + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 3, + user: supStudentAssociated, + organizationLearnerId: SUP_STUDENT_ASSOCIATED_ID, + status: SHARED, + }); + participateToAssessmentCampaign({ + databaseBuilder, + campaignId: 3, + user: supStudentDisabled, + organizationLearnerId: SUP_STUDENT_DISABLED_ID, + status: STARTED, + }); } function _buildSupProfilesCollectionParticipations({ databaseBuilder }) { const supStudentAssociated = { id: SUP_STUDENT_ASSOCIATED_ID, createdAt: new Date('2022-02-06') }; const supStudentDisabled = { id: SUP_STUDENT_DISABLED_ID, createdAt: new Date('2022-02-07') }; const supStudentCertifiable = { id: SUP_STUDENT_CERTIFIABLE, createdAt: new Date('2022-02-08') }; - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 10, user: supStudentAssociated, organizationLearnerId: SUP_STUDENT_ASSOCIATED_ID, status: SHARED }); - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 10, user: supStudentDisabled, organizationLearnerId: SUP_STUDENT_DISABLED_ID, status: TO_SHARE }); - participateToProfilesCollectionCampaign({ databaseBuilder, campaignId: 10, user: supStudentCertifiable, organizationLearnerId: SUP_STUDENT_CERTIFIABLE, status: SHARED, isCertifiable: true }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 10, + user: supStudentAssociated, + organizationLearnerId: SUP_STUDENT_ASSOCIATED_ID, + status: SHARED, + }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 10, + user: supStudentDisabled, + organizationLearnerId: SUP_STUDENT_DISABLED_ID, + status: TO_SHARE, + }); + participateToProfilesCollectionCampaign({ + databaseBuilder, + campaignId: 10, + user: supStudentCertifiable, + organizationLearnerId: SUP_STUDENT_CERTIFIABLE, + status: SHARED, + isCertifiable: true, + }); } diff --git a/api/db/seeds/data/certification/badge-acquisition-builder.js b/api/db/seeds/data/certification/badge-acquisition-builder.js index a09cb1e1df2..65ec0cd3a10 100644 --- a/api/db/seeds/data/certification/badge-acquisition-builder.js +++ b/api/db/seeds/data/certification/badge-acquisition-builder.js @@ -1,4 +1,4 @@ -const { +import { PIX_EMPLOI_CLEA_BADGE_ID_V1, PIX_EMPLOI_CLEA_BADGE_ID_V2, PIX_EMPLOI_CLEA_BADGE_ID_V3, @@ -6,8 +6,9 @@ const { PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE_AVANCE_BADGE_ID, PIX_EDU_FORMATION_INITIALE_1ER_DEGRE_CONFIRME_BADGE_ID, PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_AVANCE_BADGE_ID, -} = require('../badges-builder'); -const { +} from '../badges-builder.js'; + +import { CERTIF_REGULAR_USER1_ID, CERTIF_SUCCESS_USER_ID, CERTIF_FAILURE_USER_ID, @@ -15,10 +16,11 @@ const { CERTIF_EDU_FORMATION_CONTINUE_2ND_DEGRE_USER_ID, CERTIF_EDU_FORMATION_INITIALE_1ER_DEGRE_USER_ID, CERTIF_EDU_FORMATION_CONTINUE_1ER_DEGRE_USER_ID, -} = require('./users'); +} from './users.js'; + +import { participateToAssessmentCampaign } from '../campaign-participations-builder.js'; -const { participateToAssessmentCampaign } = require('../campaign-participations-builder'); -const { +import { TARGET_PROFILE_PIX_EMPLOI_CLEA_ID, TARGET_PROFILE_PIX_EMPLOI_CLEA_ID_V2, TARGET_PROFILE_PIX_EMPLOI_CLEA_ID_V3, @@ -26,9 +28,10 @@ const { TARGET_PROFILE_PIX_EDU_FORMATION_CONTINUE_2ND_DEGRE, TARGET_PROFILE_PIX_EDU_FORMATION_INITIALE_1ER_DEGRE, TARGET_PROFILE_PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE, -} = require('../target-profiles-builder'); -const { PRO_COMPANY_ID, PRO_LEARNER_ASSOCIATED_ID } = require('../organizations-pro-builder'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +} from '../target-profiles-builder.js'; + +import { PRO_COMPANY_ID, PRO_LEARNER_ASSOCIATED_ID } from '../organizations-pro-builder.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; function badgeAcquisitionBuilder({ databaseBuilder }) { @@ -98,9 +101,7 @@ function badgeAcquisitionBuilder({ databaseBuilder }) { }); } -module.exports = { - badgeAcquisitionBuilder, -}; +export { badgeAcquisitionBuilder }; function _buildBadgeAcquisition({ campaignName, campaignCode, targetProfileId, userId, badgeId, databaseBuilder }) { const campaignParticipationId = _buildRequiredCampaignData({ diff --git a/api/db/seeds/data/certification/certification-candidates-builder.js b/api/db/seeds/data/certification/certification-candidates-builder.js index 608d47a2efc..8aea628b542 100644 --- a/api/db/seeds/data/certification/certification-candidates-builder.js +++ b/api/db/seeds/data/certification/certification-candidates-builder.js @@ -1,5 +1,6 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { STARTED_SESSION_ID, STARTED_SESSION_WITH_LOT_OF_CANDIDATES_ID, TO_FINALIZE_SESSION_ID, @@ -10,21 +11,26 @@ const { SCO_NO_MANAGING_STUDENTS_AEFE_SESSION_ID, PIX_DROIT_SESSION_ID, COMPLEMENTARY_CERTIFICATIONS_SESSION_ID, -} = require('./certification-sessions-builder'); -const { SCO_STUDENT_ID: SCO_STUDENT_ORGANIZATION_LEARNER_ID } = require('../organizations-sco-builder'); -const { +} from './certification-sessions-builder.js'; + +import { SCO_STUDENT_ID as SCO_STUDENT_ORGANIZATION_LEARNER_ID } from '../organizations-sco-builder.js'; + +import { CERTIF_SUCCESS_USER_ID, CERTIF_FAILED_USER_ID, CERTIF_REGULAR_USER5_ID, CERTIF_SCO_STUDENT_ID, -} = require('./users'); -const { +} from './users.js'; + +import { CLEA_COMPLEMENTARY_CERTIFICATION_ID, PIX_DROIT_COMPLEMENTARY_CERTIFICATION_ID, PIX_EDU_2ND_DEGRE_COMPLEMENTARY_CERTIFICATION_ID, -} = require('./certification-centers-builder'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { BILLING_MODES } = require('../../../../lib/domain/models/CertificationCandidate'); +} from './certification-centers-builder.js'; + +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { CertificationCandidate } from '../../../../lib/domain/models/CertificationCandidate.js'; +const { BILLING_MODES } = CertificationCandidate; const A_LOT_OF_CANDIDATES_COUNT = 150; const SUCCESS_CANDIDATE_IN_SESSION_TO_FINALIZE_ID = 1; @@ -297,7 +303,7 @@ function certificationCandidatesBuilder({ databaseBuilder }) { }); } -module.exports = { +export { certificationCandidatesBuilder, SUCCESS_CANDIDATE_IN_SESSION_TO_FINALIZE_ID, FAILURE_CANDIDATE_IN_SESSION_TO_FINALIZE_ID, diff --git a/api/db/seeds/data/certification/certification-center-invitations-builder.js b/api/db/seeds/data/certification/certification-center-invitations-builder.js index b294fd944a1..11a2e196616 100644 --- a/api/db/seeds/data/certification/certification-center-invitations-builder.js +++ b/api/db/seeds/data/certification/certification-center-invitations-builder.js @@ -1,6 +1,4 @@ -const { - SUP_CERTIF_CENTER_ID, -} = require('./certification-centers-builder'); +import { SUP_CERTIF_CENTER_ID } from './certification-centers-builder.js'; function certificationCenterInvitationsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildCertificationCenterInvitation({ @@ -28,6 +26,4 @@ function certificationCenterInvitationsBuilder({ databaseBuilder }) { }); } -module.exports = { - certificationCenterInvitationsBuilder, -}; +export { certificationCenterInvitationsBuilder }; diff --git a/api/db/seeds/data/certification/certification-center-memberships-builder.js b/api/db/seeds/data/certification/certification-center-memberships-builder.js index 7a8fda98326..e7fdb23a483 100644 --- a/api/db/seeds/data/certification/certification-center-memberships-builder.js +++ b/api/db/seeds/data/certification/certification-center-memberships-builder.js @@ -1,4 +1,4 @@ -const { +import { SCO_COLLEGE_CERTIF_CENTER_ID, SCO_LYCEE_CERTIF_CENTER_ID, PRO_CERTIF_CENTER_ID, @@ -6,16 +6,17 @@ const { DROIT_CERTIF_CENTER_ID, SCO_NO_MANAGING_STUDENTS_CERTIF_CENTER_ID, AGRI_SCO_MANAGING_STUDENT_ID, -} = require('./certification-centers-builder'); -const { +} from './certification-centers-builder.js'; + +import { PIX_SCO_CERTIF_USER_ID, PIX_PRO_CERTIF_USER_ID, PIX_SUP_CERTIF_USER_ID, CERTIF_REGULAR_USER1_ID, CERTIF_DROIT_USER5_ID, -} = require('./users'); +} from './users.js'; -module.exports = function certificationCenterMembershipsBuilder({ databaseBuilder }) { +const certificationCenterMembershipsBuilder = function ({ databaseBuilder }) { databaseBuilder.factory.buildCertificationCenterMembership({ certificationCenterId: SCO_COLLEGE_CERTIF_CENTER_ID, userId: PIX_SCO_CERTIF_USER_ID, @@ -37,7 +38,18 @@ module.exports = function certificationCenterMembershipsBuilder({ databaseBuilde userId: PIX_SCO_CERTIF_USER_ID, }); - databaseBuilder.factory.buildCertificationCenterMembership({ userId: PIX_PRO_CERTIF_USER_ID, certificationCenterId: PRO_CERTIF_CENTER_ID }); - databaseBuilder.factory.buildCertificationCenterMembership({ userId: PIX_SUP_CERTIF_USER_ID, certificationCenterId: SUP_CERTIF_CENTER_ID }); - databaseBuilder.factory.buildCertificationCenterMembership({ userId: CERTIF_DROIT_USER5_ID, certificationCenterId: DROIT_CERTIF_CENTER_ID }); + databaseBuilder.factory.buildCertificationCenterMembership({ + userId: PIX_PRO_CERTIF_USER_ID, + certificationCenterId: PRO_CERTIF_CENTER_ID, + }); + databaseBuilder.factory.buildCertificationCenterMembership({ + userId: PIX_SUP_CERTIF_USER_ID, + certificationCenterId: SUP_CERTIF_CENTER_ID, + }); + databaseBuilder.factory.buildCertificationCenterMembership({ + userId: CERTIF_DROIT_USER5_ID, + certificationCenterId: DROIT_CERTIF_CENTER_ID, + }); }; + +export { certificationCenterMembershipsBuilder }; diff --git a/api/db/seeds/data/certification/certification-centers-builder.js b/api/db/seeds/data/certification/certification-centers-builder.js index e82bc383c7b..1c4d36bfd3f 100644 --- a/api/db/seeds/data/certification/certification-centers-builder.js +++ b/api/db/seeds/data/certification/certification-centers-builder.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const { DEFAULT_PASSWORD } = require('../users-builder'); +import _ from 'lodash'; +import { DEFAULT_PASSWORD } from '../users-builder.js'; const SCO_COLLEGE_CERTIF_CENTER_ID = 1; const GREAT_OAK_CERTIF_CENTER_ID = 23; @@ -32,7 +32,7 @@ const PIX_DROIT_COMPLEMENTARY_CERTIFICATION_ID = 53; const PIX_EDU_1ER_DEGRE_COMPLEMENTARY_CERTIFICATION_ID = 54; const PIX_EDU_2ND_DEGRE_COMPLEMENTARY_CERTIFICATION_ID = 55; -const { +import { PIX_EMPLOI_CLEA_BADGE_ID_V1, PIX_EMPLOI_CLEA_BADGE_ID_V2, PIX_EMPLOI_CLEA_BADGE_ID_V3, @@ -48,7 +48,7 @@ const { PIX_EDU_FORMATION_INITIALE_1ER_DEGRE_INITIE_BADGE_ID, PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_CONFIRME_BADGE_ID, PIX_EDU_FORMATION_CONTINUE_1ER_DEGRE_EXPERT_BADGE_ID, -} = require('../badges-builder'); +} from '../badges-builder.js'; function certificationCentersBuilder({ databaseBuilder }) { databaseBuilder.factory.buildComplementaryCertification.clea({ @@ -314,7 +314,7 @@ function certificationCentersBuilder({ databaseBuilder }) { }); } -module.exports = { +export { certificationCentersBuilder, SCO_COLLEGE_CERTIF_CENTER_ID, SCO_COLLEGE_CERTIF_CENTER_NAME, diff --git a/api/db/seeds/data/certification/certification-courses-builder.js b/api/db/seeds/data/certification/certification-courses-builder.js index 71ab1dcdf5e..f002521a95f 100644 --- a/api/db/seeds/data/certification/certification-courses-builder.js +++ b/api/db/seeds/data/certification/certification-courses-builder.js @@ -1,33 +1,33 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { CERTIF_SUCCESS_USER_ID, CERTIF_SCO_STUDENT_ID, CERTIF_FAILURE_USER_ID, CERTIF_REGULAR_USER5_ID, CERTIF_EDU_FORMATION_INITIALE_1ER_DEGRE_USER_ID, -} = require('./users'); -const { +} from './users.js'; + +import { TO_FINALIZE_SESSION_ID, NO_PROBLEM_FINALIZED_SESSION_ID, PROBLEMS_FINALIZED_SESSION_ID, PUBLISHED_SESSION_ID, PUBLISHED_SCO_SESSION_ID, -} = require('./certification-sessions-builder'); -const { +} from './certification-sessions-builder.js'; + +import { CANDIDATE_DATA_SUCCESS, CANDIDATE_DATA_FAILURE, CANDIDATE_DATA_STARTED, CANDIDATE_SCO_DATA_SUCCESS, CANDIDATE_DATA_EDU, -} = require('./certification-candidates-builder'); -const { CERTIFICATION_CHALLENGES_DATA } = require('./certification-data'); -const { - CertificationIssueReportCategories, -} = require('./../../../../lib/domain/models/CertificationIssueReportCategory'); -const { - generateCertificateVerificationCode, -} = require('../../../../lib/domain/services/verify-certificate-code-service'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); +} from './certification-candidates-builder.js'; + +import { CERTIFICATION_CHALLENGES_DATA } from './certification-data.js'; +import { CertificationIssueReportCategory } from './../../../../lib/domain/models/CertificationIssueReportCategory.js'; +import { generateCertificateVerificationCode } from '../../../../lib/domain/services/verify-certificate-code-service.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; const ASSESSMENT_SUCCESS_IN_SESSION_TO_FINALIZE_ID = 100; const ASSESSMENT_FAILURE_IN_SESSION_TO_FINALIZE_ID = 101; @@ -157,17 +157,19 @@ async function certificationCoursesBuilder({ databaseBuilder }) { } } -async function _buildCertificationCourse(databaseBuilder, { - id, - assessmentId, - userId, - sessionId, - candidateData, - examinerComment, - hasSeenEndTestScreen, - isPublished, - pixCertificationStatus, -}, +async function _buildCertificationCourse( + databaseBuilder, + { + id, + assessmentId, + userId, + sessionId, + candidateData, + examinerComment, + hasSeenEndTestScreen, + isPublished, + pixCertificationStatus, + } ) { const createdAt = new Date('2020-01-31T00:00:00Z'); const verificationCode = await generateCertificateVerificationCode(); @@ -187,18 +189,18 @@ async function _buildCertificationCourse(databaseBuilder, { if (examinerComment) { databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, description: examinerComment + ' (deuxième fois)', }); databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, description: examinerComment + ' (première fois)', resolvedAt: '2020-05-01T00:00:00Z', }); databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId, - category: CertificationIssueReportCategories.SIGNATURE_ISSUE, + category: CertificationIssueReportCategory.SIGNATURE_ISSUE, description: examinerComment, }); } @@ -227,7 +229,7 @@ async function _buildCertificationCourse(databaseBuilder, { }); } -module.exports = { +export { certificationCoursesBuilder, ASSESSMENT_SUCCESS_IN_SESSION_TO_FINALIZE_ID, ASSESSMENT_FAILURE_IN_SESSION_TO_FINALIZE_ID, diff --git a/api/db/seeds/data/certification/certification-data.js b/api/db/seeds/data/certification/certification-data.js index 073c0fa6131..5ac04dd7f34 100644 --- a/api/db/seeds/data/certification/certification-data.js +++ b/api/db/seeds/data/certification/certification-data.js @@ -1787,7 +1787,7 @@ const PIX_EDU_FORMATION_CONTINUE_FORMATEUR_PROFILE_DATA_OBJECTS_FOR_BUILDING_ANS }, ]; -module.exports = { +export { WEAK_CERTIFIABLE_PROFILE_DATA_OBJECTS_FOR_BUILDING_ANSWERS_AND_KNOWLEDGE_ELEMENTS, WEAK_CERTIFIABLE_WITH_TIMED_CHALLENGE_PROFILE_DATA_OBJECTS_FOR_BUILDING_ANSWERS_AND_KNOWLEDGE_ELEMENTS, CERTIFICATION_CHALLENGES_DATA, diff --git a/api/db/seeds/data/certification/certification-scores-builder.js b/api/db/seeds/data/certification/certification-scores-builder.js index 4f009f2fdf3..0b9921cc53f 100644 --- a/api/db/seeds/data/certification/certification-scores-builder.js +++ b/api/db/seeds/data/certification/certification-scores-builder.js @@ -1,5 +1,6 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { ASSESSMENT_SUCCESS_IN_SESSION_TO_FINALIZE_ID, ASSESSMENT_FAILURE_IN_SESSION_TO_FINALIZE_ID, ASSESSMENT_SUCCESS_IN_NO_PROBLEM_FINALIZED_SESSION_ID, @@ -11,13 +12,14 @@ const { ASSESSMENT_SUCCESS_PUBLISHED_SESSION_SCO_ID, ASSESSMENT_FAILURE_PUBLISHED_SESSION_ID, ASSESSMENT_SUCCESS_EDU_PUBLISHED_SESSION_ID, -} = require('./certification-courses-builder'); -const { +} from './certification-courses-builder.js'; + +import { CERTIFICATION_FAILURE_ANSWERS_DATA, CERTIFICATION_SUCCESS_ANSWERS_DATA, CERTIFICATION_FAILURE_COMPETENCE_MARKS_DATA, CERTIFICATION_SUCCESS_COMPETENCE_MARKS_DATA, -} = require('./certification-data'); +} from './certification-data.js'; function certificationScoresBuilder({ databaseBuilder }) { // Each certification present the same scores per user. @@ -35,7 +37,7 @@ function certificationScoresBuilder({ databaseBuilder }) { ], (assessmentId) => { _buildSuccessScore(databaseBuilder, createdAt, assessmentId); - }, + } ); _.each( [ @@ -46,7 +48,8 @@ function certificationScoresBuilder({ databaseBuilder }) { ], (assessmentId) => { _buildFailureScore(databaseBuilder, createdAt, assessmentId); - }); + } + ); // Special case : build answers only, has for this one, the assessment has not been completed _buildAnswers({ @@ -74,8 +77,16 @@ function _addTenSeconds(date) { function _buildSuccessScore(databaseBuilder, createdAt, assessmentId) { _buildAnswers({ answerData: CERTIFICATION_SUCCESS_ANSWERS_DATA, databaseBuilder, assessmentId, createdAt }); const assessmentResultId = databaseBuilder.factory.buildAssessmentResult({ - level: null, pixScore: 518, emitter: 'PIX-ALGO', status: 'validated', commentForJury: null, - commentForCandidate: null, commentForOrganization: null, juryId: null, assessmentId, createdAt, + level: null, + pixScore: 518, + emitter: 'PIX-ALGO', + status: 'validated', + commentForJury: null, + commentForCandidate: null, + commentForOrganization: null, + juryId: null, + assessmentId, + createdAt, }).id; _.each(CERTIFICATION_SUCCESS_COMPETENCE_MARKS_DATA, (competenceMarkData) => { databaseBuilder.factory.buildCompetenceMark({ ...competenceMarkData, assessmentResultId, createdAt }); @@ -85,12 +96,20 @@ function _buildSuccessScore(databaseBuilder, createdAt, assessmentId) { function _buildFailureScore(databaseBuilder, createdAt, assessmentId) { _buildAnswers({ answerData: CERTIFICATION_FAILURE_ANSWERS_DATA, databaseBuilder, assessmentId, createdAt }); const assessmentResultId = databaseBuilder.factory.buildAssessmentResult({ - level: -1, pixScore: 0, emitter: 'PIX-ALGO', status: 'rejected', commentForJury: null, - commentForCandidate: null, commentForOrganization: null, juryId: null, assessmentId, createdAt, + level: -1, + pixScore: 0, + emitter: 'PIX-ALGO', + status: 'rejected', + commentForJury: null, + commentForCandidate: null, + commentForOrganization: null, + juryId: null, + assessmentId, + createdAt, }).id; _.each(CERTIFICATION_FAILURE_COMPETENCE_MARKS_DATA, (competenceMarkData) => { databaseBuilder.factory.buildCompetenceMark({ ...competenceMarkData, assessmentResultId, createdAt }); }); } -module.exports = certificationScoresBuilder; +export { certificationScoresBuilder }; diff --git a/api/db/seeds/data/certification/certification-sessions-builder.js b/api/db/seeds/data/certification/certification-sessions-builder.js index 358d549a0d8..59666846275 100644 --- a/api/db/seeds/data/certification/certification-sessions-builder.js +++ b/api/db/seeds/data/certification/certification-sessions-builder.js @@ -1,4 +1,4 @@ -const { +import { SCO_COLLEGE_CERTIF_CENTER_ID, SCO_COLLEGE_CERTIF_CENTER_NAME, SCO_NO_MANAGING_STUDENTS_CERTIF_CENTER_ID, @@ -7,8 +7,9 @@ const { DROIT_CERTIF_CENTER_NAME, SUP_CERTIF_CENTER_NAME, SUP_CERTIF_CENTER_ID, -} = require('./certification-centers-builder'); -const { PIX_SUPER_ADMIN_ID } = require('./../users-builder'); +} from './certification-centers-builder.js'; + +import { PIX_SUPER_ADMIN_ID } from './../users-builder.js'; const EMPTY_SESSION_ID = 1; const STARTED_SESSION_ID = 2; const STARTED_SESSION_WITH_LOT_OF_CANDIDATES_ID = 3; @@ -33,7 +34,13 @@ function certificationSessionsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildSession({ id: EMPTY_SESSION_ID, - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-empty`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-empty`, + date, + time, description: 'Session pas commencée avec ZERO candidat inscrit.', accessCode: 'ANNE01', examinerGlobalComment: null, @@ -41,7 +48,13 @@ function certificationSessionsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildSession({ id: STARTED_SESSION_ID, - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-started`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-started`, + date, + time, description: 'Session pas commencée avec quelques candidats inscrits non liés.', accessCode: 'ANNE02', examinerGlobalComment: null, @@ -49,7 +62,13 @@ function certificationSessionsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildSession({ id: STARTED_SESSION_WITH_LOT_OF_CANDIDATES_ID, - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-lot-of-candidates`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-lot-of-candidates`, + date, + time, description: 'Session pas commencée avec des candidats inscrits non liés.', accessCode: 'ANNE03', examinerGlobalComment: null, @@ -57,7 +76,13 @@ function certificationSessionsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildSession({ id: TO_FINALIZE_SESSION_ID, - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-to-finalize`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-to-finalize`, + date, + time, description: 'Session pas encore finalisée, avec des candidats ayant passés leur test de certification.', accessCode: 'ANNE04', examinerGlobalComment: null, @@ -65,8 +90,15 @@ function certificationSessionsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildSession({ id: NO_PROBLEM_FINALIZED_SESSION_ID, - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-no-problem`, date, time, - description: 'Session finalisée sans problème, donc aucun commentaire et le surveillant a vu tous les écrans de fin de test.', + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-no-problem`, + date, + time, + description: + 'Session finalisée sans problème, donc aucun commentaire et le surveillant a vu tous les écrans de fin de test.', accessCode: 'ANNE05', examinerGlobalComment: null, finalizedAt: new Date('2020-04-15T15:00:34Z'), @@ -77,19 +109,27 @@ function certificationSessionsBuilder({ databaseBuilder }) { certificationCenterName: certificationCenter, isPublishable: true, publishedAt: null, - date, time, + date, + time, finalizedAt: new Date('2020-04-15T15:00:34Z'), }); databaseBuilder.factory.buildSession({ id: PROBLEMS_FINALIZED_SESSION_ID, - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-problems`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-problems`, + date, + time, description: 'Session finalisée à problèmes et assignée !', accessCode: 'ANNE06', examinerGlobalComment: 'Une météorite est tombée sur le centre de certification pendant la session !!', finalizedAt: new Date('2020-05-05T15:00:34Z'), assignedCertificationOfficerId: PIX_SUPER_ADMIN_ID, - juryComment: 'Tu te rends compte, si on n’avait pas perdu une heure et quart, on serait là depuis une heure et quart !', + juryComment: + 'Tu te rends compte, si on n’avait pas perdu une heure et quart, on serait là depuis une heure et quart !', juryCommentAuthorId: PIX_SUPER_ADMIN_ID, juryCommentedAt: new Date('2021-04-28T00:42:03Z'), }); @@ -99,15 +139,21 @@ function certificationSessionsBuilder({ databaseBuilder }) { certificationCenterName: certificationCenter, isPublishable: false, publishedAt: null, - date, time, + date, + time, finalizedAt: new Date('2020-05-05T15:00:34Z'), assignedCertificationOfficerName: 'Super Admin', }); databaseBuilder.factory.buildSession({ id: NO_CERTIF_CENTER_SESSION_ID, - certificationCenterId: null, certificationCenter: 'Centre de certif pas dans la BDD !', - address, room, examiner, date, time, + certificationCenterId: null, + certificationCenter: 'Centre de certif pas dans la BDD !', + address, + room, + examiner, + date, + time, description: 'Session sans vrai certification center !', accessCode: 'ANNE07', examinerGlobalComment: 'Salut les zouzous', @@ -116,7 +162,13 @@ function certificationSessionsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildSession({ id: PUBLISHED_SESSION_ID, - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-published`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-published`, + date, + time, description: 'Session publiée', accessCode: 'ANNE08', finalizedAt: new Date('2020-05-05T15:00:34Z'), @@ -127,14 +179,21 @@ function certificationSessionsBuilder({ databaseBuilder }) { sessionId: PUBLISHED_SESSION_ID, certificationCenterName: certificationCenter, isPublishable: true, - date, time, + date, + time, finalizedAt: new Date('2020-05-05T15:00:34Z'), publishedAt: new Date('2020-06-05T15:00:34Z'), }); databaseBuilder.factory.buildSession({ id: PUBLISHED_SCO_SESSION_ID, - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-published-sco`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-published-sco`, + date, + time, description: 'Session publiée', accessCode: 'ANNE08', finalizedAt: new Date('2020-05-05T15:00:34Z'), @@ -145,7 +204,8 @@ function certificationSessionsBuilder({ databaseBuilder }) { sessionId: PUBLISHED_SCO_SESSION_ID, certificationCenterName: certificationCenter, isPublishable: true, - date, time, + date, + time, finalizedAt: new Date('2020-05-05T15:00:34Z'), publishedAt: new Date('2020-06-05T15:00:34Z'), }); @@ -154,18 +214,27 @@ function certificationSessionsBuilder({ databaseBuilder }) { id: COMPLEMENTARY_CERTIFICATIONS_SESSION_ID, certificationCenterName: SUP_CERTIF_CENTER_NAME, certificationCenterId: SUP_CERTIF_CENTER_ID, - date, time, + date, + time, description: 'Candidats avec des certifications complémentaires', }); // Some sessions to illustrate paginated sessions list order in PixAdmin databaseBuilder.factory.buildSession({ - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-1`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-1`, + date, + time, finalizedAt: null, publishedAt: null, }); const finalizedSession = databaseBuilder.factory.buildSession({ - certificationCenter, certificationCenterId, address, + certificationCenter, + certificationCenterId, + address, createdAt: new Date('2018-01-01T00:00:00Z'), date: '2018-01-02', finalizedAt: new Date('2018-01-03T00:00:00Z'), @@ -175,19 +244,27 @@ function certificationSessionsBuilder({ databaseBuilder }) { sessionId: finalizedSession.id, certificationCenterName: certificationCenter, isPublishable: true, - date: '2018-01-02', time, + date: '2018-01-02', + time, finalizedAt: new Date('2018-01-03T00:00:00Z'), publishedAt: null, }); databaseBuilder.factory.buildSession({ - certificationCenter, certificationCenterId, + certificationCenter, + certificationCenterId, finalizedAt: new Date('2018-01-02T00:00:00Z'), publishedAt: null, resultsSentToPrescriberAt: new Date('2018-01-04T00:00:00Z'), }); databaseBuilder.factory.buildSession({ - certificationCenter, certificationCenterId, address, room, examiner: `${examiner}-2`, date, time, + certificationCenter, + certificationCenterId, + address, + room, + examiner: `${examiner}-2`, + date, + time, finalizedAt: new Date('2018-01-02T00:00:00Z'), publishedAt: new Date('2018-01-03T00:00:00Z'), }); @@ -209,7 +286,12 @@ function certificationSessionsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildSession({ id: PIX_DROIT_SESSION_ID, certificationCenter: DROIT_CERTIF_CENTER_NAME, - certificationCenterId: DROIT_CERTIF_CENTER_ID, address, room, examiner: `${examiner}-3`, date, time, + certificationCenterId: DROIT_CERTIF_CENTER_ID, + address, + room, + examiner: `${examiner}-3`, + date, + time, description: 'Certif avec pix+droit', accessCode: 'DROI01', finalizedAt: null, @@ -217,7 +299,7 @@ function certificationSessionsBuilder({ databaseBuilder }) { }); } -module.exports = { +export { certificationSessionsBuilder, EMPTY_SESSION_ID, STARTED_SESSION_ID, diff --git a/api/db/seeds/data/certification/complementary-certification-course-results-builder.js b/api/db/seeds/data/certification/complementary-certification-course-results-builder.js index e13b8d4204d..2b41aa31550 100644 --- a/api/db/seeds/data/certification/complementary-certification-course-results-builder.js +++ b/api/db/seeds/data/certification/complementary-certification-course-results-builder.js @@ -1,23 +1,27 @@ -const { badges } = require('../../../constants'); -const { +import { badges } from '../../../constants.js'; + +import { CERTIFICATION_COURSE_SUCCESS_ID, CERTIFICATION_COURSE_FAILURE_ID, CERTIFICATION_COURSE_EDU_ID, -} = require('./certification-courses-builder'); -const { PIX_DROIT_MAITRE_BADGE_ID } = require('../badges-builder'); -const { CERTIF_DROIT_USER5_ID } = require('./users'); -const { +} from './certification-courses-builder.js'; + +import { PIX_DROIT_MAITRE_BADGE_ID } from '../badges-builder.js'; +import { CERTIF_DROIT_USER5_ID } from './users.js'; + +import { CLEA_COMPLEMENTARY_CERTIFICATION_ID, PIX_DROIT_COMPLEMENTARY_CERTIFICATION_ID, PIX_EDU_1ER_DEGRE_COMPLEMENTARY_CERTIFICATION_ID, PIX_CLEA_V3_COMPLEMENTARY_CERTIFICATION_BADGE_ID, PIX_DROIT_MAITRE_COMPLEMENTARY_CERTIFICATION_BADGE_ID, PIX_EDU_1ER_INITIE_COMPLEMENTARY_CERTIFICATION_BADGE_ID, -} = require('./certification-centers-builder'); -const { participateToAssessmentCampaign } = require('../campaign-participations-builder'); -const { TARGET_PROFILE_PIX_DROIT_ID } = require('../target-profiles-builder'); -const { SUP_STUDENT_ASSOCIATED_ID, SUP_UNIVERSITY_ID } = require('../organizations-sup-builder'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +} from './certification-centers-builder.js'; + +import { participateToAssessmentCampaign } from '../campaign-participations-builder.js'; +import { TARGET_PROFILE_PIX_DROIT_ID } from '../target-profiles-builder.js'; +import { SUP_STUDENT_ASSOCIATED_ID, SUP_UNIVERSITY_ID } from '../organizations-sup-builder.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; function complementaryCertificationCourseResultsBuilder({ databaseBuilder }) { @@ -67,7 +71,7 @@ function complementaryCertificationCourseResultsBuilder({ databaseBuilder }) { certificationCourseId: CERTIFICATION_COURSE_SUCCESS_ID, complementaryCertificationId: PIX_DROIT_COMPLEMENTARY_CERTIFICATION_ID, complementaryCertificationBadgeId: PIX_DROIT_MAITRE_COMPLEMENTARY_CERTIFICATION_BADGE_ID, - }, + } ); databaseBuilder.factory.buildComplementaryCertificationCourseResult({ complementaryCertificationCourseId: complementaryCertifCourseSuccessDroitId, @@ -87,6 +91,4 @@ function complementaryCertificationCourseResultsBuilder({ databaseBuilder }) { }); } -module.exports = { - complementaryCertificationCourseResultsBuilder, -}; +export { complementaryCertificationCourseResultsBuilder }; diff --git a/api/db/seeds/data/certification/issue-report-categories-builder.js b/api/db/seeds/data/certification/issue-report-categories-builder.js index b23f40c1274..7717f3a24c0 100644 --- a/api/db/seeds/data/certification/issue-report-categories-builder.js +++ b/api/db/seeds/data/certification/issue-report-categories-builder.js @@ -137,4 +137,4 @@ function issueReportCategoriesBuilder({ databaseBuilder }) { }); } -module.exports = { issueReportCategoriesBuilder }; +export { issueReportCategoriesBuilder }; diff --git a/api/db/seeds/data/certification/tooling.js b/api/db/seeds/data/certification/tooling.js index 9bec3193547..4af6deaf5eb 100644 --- a/api/db/seeds/data/certification/tooling.js +++ b/api/db/seeds/data/certification/tooling.js @@ -1,12 +1,12 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const skillRepository = require('../../../../lib/infrastructure/repositories/skill-repository'); -const competenceRepository = require('../../../../lib/infrastructure/repositories/competence-repository'); -const challengeRepository = require('../../../../lib/infrastructure/repositories/challenge-repository'); -const badgeRepository = require('../../../../lib/infrastructure/repositories/badge-repository'); -const logger = require('../../../../lib/infrastructure/logger'); -const { knex } = require('../../../../db/knex-database-connection'); -const ComplementaryCertification = require('../../../../lib/domain/models/ComplementaryCertification'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import * as skillRepository from '../../../../lib/infrastructure/repositories/skill-repository.js'; +import * as competenceRepository from '../../../../lib/infrastructure/repositories/competence-repository.js'; +import * as challengeRepository from '../../../../lib/infrastructure/repositories/challenge-repository.js'; +import * as badgeRepository from '../../../../lib/infrastructure/repositories/badge-repository.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; +import { knex } from '../../../../db/knex-database-connection.js'; +import { ComplementaryCertification } from '../../../../lib/domain/models/ComplementaryCertification.js'; let allChallenges = []; let allPixCompetences = []; @@ -49,7 +49,7 @@ async function makeUserCleaCertifiable({ userId, databaseBuilder }) { .innerJoin( 'complementary-certifications', 'complementary-certifications.id', - 'complementary-certification-badges.complementaryCertificationId', + 'complementary-certification-badges.complementaryCertificationId' ) .where({ 'complementary-certifications.key': ComplementaryCertification.CLEA }) .orderBy('complementary-certification-badges.level', 'desc'); @@ -154,9 +154,4 @@ function _findFirstChallengeValidatedBySkillId(skillId) { return _.find(allChallenges, { status: 'validé', skill: { id: skillId } }); } -module.exports = { - makeUserPixCertifiable, - makeUserPixDroitCertifiable, - makeUserCleaCertifiable, - makeUserPixEduCertifiable, -}; +export { makeUserPixCertifiable, makeUserPixDroitCertifiable, makeUserCleaCertifiable, makeUserPixEduCertifiable }; diff --git a/api/db/seeds/data/certification/user-profiles-builder.js b/api/db/seeds/data/certification/user-profiles-builder.js index 2ade00e7243..a8c6534d5e7 100644 --- a/api/db/seeds/data/certification/user-profiles-builder.js +++ b/api/db/seeds/data/certification/user-profiles-builder.js @@ -1,6 +1,7 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { +import _ from 'lodash'; +import bluebird from 'bluebird'; + +import { CERTIF_SUCCESS_USER_ID, CERTIF_FAILURE_USER_ID, CERTIF_REGULAR_USER1_ID, @@ -15,14 +16,17 @@ const { CERTIF_EDU_FORMATION_CONTINUE_2ND_DEGRE_USER_ID, CERTIF_EDU_FORMATION_INITIALE_1ER_DEGRE_USER_ID, CERTIF_EDU_FORMATION_CONTINUE_1ER_DEGRE_USER_ID, -} = require('./users'); -const { makeUserPixCertifiable, makeUserPixDroitCertifiable } = require('./tooling'); -const { +} from './users.js'; + +import { makeUserPixCertifiable, makeUserPixDroitCertifiable } from './tooling.js'; + +import { WEAK_CERTIFIABLE_WITH_TIMED_CHALLENGE_PROFILE_DATA_OBJECTS_FOR_BUILDING_ANSWERS_AND_KNOWLEDGE_ELEMENTS, PIX_EDU_FORMATION_INITIALE_AVANCE_PROFILE_DATA_OBJECTS_FOR_BUILDING_ANSWERS_AND_KNOWLEDGE_ELEMENTS, PIX_EDU_FORMATION_CONTINUE_FORMATEUR_PROFILE_DATA_OBJECTS_FOR_BUILDING_ANSWERS_AND_KNOWLEDGE_ELEMENTS, -} = require('./certification-data'); -const { SCO_FOREIGNER_USER_ID, SCO_FRENCH_USER_ID } = require('../organizations-sco-builder'); +} from './certification-data.js'; + +import { SCO_FOREIGNER_USER_ID, SCO_FRENCH_USER_ID } from '../organizations-sco-builder.js'; async function certificationUserProfilesBuilder({ databaseBuilder }) { const createdAt = new Date('2019-12-31T00:00:00Z'); @@ -61,7 +65,7 @@ async function certificationUserProfilesBuilder({ databaseBuilder }) { countCertifiableCompetences: 5, levelOnEachCompetence: 1, }); - }, + } ); // Pix+ Droit @@ -96,7 +100,7 @@ async function certificationUserProfilesBuilder({ databaseBuilder }) { userId: CERTIF_REGULAR_USER_WITH_TIMED_CHALLENGE_ID, assessmentId, }); - }, + } ); // Pix+ EDU @@ -184,7 +188,7 @@ async function certificationUserProfilesBuilder({ databaseBuilder }) { userId: CERTIF_EDU_FORMATION_CONTINUE_2ND_DEGRE_USER_ID, assessmentId: assessmentIdForPixEduFormationContinue2ndDegre, }); - }, + } ); await makeUserPixCertifiable({ @@ -215,10 +219,8 @@ async function certificationUserProfilesBuilder({ databaseBuilder }) { userId: CERTIF_EDU_FORMATION_CONTINUE_1ER_DEGRE_USER_ID, assessmentId: assessmentIdForPixEduFormationContinue1erDegre, }); - }, + } ); } -module.exports = { - certificationUserProfilesBuilder, -}; +export { certificationUserProfilesBuilder }; diff --git a/api/db/seeds/data/certification/users.js b/api/db/seeds/data/certification/users.js index 2628f1905d2..9af4d8df87a 100644 --- a/api/db/seeds/data/certification/users.js +++ b/api/db/seeds/data/certification/users.js @@ -15,9 +15,8 @@ const CERTIF_EDU_FORMATION_INITIALE_2ND_DEGRE_USER_ID = 113; const CERTIF_EDU_FORMATION_CONTINUE_2ND_DEGRE_USER_ID = 114; const CERTIF_EDU_FORMATION_INITIALE_1ER_DEGRE_USER_ID = 115; const CERTIF_EDU_FORMATION_CONTINUE_1ER_DEGRE_USER_ID = 116; -const { DEFAULT_PASSWORD } = require('../users-builder'); - -const { SCO_STUDENT_ID } = require('../organizations-sco-builder'); +import { DEFAULT_PASSWORD } from '../users-builder.js'; +import { SCO_STUDENT_ID } from '../organizations-sco-builder.js'; function certificationUsersBuilder({ databaseBuilder }) { databaseBuilder.factory.buildUser.withRawPassword({ @@ -174,10 +173,13 @@ function certificationUsersBuilder({ databaseBuilder }) { }); } -module.exports = { +const CERTIF_SCO_STUDENT_ID = SCO_STUDENT_ID; +const CERTIF_FAILED_USER_ID = CERTIF_FAILURE_USER_ID; + +export { certificationUsersBuilder, PIX_SCO_CERTIF_USER_ID, - CERTIF_SCO_STUDENT_ID: SCO_STUDENT_ID, + CERTIF_SCO_STUDENT_ID, PIX_PRO_CERTIF_USER_ID, PIX_SUP_CERTIF_USER_ID, PIX_NONE_CERTIF_USER_ID, @@ -194,4 +196,5 @@ module.exports = { CERTIF_EDU_FORMATION_CONTINUE_2ND_DEGRE_USER_ID, CERTIF_EDU_FORMATION_INITIALE_1ER_DEGRE_USER_ID, CERTIF_EDU_FORMATION_CONTINUE_1ER_DEGRE_USER_ID, + CERTIF_FAILED_USER_ID, }; diff --git a/api/db/seeds/data/common/common-builder.js b/api/db/seeds/data/common/common-builder.js index 9713b876ddf..de945856096 100644 --- a/api/db/seeds/data/common/common-builder.js +++ b/api/db/seeds/data/common/common-builder.js @@ -1,4 +1,6 @@ -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; // IDS /// USERS @@ -34,7 +36,7 @@ const PIX_EDU_1ER_DEGRE_CONFIRME_COMPLEMENTARY_CERTIFICATION_BADGE_ID = 73; const PIX_EDU_2ND_DEGRE_INITIE_COMPLEMENTARY_CERTIFICATION_BADGE_ID = 74; const PIX_EDU_2ND_DEGRE_CONFIRME_COMPLEMENTARY_CERTIFICATION_BADGE_ID = 75; -module.exports = { +export { commonBuilder, CLEA_COMPLEMENTARY_CERTIFICATION_ID, PIX_DROIT_COMPLEMENTARY_CERTIFICATION_ID, @@ -410,7 +412,7 @@ function _createDroit(databaseBuilder) { id: PIX_DROIT_MAITRE_CERTIFIABLE_BADGE_ID, targetProfileId: PIX_DROIT_TARGET_PROFILE_ID, message: - 'Félicitations ! Votre profil est prêt pour vous présenter à une certification Pix+Droit de niveau Avancé. Vous avez fait preuve d\'une maîtrise des compétences numériques nécessaires à l\'exercice des métiers du droit dans tous les domaines. En perfectionnant encore vos compétences, vous pourrez obtenir le niveau Expert.', + "Félicitations ! Votre profil est prêt pour vous présenter à une certification Pix+Droit de niveau Avancé. Vous avez fait preuve d'une maîtrise des compétences numériques nécessaires à l'exercice des métiers du droit dans tous les domaines. En perfectionnant encore vos compétences, vous pourrez obtenir le niveau Expert.", altMessage: 'Pix+Droit niveau Avancé', imageUrl: 'https://images.pix.fr/badges/badge_pix-PIX_DROIT_silver%20copy.svg', key: 'PIX_PIX_DROIT_MAITRE_CERTIF', @@ -488,7 +490,7 @@ function _createDroit(databaseBuilder) { id: PIX_DROIT_EXPERT_CERTIFIABLE_BADGE_ID, targetProfileId: PIX_DROIT_TARGET_PROFILE_ID, message: - 'Félicitations ! Votre profil est prêt pour vous présenter à une certification Pix+Droit de niveau Expert. Les compétences numériques nécessaires à l\'exercice des métiers du droit n\'ont plus de secret pour vous.', + "Félicitations ! Votre profil est prêt pour vous présenter à une certification Pix+Droit de niveau Expert. Les compétences numériques nécessaires à l'exercice des métiers du droit n'ont plus de secret pour vous.", altMessage: 'Pix+Droit niveau Expert', imageUrl: 'https://images.pix.fr/badges/badge_pix-PIX_DROIT_gold%20copy.svg', key: 'PIX_PIX_DROIT_EXPERT_CERTIF', @@ -538,7 +540,7 @@ function _createDroit(databaseBuilder) { id: PIX_DROIT_INITIE_CERTIFIABLE_BADGE_ID, targetProfileId: PIX_DROIT_TARGET_PROFILE_ID, message: - 'Félicitations ! Votre profil est prêt pour vous présenter à une certification Pix+Droit de niveau Initié. Vous avez fait preuve d\'une maîtrise des compétences numériques nécessaires à l\'exercice des métiers du droit dans tous les domaines. En perfectionnant encore vos compétences, vous pourrez obtenir un niveau Avancé.', + "Félicitations ! Votre profil est prêt pour vous présenter à une certification Pix+Droit de niveau Initié. Vous avez fait preuve d'une maîtrise des compétences numériques nécessaires à l'exercice des métiers du droit dans tous les domaines. En perfectionnant encore vos compétences, vous pourrez obtenir un niveau Avancé.", altMessage: 'Pix+Droit niveau Initié', imageUrl: 'https://images.pix.fr/badges/Pix_plus_Droit- Pret-certif_Bronze--Initie.svg', key: 'PIX_PIX_DROIT_INITIE_CERTIF', @@ -1238,4 +1240,3 @@ function _createCities(databaseBuilder) { INSEECode: '97101', }); } - diff --git a/api/db/seeds/data/common/tooling/campaign-tooling.js b/api/db/seeds/data/common/tooling/campaign-tooling.js index 17fd148df19..330d4df2a6a 100644 --- a/api/db/seeds/data/common/tooling/campaign-tooling.js +++ b/api/db/seeds/data/common/tooling/campaign-tooling.js @@ -1,15 +1,12 @@ -const _ = require('lodash'); -const dayjs = require('dayjs'); -const learningContent = require('./learning-content'); -const profileTooling = require('./profile-tooling'); -const generic = require('./generic'); -const CampaignParticipationStatuses = require('../../../../../lib/domain/models/CampaignParticipationStatuses'); -const Assessment = require('../../../../../lib/domain/models/Assessment'); +import _ from 'lodash'; +import dayjs from 'dayjs'; +import * as learningContent from './learning-content.js'; +import * as profileTooling from './profile-tooling.js'; +import * as generic from './generic.js'; +import { CampaignParticipationStatuses } from '../../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { Assessment } from '../../../../../lib/domain/models/Assessment.js'; -module.exports = { - createAssessmentCampaign, - createProfilesCollectionCampaign, -}; +export { createAssessmentCampaign, createProfilesCollectionCampaign }; /** * Fonction générique pour créer une campagne d'évaluation selon une configuration donnée. @@ -100,7 +97,7 @@ async function createAssessmentCampaign({ const skillsCapped = skillsForTube.filter((skill) => skill.level <= parseInt(cappedTube.level)); skillCount += skillsCapped.length; skillsCapped.map((skill) => - databaseBuilder.factory.buildCampaignSkill({ campaignId: realCampaignId, skillId: skill.id }), + databaseBuilder.factory.buildCampaignSkill({ campaignId: realCampaignId, skillId: skill.id }) ); } const badgeIds = await databaseBuilder.knex('badges').pluck('id').where({ targetProfileId }); @@ -108,7 +105,7 @@ async function createAssessmentCampaign({ const userAndLearnerIds = await _createOrRetrieveUsersAndLearners( databaseBuilder, realOrganizationId, - configCampaign.participantCount, + configCampaign.participantCount ); const answersAndKnowledgeElementsForProfile = await _getProfile('PERFECT'); @@ -166,7 +163,7 @@ async function createAssessmentCampaign({ userId, ...keData, createdAt: dayjs().subtract(1, 'day'), - }), + }) ); } for (const badgeId of badgeIds) { @@ -189,7 +186,7 @@ async function createAssessmentCampaign({ userId, ...keData, createdAt: dayjs().subtract(1, 'day'), - }), + }) ); } databaseBuilder.factory.buildKnowledgeElementSnapshot({ @@ -283,7 +280,7 @@ async function createProfilesCollectionCampaign({ const userAndLearnerIds = await _createOrRetrieveUsersAndLearners( databaseBuilder, realOrganizationId, - configCampaign.participantCount, + configCampaign.participantCount ); const profileDistribution = [ ...Array(configCampaign.profileDistribution.beginner || 0).fill('BEGINNER'), @@ -333,7 +330,7 @@ async function createProfilesCollectionCampaign({ userId, ...keData, createdAt: dayjs().subtract(1, 'day'), - }), + }) ); } databaseBuilder.factory.buildKnowledgeElementSnapshot({ diff --git a/api/db/seeds/data/common/tooling/certification-center-tooling.js b/api/db/seeds/data/common/tooling/certification-center-tooling.js index 049bb9338f9..e0f37b0ee96 100644 --- a/api/db/seeds/data/common/tooling/certification-center-tooling.js +++ b/api/db/seeds/data/common/tooling/certification-center-tooling.js @@ -1,6 +1,4 @@ -module.exports = { - createCertificationCenter, -}; +export { createCertificationCenter }; /** * Fonction générique pour créer un centre de certification selon une configuration donnée. @@ -62,7 +60,7 @@ function _buildCertificationCenterHabilitations({ databaseBuilder.factory.buildComplementaryCertificationHabilitation({ certificationCenterId, complementaryCertificationId, - }), + }) ); } @@ -73,7 +71,7 @@ function _buildCertificationCenterMemberships({ databaseBuilder, certificationCe certificationCenterId, createdAt: new Date(), isReferer: false, - }), + }) ); } diff --git a/api/db/seeds/data/common/tooling/generic.js b/api/db/seeds/data/common/tooling/generic.js index 17ac3a64d7e..afea7d2fc96 100644 --- a/api/db/seeds/data/common/tooling/generic.js +++ b/api/db/seeds/data/common/tooling/generic.js @@ -1,9 +1,6 @@ -const _ = require('lodash'); +import _ from 'lodash'; -module.exports = { - pickRandomAmong, - pickOneRandomAmong, -}; +export { pickRandomAmong, pickOneRandomAmong }; function pickRandomAmong(collection, howMuch) { const shuffledCollection = _.sortBy(collection, () => _.random(0, 100)); diff --git a/api/db/seeds/data/common/tooling/index.js b/api/db/seeds/data/common/tooling/index.js index 4e0a61939a8..2592fb2f87b 100644 --- a/api/db/seeds/data/common/tooling/index.js +++ b/api/db/seeds/data/common/tooling/index.js @@ -1,17 +1,9 @@ -const campaign = require('./campaign-tooling'); -const session = require('./session-tooling'); -const profile = require('./profile-tooling'); -const targetProfile = require('./target-profile-tooling'); -const training = require('./training-tooling'); -const organization = require('./organization-tooling'); -const certificationCenter = require('./certification-center-tooling'); +import * as campaign from './campaign-tooling.js'; +import * as session from './session-tooling.js'; +import * as profile from './profile-tooling.js'; +import * as targetProfile from './target-profile-tooling.js'; +import * as training from './training-tooling.js'; +import * as organization from './organization-tooling.js'; +import * as certificationCenter from './certification-center-tooling.js'; -module.exports = { - campaign, - certificationCenter, - organization, - session, - targetProfile, - training, - profile, -}; +export { campaign, certificationCenter, organization, session, targetProfile, training, profile }; diff --git a/api/db/seeds/data/common/tooling/learning-content.js b/api/db/seeds/data/common/tooling/learning-content.js index fe6b4e1dae0..6ba6c5ed13e 100644 --- a/api/db/seeds/data/common/tooling/learning-content.js +++ b/api/db/seeds/data/common/tooling/learning-content.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const competenceRepository = require('../../../../../lib/infrastructure/repositories/competence-repository'); -const challengeRepository = require('../../../../../lib/infrastructure/repositories/challenge-repository'); -const { skillDatasource } = require('../../../../../lib/infrastructure/datasources/learning-content/skill-datasource'); +import _ from 'lodash'; +import * as competenceRepository from '../../../../../lib/infrastructure/repositories/competence-repository.js'; +import * as challengeRepository from '../../../../../lib/infrastructure/repositories/challenge-repository.js'; +import { skillDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/skill-datasource.js'; let ALL_COMPETENCES, ALL_ACTIVE_SKILLS, ALL_CHALLENGES, ACTIVE_SKILLS_BY_COMPETENCE, ACTIVE_SKILLS_BY_TUBE; let VALIDATED_CHALLENGES_BY_SKILL; @@ -85,7 +85,7 @@ async function findActiveSkillsByFrameworkName(frameworkName) { return _.filter(activeSkills, (activeSkill) => competenceIds.includes(activeSkill.competenceId)); } -module.exports = { +export { getAllCompetences, getCoreCompetences, findActiveSkillsByCompetenceId, diff --git a/api/db/seeds/data/common/tooling/organization-tooling.js b/api/db/seeds/data/common/tooling/organization-tooling.js index e5c2e1dc5d7..62bcfbe9fda 100644 --- a/api/db/seeds/data/common/tooling/organization-tooling.js +++ b/api/db/seeds/data/common/tooling/organization-tooling.js @@ -1,6 +1,4 @@ -module.exports = { - createOrganization, -}; +export { createOrganization }; /** * Fonction générique pour créer une organisation selon une configuration donnée. @@ -153,7 +151,7 @@ function _buildOrganizationFeatures({ databaseBuilder, organizationId, featureId databaseBuilder.factory.buildOrganizationFeature({ organizationId, featureId, - }), + }) ); } @@ -162,7 +160,7 @@ function _buildOrganizationTags({ databaseBuilder, organizationId, tagIds }) { databaseBuilder.factory.buildOrganizationTag({ organizationId, tagId, - }), + }) ); } @@ -180,7 +178,7 @@ function _buildMemberships({ databaseBuilder, organizationId, adminUserId, membe userId: memberId, organizationId, organizationRole: 'MEMBER', - }), + }) ); } diff --git a/api/db/seeds/data/common/tooling/profile-tooling.js b/api/db/seeds/data/common/tooling/profile-tooling.js index c1bed0cb64c..b3b6f2feeae 100644 --- a/api/db/seeds/data/common/tooling/profile-tooling.js +++ b/api/db/seeds/data/common/tooling/profile-tooling.js @@ -1,12 +1,12 @@ -const _ = require('lodash'); -const learningContent = require('./learning-content'); -const generic = require('./generic'); -const Assessment = require('../../../../../lib/domain/models/Assessment'); -const CompetenceEvaluation = require('../../../../../lib/domain/models/CompetenceEvaluation'); -const { PIX_COUNT_BY_LEVEL } = require('../../../../../lib/domain/constants'); +import _ from 'lodash'; +import * as learningContent from './learning-content.js'; +import * as generic from './generic.js'; +import { Assessment } from '../../../../../lib/domain/models/Assessment.js'; +import { CompetenceEvaluation } from '../../../../../lib/domain/models/CompetenceEvaluation.js'; +import { PIX_COUNT_BY_LEVEL } from '../../../../../lib/domain/constants.js'; const UNREACHABLE_PIX_SCORE = 999999; -module.exports = { +export { createCertifiableProfile, createPerfectProfile, getAnswersAndKnowledgeElementsForAdvancedProfile, @@ -167,7 +167,7 @@ function _makeCompetenceEvaluation({ databaseBuilder, userId, competenceId }) { function _makeUserReachPixScoreForCompetences({ databaseBuilder, userId, answersAndKnowledgeElementsCollection }) { const answersAndKnowledgeElementsByCompetenceId = _.groupBy( answersAndKnowledgeElementsCollection, - ({ keData }) => keData.competenceId, + ({ keData }) => keData.competenceId ); for (const [competenceId, answersAndKnowledgeElements] of Object.entries(answersAndKnowledgeElementsByCompetenceId)) { const assessmentId = _makeCompetenceEvaluation({ databaseBuilder, userId, competenceId }); diff --git a/api/db/seeds/data/common/tooling/session-tooling.js b/api/db/seeds/data/common/tooling/session-tooling.js index ed9b28c2a4c..93af6eb8f28 100644 --- a/api/db/seeds/data/common/tooling/session-tooling.js +++ b/api/db/seeds/data/common/tooling/session-tooling.js @@ -1,22 +1,18 @@ -const _ = require('lodash'); -const learningContent = require('./learning-content'); -const campaignTooling = require('./campaign-tooling'); -const generic = require('./generic'); -const { +import _ from 'lodash'; +import * as learningContent from './learning-content.js'; +import * as campaignTooling from './campaign-tooling.js'; +import * as generic from './generic.js'; + +import { CLEA_COMPLEMENTARY_CERTIFICATION_ID, PIX_DROIT_COMPLEMENTARY_CERTIFICATION_ID, PIX_EDU_1ER_DEGRE_COMPLEMENTARY_CERTIFICATION_ID, PIX_EDU_2ND_DEGRE_COMPLEMENTARY_CERTIFICATION_ID, -} = require('../common-builder'); +} from '../common-builder.js'; let verifCodeCount = 0; -module.exports = { - createDraftScoSession, - createPublishedScoSession, - createDraftSession, - createPublishedSession, -}; +export { createDraftScoSession, createPublishedScoSession, createDraftSession, createPublishedSession }; /** * Fonction générique pour créer une session sco avec candidats non démarrée selon une configuration donnée. @@ -378,14 +374,14 @@ async function createPublishedSession({ const { coreProfileData, complementaryCertificationsProfileData } = await _makeCandidatesCertifiable( databaseBuilder, - certificationCandidates, + certificationCandidates ); await _makeCandidatesPassCertification( databaseBuilder, sessionId, certificationCandidates, coreProfileData, - complementaryCertificationsProfileData, + complementaryCertificationsProfileData ); return { sessionId }; @@ -409,7 +405,7 @@ async function _registerOrganizationLearnersToSession({ databaseBuilder, sessionId, extraTimePercentages, - hasJoinSession, + hasJoinSession ); } return certificationCandidates; @@ -421,7 +417,7 @@ function _addCertificationCandidatesToScoSession( databaseBuilder, sessionId, extraTimePercentages, - hasJoinSession, + hasJoinSession ) { organizationLearners.forEach((organizationLearner, index) => { certificationCandidates.push( @@ -444,7 +440,7 @@ function _addCertificationCandidatesToScoSession( authorizedToStart: false, billingMode: null, prepaymentCode: null, - }), + }) ); }); } @@ -558,7 +554,7 @@ async function _getComplementaryCertificationIdsFromCertificationCenterHabilitat ...(await databaseBuilder .knex('complementary-certification-habilitations') .pluck('complementaryCertificationId') - .where('certificationCenterId', certificationCenterId)), + .where('certificationCenterId', certificationCenterId)) ); } @@ -623,7 +619,7 @@ async function _makeCandidatesCertifiable(databaseBuilder, certificationCandidat coreProfileData: await _makeCandidatesCoreCertifiable(databaseBuilder, certificationCandidates), complementaryCertificationsProfileData: await _makeCandidatesComplementaryCertifiable( databaseBuilder, - certificationCandidates, + certificationCandidates ), }; } @@ -675,7 +671,7 @@ async function _makeCandidatesCoreCertifiable(databaseBuilder, certificationCand } coreProfileData[competence.id].threeMostDifficultSkillsAndChallenges = _.takeRight( coreProfileData[competence.id].threeMostDifficultSkillsAndChallenges, - 3, + 3 ); coreProfileData[competence.id].pixScore = Math.ceil(coreProfileData[competence.id].pixScore); } @@ -692,7 +688,7 @@ async function _makeCandidatesComplementaryCertifiable(databaseBuilder, certific ]) { const certificationCandidatesWithSubscription = certificationCandidates.filter( (certificationCandidate) => - certificationCandidate.complementaryCertificationSubscribedId === complementaryCertificationId, + certificationCandidate.complementaryCertificationSubscribedId === complementaryCertificationId ); if (certificationCandidatesWithSubscription.length > 0) { complementaryCertificationsProfileData[complementaryCertificationId] = @@ -700,7 +696,7 @@ async function _makeCandidatesComplementaryCertifiable(databaseBuilder, certific databaseBuilder, complementaryCertificationId, frameworkName, - certificationCandidatesWithSubscription, + certificationCandidatesWithSubscription ); } } @@ -711,7 +707,7 @@ async function _makeCandidatesComplementaryCertificationCertifiable( databaseBuilder, complementaryCertificationId, frameworkName, - certificationCandidates, + certificationCandidates ) { const [targetProfileId] = await databaseBuilder .knex('complementary-certification-badges') @@ -802,11 +798,11 @@ async function _makeCandidatesComplementaryCertificationCertifiable( for (const [areaId, { fourMostDifficultSkillsAndChallenges }] of Object.entries(complementaryProfileData)) { complementaryProfileData[areaId].fourMostDifficultSkillsAndChallenges = _.orderBy( fourMostDifficultSkillsAndChallenges, - ({ skill }) => skill.level, + ({ skill }) => skill.level ); complementaryProfileData[areaId].fourMostDifficultSkillsAndChallenges = _.takeRight( complementaryProfileData[areaId].fourMostDifficultSkillsAndChallenges, - 4, + 4 ); } @@ -818,7 +814,7 @@ function _makeCandidatesPassCertification( sessionId, certificationCandidates, coreProfileData, - complementaryCertificationsProfileData, + complementaryCertificationsProfileData ) { for (const certificationCandidate of certificationCandidates) { const certificationCourseId = databaseBuilder.factory.buildCertificationCourse({ diff --git a/api/db/seeds/data/common/tooling/target-profile-tooling.js b/api/db/seeds/data/common/tooling/target-profile-tooling.js index 8877d3c47bf..66ed7812053 100644 --- a/api/db/seeds/data/common/tooling/target-profile-tooling.js +++ b/api/db/seeds/data/common/tooling/target-profile-tooling.js @@ -1,12 +1,8 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const learningContent = require('./learning-content'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import * as learningContent from './learning-content.js'; -module.exports = { - createTargetProfile, - createBadge, - createStages, -}; +export { createTargetProfile, createBadge, createStages }; let frameworkNames; const tubeIdsByFramework = {}; /** @@ -66,7 +62,7 @@ async function createTargetProfile({ .uniq() .value(); }, - { concurrency: 3 }, + { concurrency: 3 } ); frameworkNames = Object.keys(tubeIdsByFramework); } @@ -186,7 +182,7 @@ function createStages({ value: null, isFirstSkill: true, shouldInsertPrescriberTitleAndDescription, - }), + }) ); --currentCountStages; } @@ -210,7 +206,7 @@ function createStages({ value, isFirstSkill: false, shouldInsertPrescriberTitleAndDescription, - }), + }) ); } return { stageIds }; @@ -246,7 +242,7 @@ function _createTargetProfile({ databaseBuilder.factory.buildTargetProfileShare({ targetProfileId, organizationId, - }), + }) ); } @@ -307,7 +303,7 @@ function _createTargetProfileTubes({ databaseBuilder, targetProfileId, configTar for (let i = 0; i < framework.countTubes; ++i) { const tubeId = _pickRandomTube( frameworkName, - cappedTubesDTO.map(({ id }) => id), + cappedTubesDTO.map(({ id }) => id) ); if (tubeId) { const level = _.random(framework.minLevel, framework.maxLevel); diff --git a/api/db/seeds/data/common/tooling/training-tooling.js b/api/db/seeds/data/common/tooling/training-tooling.js index 5b94ddcaed8..d17bff36314 100644 --- a/api/db/seeds/data/common/tooling/training-tooling.js +++ b/api/db/seeds/data/common/tooling/training-tooling.js @@ -1,10 +1,8 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const learningContent = require('./learning-content'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import * as learningContent from './learning-content.js'; -module.exports = { - createTraining, -}; +export { createTraining }; const tubeIdsByFramework = {}; let frameworkNames; @@ -66,7 +64,7 @@ async function createTraining({ .uniq() .value(); }, - { concurrency: 3 }, + { concurrency: 3 } ); frameworkNames = Object.keys(tubeIdsByFramework); } @@ -84,7 +82,7 @@ async function createTraining({ databaseBuilder.factory.buildTargetProfileTraining({ targetProfileId, trainingId, - }), + }) ); const cappedTubesDTO = []; for (const configTrigger of configTriggers) { @@ -98,7 +96,7 @@ async function createTraining({ for (let i = 0; i < framework.countTubes; ++i) { const tubeId = _pickRandomTube( frameworkName, - cappedTubesDTO.map(({ id }) => id), + cappedTubesDTO.map(({ id }) => id) ); if (tubeId) { const level = _.random(framework.minLevel, framework.maxLevel); diff --git a/api/db/seeds/data/feature/feature-builder.js b/api/db/seeds/data/feature/feature-builder.js index 1f8ae267864..62d95c34f00 100644 --- a/api/db/seeds/data/feature/feature-builder.js +++ b/api/db/seeds/data/feature/feature-builder.js @@ -1,8 +1,9 @@ -const apps = require('../../../../lib/domain/constants.js'); - -module.exports = function featuresBuilder({ databaseBuilder }) { +import * as apps from '../../../../lib/domain/constants.js'; +const featuresBuilder = function ({ databaseBuilder }) { databaseBuilder.factory.buildFeature({ key: apps.ORGANIZATION_FEATURE.MULTIPLE_SENDING_ASSESSMENT, }); }; + +export { featuresBuilder }; diff --git a/api/db/seeds/data/fill-campaign-skills.js b/api/db/seeds/data/fill-campaign-skills.js index 7e3a30895e5..13dc571b153 100644 --- a/api/db/seeds/data/fill-campaign-skills.js +++ b/api/db/seeds/data/fill-campaign-skills.js @@ -1,5 +1,5 @@ -const { knex } = require('../../../db/knex-database-connection'); -const skillRepository = require('../../../lib/infrastructure/repositories/skill-repository'); +import { knex } from '../../../db/knex-database-connection.js'; +import * as skillRepository from '../../../lib/infrastructure/repositories/skill-repository.js'; async function fillCampaignSkills() { const campaigns = await knex('campaigns') @@ -35,6 +35,4 @@ async function fillCampaignSkills() { } } -module.exports = { - fillCampaignSkills, -}; +export { fillCampaignSkills }; diff --git a/api/db/seeds/data/organization-places-pro-builder.js b/api/db/seeds/data/organization-places-pro-builder.js index 754f3455931..84fd4ac6312 100644 --- a/api/db/seeds/data/organization-places-pro-builder.js +++ b/api/db/seeds/data/organization-places-pro-builder.js @@ -1,5 +1,5 @@ -const { PRO_COMPANY_ID } = require('./organizations-pro-builder'); -const { PIX_SUPER_ADMIN_ID } = require('./users-builder'); +import { PRO_COMPANY_ID } from './organizations-pro-builder.js'; +import { PIX_SUPER_ADMIN_ID } from './users-builder.js'; function organizationPlacesProBuilder({ databaseBuilder }) { const activationDate = new Date(); const expirationDate = new Date(); @@ -91,6 +91,4 @@ function organizationPlacesProBuilder({ databaseBuilder }) { }); } -module.exports = { - organizationPlacesProBuilder, -}; +export { organizationPlacesProBuilder }; diff --git a/api/db/seeds/data/organizations-pro-builder.js b/api/db/seeds/data/organizations-pro-builder.js index 03e1e76d16d..fb309956f35 100644 --- a/api/db/seeds/data/organizations-pro-builder.js +++ b/api/db/seeds/data/organizations-pro-builder.js @@ -1,9 +1,12 @@ -const Membership = require('../../../lib/domain/models/Membership'); -const OrganizationInvitation = require('../../../lib/domain/models/OrganizationInvitation'); -const { ROLES } = require('../../../lib/domain/constants').PIX_ADMIN; -const { DEFAULT_PASSWORD, PIX_ALL_ORGA_ID } = require('./users-builder'); -const OidcIdentityProviders = require('../../../lib/domain/constants/oidc-identity-providers'); +import { Membership } from '../../../lib/domain/models/Membership.js'; +import { OrganizationInvitation } from '../../../lib/domain/models/OrganizationInvitation.js'; +import { PIX_ADMIN } from '../../../lib/domain/constants.js'; +const { ROLES } = PIX_ADMIN; + +import { DEFAULT_PASSWORD, PIX_ALL_ORGA_ID } from './users-builder.js'; +import * as OidcIdentityProviders from '../../../lib/domain/constants/oidc-identity-providers.js'; +import { logoUrl } from '../src/dragonAndCoBase64.js'; const PRO_COMPANY_ID = 1; const PRO_POLE_EMPLOI_ID = 4; const PRO_CNAV_ID = 17; @@ -46,7 +49,7 @@ function organizationsProBuilder({ databaseBuilder }) { id: PRO_COMPANY_ID, type: 'PRO', name: 'Dragon & Co', - logoUrl: require('../src/dragonAndCoBase64'), + logoUrl, createdBy: privateCompanyCreator.id, credit: 100, externalId: null, @@ -244,7 +247,7 @@ function organizationsProBuilder({ databaseBuilder }) { }); } -module.exports = { +export { organizationsProBuilder, PRO_COMPANY_ID, PRO_POLE_EMPLOI_ID, diff --git a/api/db/seeds/data/organizations-sco-builder.js b/api/db/seeds/data/organizations-sco-builder.js index 34dab50d209..d755525d230 100644 --- a/api/db/seeds/data/organizations-sco-builder.js +++ b/api/db/seeds/data/organizations-sco-builder.js @@ -1,15 +1,18 @@ -const Membership = require('../../../lib/domain/models/Membership'); -const { DEFAULT_PASSWORD, PIX_ALL_ORGA_ID } = require('./users-builder'); -const { SamlIdentityProviders } = require('../../../lib/domain/constants/saml-identity-providers'); -const { ROLES } = require('../../../lib/domain/constants').PIX_ADMIN; -const { +import { Membership } from '../../../lib/domain/models/Membership.js'; +import { DEFAULT_PASSWORD, PIX_ALL_ORGA_ID } from './users-builder.js'; +import { SamlIdentityProviders } from '../../../lib/domain/constants/saml-identity-providers.js'; +import { PIX_ADMIN } from '../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; + +import { SCO_COLLEGE_EXTERNAL_ID, SCO_LYCEE_EXTERNAL_ID, SCO_AGRI_EXTERNAL_ID, SCO_NO_MANAGING_STUDENTS_EXTERNAL_ID, SCO_COLLEGE_WITHOUT_STUDENT_EXTERNAL_ID, GREAT_OAK_CERTIF_CENTER_EXTERNAL_ID, -} = require('../data/certification/certification-centers-builder'); +} from '../data/certification/certification-centers-builder.js'; const SCO_MIDDLE_SCHOOL_ID = 3; const SCO_HIGH_SCHOOL_ID = 6; @@ -546,7 +549,7 @@ function _buildAEFE({ databaseBuilder }) { }); } -module.exports = { +export { organizationsScoBuilder, SCO_MIDDLE_SCHOOL_ID, SCO_HIGH_SCHOOL_ID, diff --git a/api/db/seeds/data/organizations-sup-builder.js b/api/db/seeds/data/organizations-sup-builder.js index 7df8042e6bc..fe880705eea 100644 --- a/api/db/seeds/data/organizations-sup-builder.js +++ b/api/db/seeds/data/organizations-sup-builder.js @@ -1,6 +1,9 @@ -const Membership = require('../../../lib/domain/models/Membership'); -const { ROLES } = require('../../../lib/domain/constants').PIX_ADMIN; -const { DEFAULT_PASSWORD, PIX_ALL_ORGA_ID } = require('./users-builder'); +import { Membership } from '../../../lib/domain/models/Membership.js'; +import { PIX_ADMIN } from '../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; + +import { DEFAULT_PASSWORD, PIX_ALL_ORGA_ID } from './users-builder.js'; const SUP_UNIVERSITY_ID = 2; const SUP_STUDENT_ASSOCIATED_ID = 888; @@ -154,11 +157,10 @@ function organizationsSupBuilder({ databaseBuilder }) { }); } -module.exports = { +export { organizationsSupBuilder, SUP_UNIVERSITY_ID, SUP_STUDENT_ASSOCIATED_ID, SUP_STUDENT_DISABLED_ID, SUP_STUDENT_CERTIFIABLE, - }; diff --git a/api/db/seeds/data/pix-admin-roles-builder.js b/api/db/seeds/data/pix-admin-roles-builder.js index 34df52c2d8f..409c586ab1c 100644 --- a/api/db/seeds/data/pix-admin-roles-builder.js +++ b/api/db/seeds/data/pix-admin-roles-builder.js @@ -1,14 +1,13 @@ -const { - PIX_SUPER_ADMIN_ID, - PIX_SUPPORT_ID, - PIX_METIER_ID, - PIX_CERTIF_ID, -} = require('./users-builder'); -const { ROLES } = require('../../../lib/domain/constants').PIX_ADMIN; +import { PIX_SUPER_ADMIN_ID, PIX_SUPPORT_ID, PIX_METIER_ID, PIX_CERTIF_ID } from './users-builder.js'; +import { PIX_ADMIN } from '../../../lib/domain/constants.js'; -module.exports = function pixAdminRolesBuilder({ databaseBuilder }) { +const { ROLES } = PIX_ADMIN; + +const pixAdminRolesBuilder = function ({ databaseBuilder }) { databaseBuilder.factory.buildPixAdminRole({ userId: PIX_SUPER_ADMIN_ID, role: ROLES.SUPER_ADMIN }); databaseBuilder.factory.buildPixAdminRole({ userId: PIX_SUPPORT_ID, role: ROLES.SUPPORT }); databaseBuilder.factory.buildPixAdminRole({ userId: PIX_METIER_ID, role: ROLES.METIER }); databaseBuilder.factory.buildPixAdminRole({ userId: PIX_CERTIF_ID, role: ROLES.CERTIF }); }; + +export { pixAdminRolesBuilder }; diff --git a/api/db/seeds/data/pix-aile-profile-builder.js b/api/db/seeds/data/pix-aile-profile-builder.js index a73afd25bac..757e83595d3 100644 --- a/api/db/seeds/data/pix-aile-profile-builder.js +++ b/api/db/seeds/data/pix-aile-profile-builder.js @@ -1,14 +1,22 @@ -const Assessment = require('../../../lib/domain/models/Assessment'); -const CompetenceEvaluation = require('../../../lib/domain/models/CompetenceEvaluation'); -const KnowledgeElement = require('../../../lib/domain/models/KnowledgeElement'); -const moment = require('moment'); -const _ = require('lodash'); - -module.exports = function buildPixAileProfilev2({ databaseBuilder }) { +import { Assessment } from '../../../lib/domain/models/Assessment.js'; +import { CompetenceEvaluation } from '../../../lib/domain/models/CompetenceEvaluation.js'; +import { KnowledgeElement } from '../../../lib/domain/models/KnowledgeElement.js'; +import moment from 'moment'; +import _ from 'lodash'; +const buildPixAileProfilev2 = function ({ databaseBuilder }) { const userId = 1; - const _buildKnowledgeElement = ({ competenceId, answerId, skillId, assessmentId, keStatus, keSource, remainingDays, remainingHours }) => { + const _buildKnowledgeElement = ({ + competenceId, + answerId, + skillId, + assessmentId, + keStatus, + keSource, + remainingDays, + remainingHours, + }) => { const delay = 7 - remainingDays; databaseBuilder.factory.buildKnowledgeElement({ source: keSource, @@ -23,7 +31,6 @@ module.exports = function buildPixAileProfilev2({ databaseBuilder }) { }; const buildCompetenceEvaluation = ({ competenceId, assessmentState }) => { - const { id: assessmentId } = databaseBuilder.factory.buildAssessment({ userId, competenceId, @@ -34,20 +41,28 @@ module.exports = function buildPixAileProfilev2({ databaseBuilder }) { databaseBuilder.factory.buildCompetenceEvaluation({ assessmentId, competenceId, - status: assessmentState === Assessment.states.COMPLETED ? CompetenceEvaluation.statuses.COMPLETED : CompetenceEvaluation.statuses.STARTED, + status: + assessmentState === Assessment.states.COMPLETED + ? CompetenceEvaluation.statuses.COMPLETED + : CompetenceEvaluation.statuses.STARTED, userId, }); return { assessmentId }; }; - const buildCompetencePlacement = ({ competenceId, assessmentState, challengeSkillMap, remainingDays, remainingHours }) => { + const buildCompetencePlacement = ({ + competenceId, + assessmentState, + challengeSkillMap, + remainingDays, + remainingHours, + }) => { const { assessmentId } = buildCompetenceEvaluation({ competenceId, assessmentState, }); _.map(challengeSkillMap, (challengeSkill) => { - const { id: answerId } = databaseBuilder.factory.buildAnswer({ result: 'ok', assessmentId, @@ -89,7 +104,9 @@ module.exports = function buildPixAileProfilev2({ databaseBuilder }) { { challengeId: 'recwWzTquPlvIl4So', skillId: 'recUDrCWD76fp5MsE', inferredSkillIds: ['rec4Gvnh9kV1NeMsw'] }, { challengeId: 'rec6ZOkRMNlJNAKgl', skillId: 'recYLxHqrLVUBjF2a', inferredSkillIds: ['recRPl7tXR8n2D5xU'] }, { - challengeId: 'recX3USEK62h8rACE', skillId: 'recfO8994EvSQV9Ip', inferredSkillIds: ['rec0aOgRFRJ1qPG0b'], + challengeId: 'recX3USEK62h8rACE', + skillId: 'recfO8994EvSQV9Ip', + inferredSkillIds: ['rec0aOgRFRJ1qPG0b'], knowledgeElementStatus: KnowledgeElement.StatusType.INVALIDATED, }, ], @@ -102,7 +119,11 @@ module.exports = function buildPixAileProfilev2({ databaseBuilder }) { remainingDays: 0, challengeSkillMap: [ { challengeId: 'recPVnm4VSMQUJmq3', skillId: 'recJKLhRCjl9zizHr', inferredSkillIds: ['recdmDASRPMTzOmVc'] }, - { challengeId: 'rec7b0FTFINsQ5u6t', skillId: 'recPiCGFhfgervqr5', inferredSkillIds: ['reckyBHOf8yIl2UGq', 'recfRe4luCCP8GoVA', 'recmMMVns3LEFkHeO'] }, + { + challengeId: 'rec7b0FTFINsQ5u6t', + skillId: 'recPiCGFhfgervqr5', + inferredSkillIds: ['reckyBHOf8yIl2UGq', 'recfRe4luCCP8GoVA', 'recmMMVns3LEFkHeO'], + }, ], }); @@ -114,7 +135,11 @@ module.exports = function buildPixAileProfilev2({ databaseBuilder }) { challengeSkillMap: [ { challengeId: 'reczK5XPKm5CKImGj', skillId: 'recUDrhjEYqmfahRX', inferredSkillIds: [] }, { challengeId: 'recChtlIRd8xOz3aP', skillId: 'rec0tk8dZWOzSQbaQ', inferredSkillIds: ['recPGDVdX0LSOWQQC'] }, - { challengeId: 'rec9e4StT33VC0V6M', skillId: 'rec1TZRdq2lKyLEaR', inferredSkillIds: ['recTR73NgMRmrKRhT', 'recl2LAo6vB6BOgUd'] }, + { + challengeId: 'rec9e4StT33VC0V6M', + skillId: 'rec1TZRdq2lKyLEaR', + inferredSkillIds: ['recTR73NgMRmrKRhT', 'recl2LAo6vB6BOgUd'], + }, ], }); @@ -125,7 +150,11 @@ module.exports = function buildPixAileProfilev2({ databaseBuilder }) { remainingDays: 0, challengeSkillMap: [ { challengeId: 'recXN6TmIEgv2w6EC', skillId: 'recZLbpY9xhnR1XaX', inferredSkillIds: [] }, - { challengeId: 'recZVmpmCSMBpxPzl', skillId: 'recdY2TTdWEFz59T1', inferredSkillIds: ['recMG1dWPxaQ3OeZ8', 'recMG1uOZwLGuVyxP', 'recKWLJSisAK7f0Cy'] }, + { + challengeId: 'recZVmpmCSMBpxPzl', + skillId: 'recdY2TTdWEFz59T1', + inferredSkillIds: ['recMG1dWPxaQ3OeZ8', 'recMG1uOZwLGuVyxP', 'recKWLJSisAK7f0Cy'], + }, ], }); @@ -135,9 +164,19 @@ module.exports = function buildPixAileProfilev2({ databaseBuilder }) { assessmentState: Assessment.states.COMPLETED, remainingDays: 0, challengeSkillMap: [ - { challengeId: 'rec6fKT1tmlqI6AT6', skillId: 'rectVTDWtVIT59Dy1', inferredSkillIds: ['recXSjRtUP31qRvun', 'recBeo3fIb35FXtmF', 'recipfF8DQqJjv9pI'] }, - { challengeId: 'recijE4sMaS0mkjVu', skillId: 'recGHY2N1qq1FYH4J', inferredSkillIds: ['recTmjG8ygtFjGfP9', 'rechLuj5ydZs48koG', 'recjaPxapJkF1cx5k', 'recRJyPT0FBEeVkzR'] }, + { + challengeId: 'rec6fKT1tmlqI6AT6', + skillId: 'rectVTDWtVIT59Dy1', + inferredSkillIds: ['recXSjRtUP31qRvun', 'recBeo3fIb35FXtmF', 'recipfF8DQqJjv9pI'], + }, + { + challengeId: 'recijE4sMaS0mkjVu', + skillId: 'recGHY2N1qq1FYH4J', + inferredSkillIds: ['recTmjG8ygtFjGfP9', 'rechLuj5ydZs48koG', 'recjaPxapJkF1cx5k', 'recRJyPT0FBEeVkzR'], + }, { challengeId: 'recZjuf1caEli6BHp', skillId: 'recW0pab7QV7dlB97', inferredSkillIds: [] }, ], }); }; + +export { buildPixAileProfilev2 }; diff --git a/api/db/seeds/data/pole-emploi-sendings-builder.js b/api/db/seeds/data/pole-emploi-sendings-builder.js index 8921aea3552..627ac29a1b2 100644 --- a/api/db/seeds/data/pole-emploi-sendings-builder.js +++ b/api/db/seeds/data/pole-emploi-sendings-builder.js @@ -1,10 +1,13 @@ -const _ = require('lodash'); -const { POLE_EMPLOI_CAMPAIGN_ID } = require('./campaigns-pro-builder'); -const { PRO_POLE_EMPLOI_ID } = require('./organizations-pro-builder'); +import _ from 'lodash'; +import { POLE_EMPLOI_CAMPAIGN_ID } from './campaigns-pro-builder.js'; +import { PRO_POLE_EMPLOI_ID } from './organizations-pro-builder.js'; -module.exports = function poleEmploiSendingsBuilder({ databaseBuilder }) { +const poleEmploiSendingsBuilder = function ({ databaseBuilder }) { const _generateStatus = () => { - const possibleChoices = [{ isSuccessful: true, responseCode: '200' }, { isSuccessful: false, responseCode: '400' }]; + const possibleChoices = [ + { isSuccessful: true, responseCode: '200' }, + { isSuccessful: false, responseCode: '400' }, + ]; return _.sample(possibleChoices); }; @@ -14,54 +17,87 @@ module.exports = function poleEmploiSendingsBuilder({ databaseBuilder }) { }; _.times(10, async (index) => { - const user = await databaseBuilder.factory.buildUser({ firstName: `FirstName-${index}`, lastName: `LastName-${index}` }); - await databaseBuilder.factory.buildAuthenticationMethod.withPoleEmploiAsIdentityProvider({ userId: user.id, externalIdentifier: `externalUserId${user.id}` }); - const organizationLearnerId = await databaseBuilder.factory.buildOrganizationLearner({ organizationId: PRO_POLE_EMPLOI_ID }).id; - const campaignParticipationId = await databaseBuilder.factory.buildCampaignParticipation({ userId: user.id, campaignId: POLE_EMPLOI_CAMPAIGN_ID, status: 'TO_SHARE', organizationLearnerId }).id; - await databaseBuilder.factory.buildAssessment({ userId: user.id, campaignParticipationId, type: 'CAMPAIGN', state: 'completed', method: 'SMART_RANDOM' }); - await databaseBuilder.factory.poleEmploiSendingFactory.build({ ..._generateStatus(), campaignParticipationId, type: 'CAMPAIGN_PARTICIPATION_START', createdAt: _generateDate(index), payload: { - campagne: { - nom: 'Campagne PE', - dateDebut: '2019-08-01T00:00:00.000Z', - type: 'EVALUATION', - codeCampagne: 'QWERTY789', - urlCampagne: 'https://app.pix.fr/campagnes/QWERTY789', - nomOrganisme: 'Pix', - typeOrganisme: 'externe', + const user = await databaseBuilder.factory.buildUser({ + firstName: `FirstName-${index}`, + lastName: `LastName-${index}`, + }); + await databaseBuilder.factory.buildAuthenticationMethod.withPoleEmploiAsIdentityProvider({ + userId: user.id, + externalIdentifier: `externalUserId${user.id}`, + }); + const organizationLearnerId = await databaseBuilder.factory.buildOrganizationLearner({ + organizationId: PRO_POLE_EMPLOI_ID, + }).id; + const campaignParticipationId = await databaseBuilder.factory.buildCampaignParticipation({ + userId: user.id, + campaignId: POLE_EMPLOI_CAMPAIGN_ID, + status: 'TO_SHARE', + organizationLearnerId, + }).id; + await databaseBuilder.factory.buildAssessment({ + userId: user.id, + campaignParticipationId, + type: 'CAMPAIGN', + state: 'completed', + method: 'SMART_RANDOM', + }); + await databaseBuilder.factory.poleEmploiSendingFactory.build({ + ..._generateStatus(), + campaignParticipationId, + type: 'CAMPAIGN_PARTICIPATION_START', + createdAt: _generateDate(index), + payload: { + campagne: { + nom: 'Campagne PE', + dateDebut: '2019-08-01T00:00:00.000Z', + type: 'EVALUATION', + codeCampagne: 'QWERTY789', + urlCampagne: 'https://app.pix.fr/campagnes/QWERTY789', + nomOrganisme: 'Pix', + typeOrganisme: 'externe', + }, + individu: { + nom: user.lastName, + prenom: user.firstName, + }, + test: { + etat: 2, + typeTest: 'DI', + referenceExterne: campaignParticipationId, + dateDebut: '2019-09-01T00:00:00.000Z', + elementsEvalues: [], + }, }, - individu: { - nom: user.lastName, - prenom: user.firstName, + }); + await databaseBuilder.factory.poleEmploiSendingFactory.build({ + ..._generateStatus(), + campaignParticipationId, + type: 'CAMPAIGN_PARTICIPATION_COMPLETION', + createdAt: _generateDate(index), + payload: { + campagne: { + nom: 'Campagne PE', + dateDebut: '2019-08-01T00:00:00.000Z', + type: 'EVALUATION', + codeCampagne: 'QWERTY789', + urlCampagne: 'https://app.pix.fr/campagnes/QWERTY789', + nomOrganisme: 'Pix', + typeOrganisme: 'externe', + }, + individu: { + nom: user.lastName, + prenom: user.firstName, + }, + test: { + etat: 3, + typeTest: 'DI', + referenceExterne: campaignParticipationId, + dateDebut: '2019-09-01T00:00:00.000Z', + elementsEvalues: [], + }, }, - test: { - etat: 2, - typeTest: 'DI', - referenceExterne: campaignParticipationId, - dateDebut: '2019-09-01T00:00:00.000Z', - elementsEvalues: [], - }, - } }); - await databaseBuilder.factory.poleEmploiSendingFactory.build({ ..._generateStatus(), campaignParticipationId, type: 'CAMPAIGN_PARTICIPATION_COMPLETION', createdAt: _generateDate(index), payload: { - campagne: { - nom: 'Campagne PE', - dateDebut: '2019-08-01T00:00:00.000Z', - type: 'EVALUATION', - codeCampagne: 'QWERTY789', - urlCampagne: 'https://app.pix.fr/campagnes/QWERTY789', - nomOrganisme: 'Pix', - typeOrganisme: 'externe', - }, - individu: { - nom: user.lastName, - prenom: user.firstName, - }, - test: { - etat: 3, - typeTest: 'DI', - referenceExterne: campaignParticipationId, - dateDebut: '2019-09-01T00:00:00.000Z', - elementsEvalues: [], - }, - } }); + }); }); }; + +export { poleEmploiSendingsBuilder }; diff --git a/api/db/seeds/data/stages-builder.js b/api/db/seeds/data/stages-builder.js index fee064f8f23..9f3fd9d4a52 100644 --- a/api/db/seeds/data/stages-builder.js +++ b/api/db/seeds/data/stages-builder.js @@ -1,19 +1,59 @@ -const { TARGET_PROFILE_STAGES_BADGES_ID, TARGET_PROFILE_STAGES_LEVEL_ID, TARGET_PROFILE_ONE_COMPETENCE_ID } = require('./target-profiles-builder'); +import { + TARGET_PROFILE_STAGES_BADGES_ID, + TARGET_PROFILE_STAGES_LEVEL_ID, + TARGET_PROFILE_ONE_COMPETENCE_ID, +} from './target-profiles-builder.js'; -module.exports = function stagesBuilder({ databaseBuilder }) { +const stagesBuilder = function ({ databaseBuilder }) { _buildStagesForTargetProfileId(databaseBuilder, TARGET_PROFILE_ONE_COMPETENCE_ID); _buildStagesForTargetProfileId(databaseBuilder, TARGET_PROFILE_STAGES_BADGES_ID); _buildStagesWithLevelForTargetProfileId(databaseBuilder, TARGET_PROFILE_STAGES_LEVEL_ID); }; +export { stagesBuilder }; + function _buildStagesForTargetProfileId(databaseBuilder, targetProfileId) { const stages = [ - { title: 'Super !', message: 'Tu as validé ton premier acquis', prescriberTitle: 'Premier Acquis', prescriberDescription: 'Un petit effort', isFirstSkill: true, threshold: null, targetProfileId }, + { + title: 'Super !', + message: 'Tu as validé ton premier acquis', + prescriberTitle: 'Premier Acquis', + prescriberDescription: 'Un petit effort', + isFirstSkill: true, + threshold: null, + targetProfileId, + }, { title: 'Bravo !', message: 'Tu as le palier 1', threshold: 0, targetProfileId }, - { title: 'Félicitations !', message: 'Tu as le palier 2', prescriberTitle: 'palier 2', prescriberDescription: 'Maîtrise partielle', threshold: 5, targetProfileId }, - { title: 'Bien joué !', message: 'Tu as le palier 3', prescriberTitle: 'palier 3', prescriberDescription: 'Maîtrise complète', threshold: 15, targetProfileId }, - { title: 'Trop fort(e) !', message: 'Tu as le palier 4', prescriberTitle: 'palier 4', threshold: 60, targetProfileId }, - { title: 'Quel(le) expert(e) !', message: 'Tu as le palier 5', prescriberDescription: 'Maîtrise absolue', threshold: 80, targetProfileId }, + { + title: 'Félicitations !', + message: 'Tu as le palier 2', + prescriberTitle: 'palier 2', + prescriberDescription: 'Maîtrise partielle', + threshold: 5, + targetProfileId, + }, + { + title: 'Bien joué !', + message: 'Tu as le palier 3', + prescriberTitle: 'palier 3', + prescriberDescription: 'Maîtrise complète', + threshold: 15, + targetProfileId, + }, + { + title: 'Trop fort(e) !', + message: 'Tu as le palier 4', + prescriberTitle: 'palier 4', + threshold: 60, + targetProfileId, + }, + { + title: 'Quel(le) expert(e) !', + message: 'Tu as le palier 5', + prescriberDescription: 'Maîtrise absolue', + threshold: 80, + targetProfileId, + }, ]; stages.forEach((stage) => databaseBuilder.factory.buildStage(stage)); @@ -21,12 +61,46 @@ function _buildStagesForTargetProfileId(databaseBuilder, targetProfileId) { function _buildStagesWithLevelForTargetProfileId(databaseBuilder, targetProfileId) { const stages = [ - { title: 'Super !', message: 'Tu as validé ton premier acquis', prescriberTitle: 'Premier Acquis', prescriberDescription: 'Un petit effort', isFirstSkill: true, level: null, targetProfileId }, + { + title: 'Super !', + message: 'Tu as validé ton premier acquis', + prescriberTitle: 'Premier Acquis', + prescriberDescription: 'Un petit effort', + isFirstSkill: true, + level: null, + targetProfileId, + }, { title: 'Pas mal mais pas max', message: 'Tu as le palier 1', level: 0, targetProfileId }, - { title: 'Félicitations !', message: 'Tu as le palier 2', prescriberTitle: 'équivalent niveau 2', prescriberDescription: 'Maîtrise partielle', level: 2, targetProfileId }, - { title: 'Bien joué !', message: 'Tu as le palier 3', prescriberTitle: 'équivalent niveau 3', prescriberDescription: 'Maîtrise complète', level: 3, targetProfileId }, - { title: 'Trop fort(e) !', message: 'Tu as le palier 4', prescriberTitle: 'équivalent niveau 4', level: 4, targetProfileId }, - { title: 'Quel(le) expert(e) !', message: 'Tu as le palier 5', prescriberDescription: 'Maîtrise absolue', level: 5, targetProfileId }, + { + title: 'Félicitations !', + message: 'Tu as le palier 2', + prescriberTitle: 'équivalent niveau 2', + prescriberDescription: 'Maîtrise partielle', + level: 2, + targetProfileId, + }, + { + title: 'Bien joué !', + message: 'Tu as le palier 3', + prescriberTitle: 'équivalent niveau 3', + prescriberDescription: 'Maîtrise complète', + level: 3, + targetProfileId, + }, + { + title: 'Trop fort(e) !', + message: 'Tu as le palier 4', + prescriberTitle: 'équivalent niveau 4', + level: 4, + targetProfileId, + }, + { + title: 'Quel(le) expert(e) !', + message: 'Tu as le palier 5', + prescriberDescription: 'Maîtrise absolue', + level: 5, + targetProfileId, + }, ]; stages.forEach((stage) => databaseBuilder.factory.buildStage.withLevel(stage)); diff --git a/api/db/seeds/data/tags-builder.js b/api/db/seeds/data/tags-builder.js index 8e311854f67..b2969034fdc 100644 --- a/api/db/seeds/data/tags-builder.js +++ b/api/db/seeds/data/tags-builder.js @@ -1,4 +1,4 @@ -module.exports = function tagsBuilder({ databaseBuilder }) { +const tagsBuilder = function ({ databaseBuilder }) { databaseBuilder.factory.buildTag({ id: 1, name: 'AGRICULTURE' }); databaseBuilder.factory.buildTag({ id: 2, name: 'PUBLIC' }); databaseBuilder.factory.buildTag({ id: 3, name: 'PRIVE' }); @@ -9,3 +9,5 @@ module.exports = function tagsBuilder({ databaseBuilder }) { databaseBuilder.factory.buildTag({ id: 8, name: 'COLLEGE' }); databaseBuilder.factory.buildTag({ id: 9, name: 'LYCEE' }); }; + +export { tagsBuilder }; diff --git a/api/db/seeds/data/target-profiles-builder.js b/api/db/seeds/data/target-profiles-builder.js index f5590fb4e93..21ae3a1a7ac 100644 --- a/api/db/seeds/data/target-profiles-builder.js +++ b/api/db/seeds/data/target-profiles-builder.js @@ -1,6 +1,7 @@ -const { PRO_COMPANY_ID, PRO_POLE_EMPLOI_ID, PRO_MED_NUM_ID } = require('./organizations-pro-builder'); -const identity = require('lodash/identity'); -const { SUP_UNIVERSITY_ID } = require('./organizations-sup-builder'); +import { PRO_COMPANY_ID, PRO_POLE_EMPLOI_ID, PRO_MED_NUM_ID } from './organizations-pro-builder.js'; +import lodash from 'lodash'; +const { identity } = lodash; +import { SUP_UNIVERSITY_ID } from './organizations-sup-builder.js'; const skillIdsForSkillSet1 = [ 'recMOy4S8XnaWblYI', @@ -247,7 +248,7 @@ function _buildTargetProfileOneCompetence(databaseBuilder) { category: 'COMPETENCES', ownerOrganizationId: PRO_COMPANY_ID, description: - 'Ce profil cible permet d\'**évaluer** sur la compétence 5.1. Le résultat est exprimé en ***pourcentage***', + "Ce profil cible permet d'**évaluer** sur la compétence 5.1. Le résultat est exprimé en ***pourcentage***", comment: 'Privé : Contient la ***compétence 5.1***.', }); @@ -886,7 +887,7 @@ function _buildTargetProfileCnav(databaseBuilder) { }); } -module.exports = { +export { targetProfilesBuilder, TARGET_PROFILE_PIC_DIAG_INITIAL_ID, TARGET_PROFILE_ONE_COMPETENCE_ID, diff --git a/api/db/seeds/data/team-certification/data-builder.js b/api/db/seeds/data/team-certification/data-builder.js index 0dee7ae8424..35bfcf421e3 100644 --- a/api/db/seeds/data/team-certification/data-builder.js +++ b/api/db/seeds/data/team-certification/data-builder.js @@ -1,10 +1,11 @@ -const tooling = require('../common/tooling'); -const { +import * as tooling from '../common/tooling/index.js'; + +import { CLEA_COMPLEMENTARY_CERTIFICATION_ID, PIX_DROIT_COMPLEMENTARY_CERTIFICATION_ID, PIX_EDU_1ER_DEGRE_COMPLEMENTARY_CERTIFICATION_ID, PIX_EDU_2ND_DEGRE_COMPLEMENTARY_CERTIFICATION_ID, -} = require('../common/common-builder'); +} from '../common/common-builder.js'; const TEAM_CERTIFICATION_OFFSET_ID = 7000; // IDS @@ -38,12 +39,9 @@ async function teamCertificationDataBuilder({ databaseBuilder }) { await _createPublishedScoSession({ databaseBuilder }); await _createSession({ databaseBuilder }); await _createPublishedSession({ databaseBuilder }); - } -module.exports = { - teamCertificationDataBuilder, -}; +export { teamCertificationDataBuilder }; function _createScoCertificationCenter({ databaseBuilder }) { databaseBuilder.factory.buildUser.withRawPassword({ diff --git a/api/db/seeds/data/team-contenu/data-builder.js b/api/db/seeds/data/team-contenu/data-builder.js index d1c43247408..f0826b38d50 100644 --- a/api/db/seeds/data/team-contenu/data-builder.js +++ b/api/db/seeds/data/team-contenu/data-builder.js @@ -1,4 +1,4 @@ -const tooling = require('../common/tooling'); +import * as tooling from '../common/tooling/index.js'; const TEAM_CONTENU_OFFSET_ID = 5000; // IDS @@ -32,9 +32,7 @@ async function teamContenuDataBuilder({ databaseBuilder }) { await _createPerfectProfileUser(databaseBuilder); } -module.exports = { - teamContenuDataBuilder, -}; +export { teamContenuDataBuilder }; function _createProOrganization(databaseBuilder) { databaseBuilder.factory.buildOrganization({ diff --git a/api/db/seeds/data/trainings-builder.js b/api/db/seeds/data/trainings-builder.js index 796ebb44b66..ca486aaed7d 100644 --- a/api/db/seeds/data/trainings-builder.js +++ b/api/db/seeds/data/trainings-builder.js @@ -1,8 +1,8 @@ -const { TARGET_PROFILE_PIX_EDU_FORMATION_INITIALE_2ND_DEGRE } = require('./target-profiles-builder'); +import { TARGET_PROFILE_PIX_EDU_FORMATION_INITIALE_2ND_DEGRE } from './target-profiles-builder.js'; function trainingBuilder({ databaseBuilder }) { const training1 = databaseBuilder.factory.buildTraining({ - title: 'Apprendre en s\'amusant', + title: "Apprendre en s'amusant", link: 'http://www.example.net', type: 'webinaire', duration: '06:00:00', @@ -32,7 +32,7 @@ function trainingBuilder({ databaseBuilder }) { locale: 'fr-fr', }); const training5 = databaseBuilder.factory.buildTraining({ - title: 'Manger bun\'s tous les midis', + title: "Manger bun's tous les midis", link: 'http://www.example5.net', type: 'webinaire', duration: '06:00:00', @@ -157,6 +157,4 @@ function trainingBuilder({ databaseBuilder }) { }); } -module.exports = { - trainingBuilder, -}; +export { trainingBuilder }; diff --git a/api/db/seeds/data/user-logins-builder.js b/api/db/seeds/data/user-logins-builder.js index 4c4701c1c6b..1006415022e 100644 --- a/api/db/seeds/data/user-logins-builder.js +++ b/api/db/seeds/data/user-logins-builder.js @@ -1,5 +1,5 @@ -const { DEFAULT_PASSWORD } = require('./users-builder'); -const { SCO_MIDDLE_SCHOOL_ID } = require('./organizations-sco-builder'); +import { DEFAULT_PASSWORD } from './users-builder.js'; +import { SCO_MIDDLE_SCHOOL_ID } from './organizations-sco-builder.js'; function userLoginsBuilder({ databaseBuilder }) { _buildBlockedUser({ databaseBuilder }); @@ -62,6 +62,4 @@ function _buildTemporaryBlockedUser({ databaseBuilder }) { }); } -module.exports = { - userLoginsBuilder, -}; +export { userLoginsBuilder }; diff --git a/api/db/seeds/data/users-builder.js b/api/db/seeds/data/users-builder.js index 8f25c373a45..b9857131250 100644 --- a/api/db/seeds/data/users-builder.js +++ b/api/db/seeds/data/users-builder.js @@ -1,4 +1,4 @@ -const OidcIdentityProviders = require('../../../lib/domain/constants/oidc-identity-providers'); +import * as OidcIdentityProviders from '../../../lib/domain/constants/oidc-identity-providers.js'; const PIX_SUPER_ADMIN_ID = 199; const PIX_SUPPORT_ID = 200; @@ -8,7 +8,6 @@ const PIX_ALL_ORGA_ID = 203; const DEFAULT_PASSWORD = 'pix123'; function usersBuilder({ databaseBuilder }) { - const now = new Date('2022-06-10'); databaseBuilder.factory.buildUser.withRawPassword({ id: 1, @@ -230,7 +229,7 @@ function usersBuilder({ databaseBuilder }) { }); } -module.exports = { +export { usersBuilder, PIX_SUPER_ADMIN_ID, PIX_SUPPORT_ID, diff --git a/api/db/seeds/seed.js b/api/db/seeds/seed.js index 8477ef0d8dd..af35e68366c 100644 --- a/api/db/seeds/seed.js +++ b/api/db/seeds/seed.js @@ -1,58 +1,48 @@ -'use strict'; -const DatabaseBuilder = require('../database-builder/database-builder'); - -const featuresBuilder = require('./data/feature/feature-builder'); - -const answersBuilder = require('./data/answers-builder'); -const assessmentsBuilder = require('./data/assessments-builder'); -const buildPixAileProfile = require('./data/pix-aile-profile-builder'); -const { campaignsProBuilder } = require('./data/campaigns-pro-builder'); -const { campaignsSupBuilder } = require('./data/campaigns-sup-builder'); -const { campaignsScoBuilder } = require('./data/campaigns-sco-builder'); -const { certificationCandidatesBuilder } = require('./data/certification/certification-candidates-builder'); -const { badgeAcquisitionBuilder } = require('./data/certification/badge-acquisition-builder'); -const { - complementaryCertificationCourseResultsBuilder, -} = require('./data/certification/complementary-certification-course-results-builder'); -const { certificationCentersBuilder } = require('./data/certification/certification-centers-builder'); -const { - certificationCenterInvitationsBuilder, -} = require('./data/certification/certification-center-invitations-builder'); -const { certificationCoursesBuilder } = require('./data/certification/certification-courses-builder'); -const certificationScoresBuilder = require('./data/certification/certification-scores-builder'); -const { certificationSessionsBuilder } = require('./data/certification/certification-sessions-builder'); -const { certificationUsersBuilder } = require('./data/certification/users'); -const { certificationUserProfilesBuilder } = require('./data/certification/user-profiles-builder'); -const certificationCenterMembershipsBuilder = require('./data/certification/certification-center-memberships-builder'); -const { organizationsProBuilder } = require('./data/organizations-pro-builder'); -const { organizationsScoBuilder } = require('./data/organizations-sco-builder'); -const { organizationsSupBuilder } = require('./data/organizations-sup-builder'); -const { organizationPlacesProBuilder } = require('./data/organization-places-pro-builder'); -const tagsBuilder = require('./data/tags-builder'); -const { badgesBuilder } = require('./data/badges-builder'); -const { targetProfilesBuilder } = require('./data/target-profiles-builder'); -const { usersBuilder } = require('./data/users-builder'); -const { userLoginsBuilder } = require('./data/user-logins-builder'); -const pixAdminRolesBuilder = require('./data/pix-admin-roles-builder'); -const stagesBuilder = require('./data/stages-builder'); -const { issueReportCategoriesBuilder } = require('./data/certification/issue-report-categories-builder'); -const { +import { DatabaseBuilder } from '../database-builder/database-builder.js'; +import { featuresBuilder } from './data/feature/feature-builder.js'; +import { answersBuilder } from './data/answers-builder.js'; +import { assessmentsBuilder } from './data/assessments-builder.js'; +import { buildPixAileProfilev2 as buildPixAileProfile } from './data/pix-aile-profile-builder.js'; +import { campaignsProBuilder } from './data/campaigns-pro-builder.js'; +import { campaignsSupBuilder } from './data/campaigns-sup-builder.js'; +import { campaignsScoBuilder } from './data/campaigns-sco-builder.js'; +import { certificationCandidatesBuilder } from './data/certification/certification-candidates-builder.js'; +import { badgeAcquisitionBuilder } from './data/certification/badge-acquisition-builder.js'; +import { complementaryCertificationCourseResultsBuilder } from './data/certification/complementary-certification-course-results-builder.js'; +import { certificationCentersBuilder } from './data/certification/certification-centers-builder.js'; +import { certificationCenterInvitationsBuilder } from './data/certification/certification-center-invitations-builder.js'; +import { certificationCoursesBuilder } from './data/certification/certification-courses-builder.js'; +import { certificationScoresBuilder } from './data/certification/certification-scores-builder.js'; +import { certificationSessionsBuilder } from './data/certification/certification-sessions-builder.js'; +import { certificationUsersBuilder } from './data/certification/users.js'; +import { certificationUserProfilesBuilder } from './data/certification/user-profiles-builder.js'; +import { certificationCenterMembershipsBuilder } from './data/certification/certification-center-memberships-builder.js'; +import { organizationsProBuilder } from './data/organizations-pro-builder.js'; +import { organizationsScoBuilder } from './data/organizations-sco-builder.js'; +import { organizationsSupBuilder } from './data/organizations-sup-builder.js'; +import { organizationPlacesProBuilder } from './data/organization-places-pro-builder.js'; +import { tagsBuilder } from './data/tags-builder.js'; +import { badgesBuilder } from './data/badges-builder.js'; +import { targetProfilesBuilder } from './data/target-profiles-builder.js'; +import { usersBuilder } from './data/users-builder.js'; +import { userLoginsBuilder } from './data/user-logins-builder.js'; +import { pixAdminRolesBuilder } from './data/pix-admin-roles-builder.js'; +import { stagesBuilder } from './data/stages-builder.js'; +import { issueReportCategoriesBuilder } from './data/certification/issue-report-categories-builder.js'; +import { getEligibleCampaignParticipations, generateKnowledgeElementSnapshots, -} = require('../../scripts/prod/generate-knowledge-element-snapshots-for-campaigns'); -const computeParticipationsResults = require('../../scripts/prod/compute-participation-results'); +} from '../../scripts/prod/generate-knowledge-element-snapshots-for-campaigns.js'; +import { computeParticipantResultsShared as computeParticipationsResults } from '../../scripts/prod/compute-participation-results.js'; +import { poleEmploiSendingsBuilder } from './data/pole-emploi-sendings-builder.js'; +import { trainingBuilder } from './data/trainings-builder.js'; +import { fillCampaignSkills } from './data/fill-campaign-skills.js'; +import { addLastAssessmentResultCertificationCourse } from '../../scripts/certification/fill-last-assessment-result-certification-course-table.js'; +import { commonBuilder } from './data/common/common-builder.js'; +import { teamContenuDataBuilder } from './data/team-contenu/data-builder.js'; +import { teamCertificationDataBuilder } from './data/team-certification/data-builder.js'; -const poleEmploiSendingsBuilder = require('./data/pole-emploi-sendings-builder'); -const { trainingBuilder } = require('./data/trainings-builder'); -const { fillCampaignSkills } = require('./data/fill-campaign-skills'); -const { - addLastAssessmentResultCertificationCourse, -} = require('../../scripts/certification/fill-last-assessment-result-certification-course-table'); -const { commonBuilder } = require('./data/common/common-builder'); -const { teamContenuDataBuilder } = require('./data/team-contenu/data-builder'); -const { teamCertificationDataBuilder } = require('./data/team-certification/data-builder'); - -exports.seed = async (knex) => { +const seed = async function (knex) { const shouldUseNewSeeds = process.env.USE_NEW_SEEDS === 'true'; const databaseBuilder = new DatabaseBuilder({ knex }); if (shouldUseNewSeeds) { @@ -123,3 +113,5 @@ exports.seed = async (knex) => { await computeParticipationsResults(10, false); } }; + +export { seed }; diff --git a/api/db/seeds/src/dragonAndCoBase64.js b/api/db/seeds/src/dragonAndCoBase64.js index bcdf9ea3a64..ebb95f87bb6 100644 --- a/api/db/seeds/src/dragonAndCoBase64.js +++ b/api/db/seeds/src/dragonAndCoBase64.js @@ -1 +1,4 @@ -module.exports = ''; +const logoUrl = + ''; + +export { logoUrl }; diff --git a/api/index.js b/api/index.js index 575eae21e0d..0193306fa61 100644 --- a/api/index.js +++ b/api/index.js @@ -1,15 +1,14 @@ -const dotenv = require('dotenv'); +import * as dotenv from 'dotenv'; dotenv.config(); -const validateEnvironmentVariables = require('./lib/infrastructure/validate-environment-variables'); +import { validateEnvironmentVariables } from './lib/infrastructure/validate-environment-variables.js'; validateEnvironmentVariables(); -const createServer = require('./server'); -const logger = require('./lib/infrastructure/logger'); -const { disconnect } = require('./db/knex-database-connection'); -const { learningContentCache } = require('./lib/infrastructure/caches/learning-content-cache'); - -const { temporaryStorage } = require('./lib/infrastructure/temporary-storage/index'); -const { redisMonitor } = require('./lib/infrastructure/utils/redis-monitor'); +import { createServer } from './server.js'; +import { logger } from './lib/infrastructure/logger.js'; +import { disconnect } from './db/knex-database-connection.js'; +import { learningContentCache } from './lib/infrastructure/caches/learning-content-cache.js'; +import { temporaryStorage } from './lib/infrastructure/temporary-storage/index.js'; +import { redisMonitor } from './lib/infrastructure/utils/redis-monitor.js'; let server; @@ -48,7 +47,8 @@ process.on('SIGINT', () => { try { await start(); if (process.env.START_JOB_IN_WEB_PROCESS) { - require('./worker.js'); + // eslint-disable-next-line node/no-unsupported-features/es-syntax + import('./worker.js'); } } catch (error) { logger.error(error); diff --git a/api/lib/.eslintrc.js b/api/lib/.eslintrc.cjs similarity index 69% rename from api/lib/.eslintrc.js rename to api/lib/.eslintrc.cjs index e503f189305..407708eb90e 100644 --- a/api/lib/.eslintrc.js +++ b/api/lib/.eslintrc.cjs @@ -1,5 +1,7 @@ +// eslint-disable-next-line eslint-comments/disable-enable-pair +/* eslint-disable no-undef */ module.exports = { - extends: ['../.eslintrc.yaml', 'plugin:node/recommended-script'], + extends: ['../.eslintrc.yaml'], rules: { 'no-restricted-modules': [ 'error', diff --git a/api/lib/application/.eslintrc.js b/api/lib/application/.eslintrc.cjs similarity index 71% rename from api/lib/application/.eslintrc.js rename to api/lib/application/.eslintrc.cjs index c4a46816b9c..fe3e9fe3fe6 100644 --- a/api/lib/application/.eslintrc.js +++ b/api/lib/application/.eslintrc.cjs @@ -1,5 +1,7 @@ +// eslint-disable-next-line eslint-comments/disable-enable-pair +/* eslint-disable no-undef */ module.exports = { - extends: '../.eslintrc.js', + extends: '../.eslintrc.cjs', rules: { 'no-restricted-syntax': [ 'error', diff --git a/api/lib/application/account-recovery/account-recovery-controller.js b/api/lib/application/account-recovery/account-recovery-controller.js index 363b3f89bcc..8b97ae4c6f2 100644 --- a/api/lib/application/account-recovery/account-recovery-controller.js +++ b/api/lib/application/account-recovery/account-recovery-controller.js @@ -1,34 +1,50 @@ -const usecases = require('../../domain/usecases/index.js'); -const studentInformationForAccountRecoverySerializer = require('../../infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); - -module.exports = { - async sendEmailForAccountRecovery(request, h) { - const studentInformation = await studentInformationForAccountRecoverySerializer.deserialize(request.payload); - - await usecases.sendEmailForAccountRecovery({ studentInformation }); - - return h.response().code(204); - }, - - async checkAccountRecoveryDemand(request, h, dependencies = { studentInformationForAccountRecoverySerializer }) { - const temporaryKey = request.params.temporaryKey; - const studentInformation = await usecases.getAccountRecoveryDetails({ temporaryKey }); - return dependencies.studentInformationForAccountRecoverySerializer.serializeAccountRecovery(studentInformation); - }, - - async updateUserAccountFromRecoveryDemand(request, h) { - const temporaryKey = request.payload.data.attributes['temporary-key']; - const password = request.payload.data.attributes.password; - - await DomainTransaction.execute(async (domainTransaction) => { - await usecases.updateUserForAccountRecovery({ - password, - temporaryKey, - domainTransaction, - }); +import { usecases } from '../../domain/usecases/index.js'; +import * as studentInformationForAccountRecoverySerializer from '../../infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; + +const sendEmailForAccountRecovery = async function ( + request, + h, + dependencies = { studentInformationForAccountRecoverySerializer } +) { + const studentInformation = await dependencies.studentInformationForAccountRecoverySerializer.deserialize( + request.payload + ); + + await usecases.sendEmailForAccountRecovery({ studentInformation }); + + return h.response().code(204); +}; + +const checkAccountRecoveryDemand = async function ( + request, + h, + dependencies = { studentInformationForAccountRecoverySerializer } +) { + const temporaryKey = request.params.temporaryKey; + const studentInformation = await usecases.getAccountRecoveryDetails({ temporaryKey }); + return dependencies.studentInformationForAccountRecoverySerializer.serializeAccountRecovery(studentInformation); +}; + +const updateUserAccountFromRecoveryDemand = async function (request, h) { + const temporaryKey = request.payload.data.attributes['temporary-key']; + const password = request.payload.data.attributes.password; + + await DomainTransaction.execute(async (domainTransaction) => { + await usecases.updateUserForAccountRecovery({ + password, + temporaryKey, + domainTransaction, }); + }); - return h.response().code(204); - }, + return h.response().code(204); }; + +const accountRecoveryController = { + sendEmailForAccountRecovery, + checkAccountRecoveryDemand, + updateUserAccountFromRecoveryDemand, +}; + +export { accountRecoveryController }; diff --git a/api/lib/application/account-recovery/index.js b/api/lib/application/account-recovery/index.js index 3ca75ee40d4..3d2ae21f25b 100644 --- a/api/lib/application/account-recovery/index.js +++ b/api/lib/application/account-recovery/index.js @@ -1,15 +1,17 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const XRegExp = require('xregexp'); +import XRegExp from 'xregexp'; const inePattern = new RegExp('^[0-9]{9}[a-zA-Z]{2}$'); const inaPattern = new RegExp('^[0-9]{10}[a-zA-Z]{1}$'); -const accountRecoveryController = require('./account-recovery-controller.js'); +import { accountRecoveryController } from './account-recovery-controller.js'; -const { passwordValidationPattern } = require('../../config.js').account; +import { config } from '../../config.js'; -exports.register = async function (server) { +const { passwordValidationPattern } = config.account; + +const register = async function (server) { server.route([ { method: 'POST', @@ -84,4 +86,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'account-recovery-api'; +const name = 'account-recovery-api'; +export { register, name }; diff --git a/api/lib/application/admin-members/admin-member-controller.js b/api/lib/application/admin-members/admin-member-controller.js index 4b14c4b1739..fa6395bd94b 100644 --- a/api/lib/application/admin-members/admin-member-controller.js +++ b/api/lib/application/admin-members/admin-member-controller.js @@ -1,34 +1,41 @@ -const adminMemberSerializer = require('../../infrastructure/serializers/jsonapi/admin-member-serializer.js'); -const usecases = require('../../domain/usecases/index.js'); +import * as adminMemberSerializer from '../../infrastructure/serializers/jsonapi/admin-member-serializer.js'; +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async findAll() { - const adminMembers = await usecases.getAdminMembers(); - return adminMemberSerializer.serialize(adminMembers); - }, +const findAll = async function (request, h, dependencies = { adminMemberSerializer }) { + const adminMembers = await usecases.getAdminMembers(); + return dependencies.adminMemberSerializer.serialize(adminMembers); +}; + +const getCurrentAdminMember = async function (request, h, dependencies = { adminMemberSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + const userDetailsForAdmin = await usecases.getAdminMemberDetails({ userId: authenticatedUserId }); + return dependencies.adminMemberSerializer.serialize(userDetailsForAdmin); +}; - async getCurrentAdminMember(request) { - const authenticatedUserId = request.auth.credentials.userId; - const userDetailsForAdmin = await usecases.getAdminMemberDetails({ userId: authenticatedUserId }); - return adminMemberSerializer.serialize(userDetailsForAdmin); - }, +const updateAdminMember = async function (request, h, dependencies = { adminMemberSerializer }) { + const id = request.params.id; + const { role } = await adminMemberSerializer.deserialize(request.payload); + const updatedAdminMember = await usecases.updateAdminMember({ id, role }); + return dependencies.adminMemberSerializer.serialize(updatedAdminMember); +}; - async updateAdminMember(request) { - const id = request.params.id; - const { role } = await adminMemberSerializer.deserialize(request.payload); - const updatedAdminMember = await usecases.updateAdminMember({ id, role }); - return adminMemberSerializer.serialize(updatedAdminMember); - }, +const deactivateAdminMember = async function (request, h) { + const id = request.params.id; + await usecases.deactivateAdminMember({ id }); + return h.response().code(204); +}; - async deactivateAdminMember(request, h) { - const id = request.params.id; - await usecases.deactivateAdminMember({ id }); - return h.response().code(204); - }, +const saveAdminMember = async function (request, h, dependencies = { adminMemberSerializer }) { + const attributes = await adminMemberSerializer.deserialize(request.payload); + const savedAdminMember = await usecases.saveAdminMember(attributes); + return h.response(dependencies.adminMemberSerializer.serialize(savedAdminMember)).created(); +}; - async saveAdminMember(request, h) { - const attributes = await adminMemberSerializer.deserialize(request.payload); - const savedAdminMember = await usecases.saveAdminMember(attributes); - return h.response(adminMemberSerializer.serialize(savedAdminMember)).created(); - }, +const adminMemberController = { + findAll, + getCurrentAdminMember, + updateAdminMember, + deactivateAdminMember, + saveAdminMember, }; +export { adminMemberController }; diff --git a/api/lib/application/admin-members/index.js b/api/lib/application/admin-members/index.js index 1ebe6a35a19..40d607db89f 100644 --- a/api/lib/application/admin-members/index.js +++ b/api/lib/application/admin-members/index.js @@ -1,9 +1,9 @@ -const adminMemberController = require('./admin-member-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const Joi = require('joi'); +import { adminMemberController } from './admin-member-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import Joi from 'joi'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -123,4 +123,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'admin-members-api'; +const name = 'admin-members-api'; +export { register, name }; diff --git a/api/lib/application/answers/answer-controller.js b/api/lib/application/answers/answer-controller.js index d88d0541767..775ce90988e 100644 --- a/api/lib/application/answers/answer-controller.js +++ b/api/lib/application/answers/answer-controller.js @@ -1,69 +1,71 @@ -const answerSerializer = require('../../infrastructure/serializers/jsonapi/answer-serializer.js'); -const answerPix1dSerializer = require('../../infrastructure/serializers/jsonapi/answer-pix1d-serializer.js'); -const correctionSerializer = require('../../infrastructure/serializers/jsonapi/correction-serializer.js'); -const usecases = require('../../domain/usecases/index.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); +import * as answerSerializer from '../../infrastructure/serializers/jsonapi/answer-serializer.js'; +import * as answerPix1dSerializer from '../../infrastructure/serializers/jsonapi/answer-pix1d-serializer.js'; +import * as correctionSerializer from '../../infrastructure/serializers/jsonapi/correction-serializer.js'; +import { usecases } from '../../domain/usecases/index.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; -module.exports = { - async save(request, h, dependencies = { answerSerializer, requestResponseUtils }) { - const answer = dependencies.answerSerializer.deserialize(request.payload); - const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - const createdAnswer = await usecases.correctAnswerThenUpdateAssessment({ answer, userId, locale }); +const save = async function (request, h, dependencies = { answerSerializer, requestResponseUtils }) { + const answer = dependencies.answerSerializer.deserialize(request.payload); + const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const createdAnswer = await usecases.correctAnswerThenUpdateAssessment({ answer, userId, locale }); - return h.response(dependencies.answerSerializer.serialize(createdAnswer)).created(); - }, + return h.response(dependencies.answerSerializer.serialize(createdAnswer)).created(); +}; - async saveForPix1D(request, h, dependencies = { answerPix1dSerializer }) { - const answer = dependencies.answerPix1dSerializer.deserialize(request.payload); - const challengeId = answer.challengeId; - const createdAnswer = await usecases.correctAnswer({ answer, challengeId }); +const saveForPix1D = async function (request, h, dependencies = { answerPix1dSerializer }) { + const answer = dependencies.answerPix1dSerializer.deserialize(request.payload); + const challengeId = answer.challengeId; + const createdAnswer = await usecases.correctAnswer({ answer, challengeId }); - return h.response(answerPix1dSerializer.serialize(createdAnswer)).created(); - }, + return h.response(answerPix1dSerializer.serialize(createdAnswer)).created(); +}; - async get(request, _h, dependencies = { requestResponseUtils }) { - const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const answerId = request.params.id; - const answer = await usecases.getAnswer({ answerId, userId }); +const get = async function (request, _h, dependencies = { requestResponseUtils }) { + const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const answerId = request.params.id; + const answer = await usecases.getAnswer({ answerId, userId }); - return answerSerializer.serialize(answer); - }, + return answerSerializer.serialize(answer); +}; - async update(request, _h, dependencies = { requestResponseUtils }) { - const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const answerId = request.params.id; - const answer = await usecases.getAnswer({ answerId, userId }); +const update = async function (request, _h, dependencies = { requestResponseUtils }) { + const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const answerId = request.params.id; + const answer = await usecases.getAnswer({ answerId, userId }); - return answerSerializer.serialize(answer); - }, + return answerSerializer.serialize(answer); +}; - async find(request, _h, dependencies = { requestResponseUtils }) { - const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const challengeId = request.query.challengeId; - const assessmentId = request.query.assessmentId; - let answers = []; - if (challengeId && assessmentId) { - answers = await usecases.findAnswerByChallengeAndAssessment({ challengeId, assessmentId, userId }); - } - if (assessmentId && !challengeId) { - answers = await usecases.findAnswerByAssessment({ assessmentId, userId }); - } +const find = async function (request, _h, dependencies = { requestResponseUtils }) { + const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const challengeId = request.query.challengeId; + const assessmentId = request.query.assessmentId; + let answers = []; + if (challengeId && assessmentId) { + answers = await usecases.findAnswerByChallengeAndAssessment({ challengeId, assessmentId, userId }); + } + if (assessmentId && !challengeId) { + answers = await usecases.findAnswerByAssessment({ assessmentId, userId }); + } - return answerSerializer.serialize(answers); - }, + return answerSerializer.serialize(answers); +}; - async getCorrection(request, _h, dependencies = { correctionSerializer, requestResponseUtils }) { - const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - const answerId = request.params.id; +const getCorrection = async function (request, _h, dependencies = { correctionSerializer, requestResponseUtils }) { + const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const answerId = request.params.id; - const correction = await usecases.getCorrectionForAnswer({ - answerId, - userId, - locale, - }); + const correction = await usecases.getCorrectionForAnswer({ + answerId, + userId, + locale, + }); - return dependencies.correctionSerializer.serialize(correction); - }, + return dependencies.correctionSerializer.serialize(correction); }; + +const answerController = { save, saveForPix1D, get, update, find, getCorrection }; + +export { answerController }; diff --git a/api/lib/application/answers/index.js b/api/lib/application/answers/index.js index ff590d56a70..92c77803654 100644 --- a/api/lib/application/answers/index.js +++ b/api/lib/application/answers/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); -const answerController = require('./answer-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import Joi from 'joi'; +import { answerController } from './answer-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { NotFoundError } from '../../domain/errors.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'POST', @@ -135,4 +135,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'answers-api'; +const name = 'answers-api'; +export { register, name }; diff --git a/api/lib/application/assessment-results/assessment-result-controller.js b/api/lib/application/assessment-results/assessment-result-controller.js index 061c94d862f..d8c1205497e 100644 --- a/api/lib/application/assessment-results/assessment-result-controller.js +++ b/api/lib/application/assessment-results/assessment-result-controller.js @@ -1,6 +1,6 @@ -const AssessmentResult = require('../../domain/models/AssessmentResult.js'); -const CompetenceMark = require('../../domain/models/CompetenceMark.js'); -const assessmentResultService = require('../../domain/services/assessment-result-service.js'); +import { AssessmentResult } from '../../domain/models/AssessmentResult.js'; +import { CompetenceMark } from '../../domain/models/CompetenceMark.js'; +import * as assessmentResultService from '../../domain/services/assessment-result-service.js'; // TODO: Should be removed and replaced by a real serializer function _deserializeResultsAdd(json) { @@ -26,13 +26,15 @@ function _deserializeResultsAdd(json) { return { assessmentResult, competenceMarks }; } -module.exports = { - async save(request, h, dependencies = { assessmentResultService }) { - const jsonResult = request.payload.data.attributes; - const { assessmentResult, competenceMarks } = _deserializeResultsAdd(jsonResult); - const juryId = request.auth.credentials.userId; - // FIXME (re)calculate partner certifications which may be invalidated/validated - await dependencies.assessmentResultService.save({ ...assessmentResult, juryId }, competenceMarks); - return null; - }, +const save = async function (request, h, dependencies = { assessmentResultService }) { + const jsonResult = request.payload.data.attributes; + const { assessmentResult, competenceMarks } = _deserializeResultsAdd(jsonResult); + const juryId = request.auth.credentials.userId; + // FIXME (re)calculate partner certifications which may be invalidated/validated + await dependencies.assessmentResultService.save({ ...assessmentResult, juryId }, competenceMarks); + return null; }; + +const assessmentResultController = { save }; + +export { assessmentResultController }; diff --git a/api/lib/application/assessment-results/index.js b/api/lib/application/assessment-results/index.js index 67a81da1fd9..fb63da7069c 100644 --- a/api/lib/application/assessment-results/index.js +++ b/api/lib/application/assessment-results/index.js @@ -1,7 +1,7 @@ -const AssessmentResultController = require('./assessment-result-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import { assessmentResultController } from './assessment-result-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'POST', @@ -18,11 +18,12 @@ exports.register = async (server) => { assign: 'hasAuthorizationToAccessAdminScope', }, ], - handler: AssessmentResultController.save, + handler: assessmentResultController.save, tags: ['api'], }, }, ]); }; -exports.name = 'assessments-results-api'; +const name = 'assessments-results-api'; +export { register, name }; diff --git a/api/lib/application/assessments/assessment-controller.js b/api/lib/application/assessments/assessment-controller.js index 2842fe985a5..c5428e5fd19 100644 --- a/api/lib/application/assessments/assessment-controller.js +++ b/api/lib/application/assessments/assessment-controller.js @@ -1,154 +1,165 @@ -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); - -const JSONAPISerializer = require('jsonapi-serializer').Serializer; -const { AssessmentEndedError } = require('../../domain/errors.js'); -const usecases = require('../../domain/usecases/index.js'); -const events = require('../../domain/events/index.js'); -const logger = require('../../infrastructure/logger.js'); -const assessmentRepository = require('../../infrastructure/repositories/assessment-repository.js'); -const assessmentSerializer = require('../../infrastructure/serializers/jsonapi/assessment-serializer.js'); -const challengeSerializer = require('../../infrastructure/serializers/jsonapi/challenge-serializer.js'); -const competenceEvaluationSerializer = require('../../infrastructure/serializers/jsonapi/competence-evaluation-serializer.js'); -const { +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import { Serializer as JSONAPISerializer } from 'jsonapi-serializer'; +import { AssessmentEndedError } from '../../domain/errors.js'; +import { usecases } from '../../domain/usecases/index.js'; +import * as events from '../../domain/events/index.js'; +import { logger } from '../../infrastructure/logger.js'; +import * as assessmentRepository from '../../infrastructure/repositories/assessment-repository.js'; +import * as assessmentSerializer from '../../infrastructure/serializers/jsonapi/assessment-serializer.js'; +import * as challengeSerializer from '../../infrastructure/serializers/jsonapi/challenge-serializer.js'; +import * as competenceEvaluationSerializer from '../../infrastructure/serializers/jsonapi/competence-evaluation-serializer.js'; +import { extractLocaleFromRequest, extractUserIdFromRequest, -} = require('../../infrastructure/utils/request-response-utils.js'); -const certificationChallengeRepository = require('../../infrastructure/repositories/certification-challenge-repository.js'); +} from '../../infrastructure/utils/request-response-utils.js'; +import * as certificationChallengeRepository from '../../infrastructure/repositories/certification-challenge-repository.js'; + +import { Examiner } from '../../domain/models/Examiner.js'; +import { ValidatorAlwaysOK } from '../../domain/models/ValidatorAlwaysOK.js'; + +const save = async function (request, h, dependencies = { assessmentRepository }) { + const assessment = assessmentSerializer.deserialize(request.payload); + assessment.userId = extractUserIdFromRequest(request); + assessment.state = 'started'; + const createdAssessment = await dependencies.assessmentRepository.save({ assessment }); + return h.response(assessmentSerializer.serialize(createdAssessment)).created(); +}; -const Examiner = require('../../domain/models/Examiner.js'); -const ValidatorAlwaysOK = require('../../domain/models/ValidatorAlwaysOK.js'); +const get = async function (request, _, dependencies = { assessmentSerializer }) { + const assessmentId = request.params.id; + const locale = extractLocaleFromRequest(request); -module.exports = { - async save(request, h, dependencies = { assessmentRepository }) { - const assessment = assessmentSerializer.deserialize(request.payload); - assessment.userId = extractUserIdFromRequest(request); - assessment.state = 'started'; - const createdAssessment = await dependencies.assessmentRepository.save({ assessment }); - return h.response(assessmentSerializer.serialize(createdAssessment)).created(); - }, + const assessment = await usecases.getAssessment({ assessmentId, locale }); - async get(request, _, dependencies = { assessmentSerializer }) { - const assessmentId = request.params.id; - const locale = extractLocaleFromRequest(request); + return dependencies.assessmentSerializer.serialize(assessment); +}; - const assessment = await usecases.getAssessment({ assessmentId, locale }); +const getLastChallengeId = async function (request, h) { + const assessmentId = request.params.id; - return dependencies.assessmentSerializer.serialize(assessment); - }, + const lastChallengeId = await usecases.getLastChallengeIdFromAssessmentId({ assessmentId }); - async getLastChallengeId(request, h) { - const assessmentId = request.params.id; + return h.response(lastChallengeId).code(200); +}; - const lastChallengeId = await usecases.getLastChallengeIdFromAssessmentId({ assessmentId }); +const getChallengeForPixAutoAnswer = async function (request, h) { + const assessmentId = request.params.id; - return h.response(lastChallengeId).code(200); - }, + const challenge = await usecases.getChallengeForPixAutoAnswer({ assessmentId }); - async getChallengeForPixAutoAnswer(request, h) { - const assessmentId = request.params.id; + return h.response(challenge).code(200); +}; - const challenge = await usecases.getChallengeForPixAutoAnswer({ assessmentId }); +const getNextChallenge = async function ( + request, + h, + dependencies = { + usecases, + assessmentRepository, + certificationChallengeRepository, + } +) { + const assessmentId = request.params.id; + + const logContext = { + zone: 'assessmentController.getNextChallenge', + type: 'controller', + assessmentId, + }; + logger.trace(logContext, 'tracing assessmentController.getNextChallenge()'); + + try { + const assessment = await dependencies.assessmentRepository.get(assessmentId); + logContext.assessmentType = assessment.type; + logger.trace(logContext, 'assessment loaded'); + + const challenge = await _getChallenge(assessment, request, dependencies); + logContext.challenge = challenge; + logger.trace(logContext, 'replying with challenge'); + + return challengeSerializer.serialize(challenge); + } catch (error) { + if (error instanceof AssessmentEndedError) { + const object = new JSONAPISerializer('', {}); + return object.serialize(null); + } + throw error; + } +}; - return h.response(challenge).code(200); - }, +const completeAssessment = async function (request) { + const assessmentId = request.params.id; + const locale = extractLocaleFromRequest(request); - async getNextChallenge( - request, - h, - dependencies = { - usecases, - assessmentRepository, - certificationChallengeRepository, - } - ) { - const assessmentId = request.params.id; - - const logContext = { - zone: 'assessmentController.getNextChallenge', - type: 'controller', - assessmentId, - }; - logger.trace(logContext, 'tracing assessmentController.getNextChallenge()'); - - try { - const assessment = await dependencies.assessmentRepository.get(assessmentId); - logContext.assessmentType = assessment.type; - logger.trace(logContext, 'assessment loaded'); - - const challenge = await _getChallenge(assessment, request, dependencies); - logContext.challenge = challenge; - logger.trace(logContext, 'replying with challenge'); - - return challengeSerializer.serialize(challenge); - } catch (error) { - if (error instanceof AssessmentEndedError) { - const object = new JSONAPISerializer('', {}); - return object.serialize(null); - } - throw error; - } - }, - - async completeAssessment(request) { - const assessmentId = request.params.id; - const locale = extractLocaleFromRequest(request); - - let event; - await DomainTransaction.execute(async (domainTransaction) => { - const result = await usecases.completeAssessment({ assessmentId, domainTransaction }); - await usecases.handleBadgeAcquisition({ assessment: result.assessment, domainTransaction }); - await usecases.handleTrainingRecommendation({ assessment: result.assessment, locale, domainTransaction }); - event = result.event; - }); - - await events.eventDispatcher.dispatch(event); - - return null; - }, - - async updateLastChallengeState(request) { - const assessmentId = request.params.id; - const lastQuestionState = request.params.state; - const challengeId = request.payload?.data?.attributes?.['challenge-id']; - - await DomainTransaction.execute(async (domainTransaction) => { - await usecases.updateLastQuestionState({ assessmentId, challengeId, lastQuestionState, domainTransaction }); - }); - - return null; - }, - - async findCompetenceEvaluations(request) { - const userId = request.auth.credentials.userId; - const assessmentId = request.params.id; - - const competenceEvaluations = await usecases.findCompetenceEvaluationsByAssessment({ userId, assessmentId }); - - return competenceEvaluationSerializer.serialize(competenceEvaluations); - }, - - async autoValidateNextChallenge(request, h) { - const assessmentId = request.params.id; - const locale = extractLocaleFromRequest(request); - const assessment = await usecases.getAssessment({ assessmentId, locale }); - const userId = assessment.userId; - const fakeAnswer = { - assessmentId, - challengeId: assessment.lastChallengeId, - value: 'FAKE_ANSWER_WITH_AUTO_VALIDATE_NEXT_CHALLENGE', - }; - const validatorAlwaysOK = new ValidatorAlwaysOK(); - const alwaysTrueExaminer = new Examiner({ validator: validatorAlwaysOK }); - await usecases.correctAnswerThenUpdateAssessment({ - answer: fakeAnswer, - userId, - locale, - examiner: alwaysTrueExaminer, - }); - return h.response().code(204); - }, + let event; + await DomainTransaction.execute(async (domainTransaction) => { + const result = await usecases.completeAssessment({ assessmentId, domainTransaction }); + await usecases.handleBadgeAcquisition({ assessment: result.assessment, domainTransaction }); + await usecases.handleTrainingRecommendation({ assessment: result.assessment, locale, domainTransaction }); + event = result.event; + }); + + await events.eventDispatcher.dispatch(event); + + return null; }; +const updateLastChallengeState = async function (request) { + const assessmentId = request.params.id; + const lastQuestionState = request.params.state; + const challengeId = request.payload?.data?.attributes?.['challenge-id']; + + await DomainTransaction.execute(async (domainTransaction) => { + await usecases.updateLastQuestionState({ assessmentId, challengeId, lastQuestionState, domainTransaction }); + }); + + return null; +}; + +const findCompetenceEvaluations = async function (request) { + const userId = request.auth.credentials.userId; + const assessmentId = request.params.id; + + const competenceEvaluations = await usecases.findCompetenceEvaluationsByAssessment({ userId, assessmentId }); + + return competenceEvaluationSerializer.serialize(competenceEvaluations); +}; + +const autoValidateNextChallenge = async function (request, h) { + const assessmentId = request.params.id; + const locale = extractLocaleFromRequest(request); + const assessment = await usecases.getAssessment({ assessmentId, locale }); + const userId = assessment.userId; + const fakeAnswer = { + assessmentId, + challengeId: assessment.lastChallengeId, + value: 'FAKE_ANSWER_WITH_AUTO_VALIDATE_NEXT_CHALLENGE', + }; + const validatorAlwaysOK = new ValidatorAlwaysOK(); + const alwaysTrueExaminer = new Examiner({ validator: validatorAlwaysOK }); + await usecases.correctAnswerThenUpdateAssessment({ + answer: fakeAnswer, + userId, + locale, + examiner: alwaysTrueExaminer, + }); + return h.response().code(204); +}; + +const assessmentController = { + save, + get, + getLastChallengeId, + getChallengeForPixAutoAnswer, + getNextChallenge, + completeAssessment, + updateLastChallengeState, + findCompetenceEvaluations, + autoValidateNextChallenge, +}; + +export { assessmentController }; + async function _getChallenge(assessment, request, dependencies) { if (assessment.isStarted()) { await dependencies.assessmentRepository.updateLastQuestionDate({ id: assessment.id, lastQuestionDate: new Date() }); diff --git a/api/lib/application/assessments/index.js b/api/lib/application/assessments/index.js index 72564c38948..44bdd658f93 100644 --- a/api/lib/application/assessments/index.js +++ b/api/lib/application/assessments/index.js @@ -1,11 +1,13 @@ -const Joi = require('joi'); -const { featureToggles } = require('../../config.js'); -const assessmentController = require('./assessment-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const assessmentAuthorization = require('../preHandlers/assessment-authorization.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import Joi from 'joi'; +import { config } from '../../config.js'; +import { assessmentController } from './assessment-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { assessmentAuthorization } from '../preHandlers/assessment-authorization.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async (server) => { +const { featureToggles } = config; + +const register = async function (server) { const routes = [ { method: 'POST', @@ -206,4 +208,5 @@ exports.register = async (server) => { server.route(routes); }; -exports.name = 'assessments-api'; +const name = 'assessments-api'; +export { register, name }; diff --git a/api/lib/application/authentication/authentication-controller.js b/api/lib/application/authentication/authentication-controller.js index 17aea1aefb3..755a29f9eac 100644 --- a/api/lib/application/authentication/authentication-controller.js +++ b/api/lib/application/authentication/authentication-controller.js @@ -1,112 +1,117 @@ -const { BadRequestError } = require('../http-errors.js'); -const tokenService = require('../../domain/services/token-service.js'); -const usecases = require('../../domain/usecases/index.js'); - -module.exports = { - /** - * @see https://tools.ietf.org/html/rfc6749#section-4.3 - */ - async createToken(request, h, dependencies = { tokenService }) { - let accessToken, refreshToken; - let expirationDelaySeconds; - - if (request.payload.grant_type === 'refresh_token') { - refreshToken = request.payload.refresh_token; - const accessTokenAndExpirationDelaySeconds = await usecases.createAccessTokenFromRefreshToken({ refreshToken }); - accessToken = accessTokenAndExpirationDelaySeconds.accessToken; - expirationDelaySeconds = accessTokenAndExpirationDelaySeconds.expirationDelaySeconds; - } else if (request.payload.grant_type === 'password') { - const { username, password, scope } = request.payload; - const localeFromCookie = request.state?.locale; - - const source = 'pix'; - const tokensAndExpirationDelaySeconds = await usecases.authenticateUser({ - username, - password, - scope, - source, - localeFromCookie, - }); - accessToken = tokensAndExpirationDelaySeconds.accessToken; - refreshToken = tokensAndExpirationDelaySeconds.refreshToken; - expirationDelaySeconds = tokensAndExpirationDelaySeconds.expirationDelaySeconds; - } else { - throw new BadRequestError('Invalid grant type'); - } - - return h - .response({ - token_type: 'bearer', - access_token: accessToken, - user_id: dependencies.tokenService.extractUserId(accessToken), - refresh_token: refreshToken, - expires_in: expirationDelaySeconds, - }) - .code(200) - .header('Content-Type', 'application/json;charset=UTF-8') - .header('Cache-Control', 'no-store') - .header('Pragma', 'no-cache'); - }, - - async authenticateExternalUser(request, h) { - const { - username, - password, - 'external-user-token': externalUserToken, - 'expected-user-id': expectedUserId, - } = request.payload.data.attributes; +import { BadRequestError } from '../http-errors.js'; +import { tokenService } from '../../domain/services/token-service.js'; +import { usecases } from '../../domain/usecases/index.js'; + +const createToken = async function (request, h, dependencies = { tokenService }) { + let accessToken, refreshToken; + let expirationDelaySeconds; - const accessToken = await usecases.authenticateExternalUser({ + if (request.payload.grant_type === 'refresh_token') { + refreshToken = request.payload.refresh_token; + const accessTokenAndExpirationDelaySeconds = await usecases.createAccessTokenFromRefreshToken({ refreshToken }); + accessToken = accessTokenAndExpirationDelaySeconds.accessToken; + expirationDelaySeconds = accessTokenAndExpirationDelaySeconds.expirationDelaySeconds; + } else if (request.payload.grant_type === 'password') { + const { username, password, scope } = request.payload; + const localeFromCookie = request.state?.locale; + + const source = 'pix'; + const tokensAndExpirationDelaySeconds = await usecases.authenticateUser({ username, password, - externalUserToken, - expectedUserId, + scope, + source, + localeFromCookie, }); + accessToken = tokensAndExpirationDelaySeconds.accessToken; + refreshToken = tokensAndExpirationDelaySeconds.refreshToken; + expirationDelaySeconds = tokensAndExpirationDelaySeconds.expirationDelaySeconds; + } else { + throw new BadRequestError('Invalid grant type'); + } - const response = { - data: { - attributes: { - 'access-token': accessToken, - }, - type: 'external-user-authentication-requests', + return h + .response({ + token_type: 'bearer', + access_token: accessToken, + user_id: dependencies.tokenService.extractUserId(accessToken), + refresh_token: refreshToken, + expires_in: expirationDelaySeconds, + }) + .code(200) + .header('Content-Type', 'application/json;charset=UTF-8') + .header('Cache-Control', 'no-store') + .header('Pragma', 'no-cache'); +}; + +const authenticateExternalUser = async function (request, h) { + const { + username, + password, + 'external-user-token': externalUserToken, + 'expected-user-id': expectedUserId, + } = request.payload.data.attributes; + + const accessToken = await usecases.authenticateExternalUser({ + username, + password, + externalUserToken, + expectedUserId, + }); + + const response = { + data: { + attributes: { + 'access-token': accessToken, }, - }; - return h.response(response).code(200); - }, + type: 'external-user-authentication-requests', + }, + }; + return h.response(response).code(200); +}; - async authenticateAnonymousUser(request, h) { - const { campaign_code: campaignCode, lang } = request.payload; - const accessToken = await usecases.authenticateAnonymousUser({ campaignCode, lang }); +const authenticateAnonymousUser = async function (request, h) { + const { campaign_code: campaignCode, lang } = request.payload; + const accessToken = await usecases.authenticateAnonymousUser({ campaignCode, lang }); - const response = { + const response = { + token_type: 'bearer', + access_token: accessToken, + }; + + return h.response(response).code(200); +}; + +const authenticateApplication = async function (request, h) { + const { client_id: clientId, client_secret: clientSecret, scope } = request.payload; + + const accessToken = await usecases.authenticateApplication({ clientId, clientSecret, scope }); + + return h + .response({ token_type: 'bearer', access_token: accessToken, - }; - - return h.response(response).code(200); - }, - - async authenticateApplication(request, h) { - const { client_id: clientId, client_secret: clientSecret, scope } = request.payload; - - const accessToken = await usecases.authenticateApplication({ clientId, clientSecret, scope }); - - return h - .response({ - token_type: 'bearer', - access_token: accessToken, - client_id: clientId, - }) - .code(200) - .header('Content-Type', 'application/json;charset=UTF-8') - .header('Cache-Control', 'no-store') - .header('Pragma', 'no-cache'); - }, - - async revokeToken(request, h) { - if (request.payload.token_type_hint === 'access_token') return null; - - await usecases.revokeRefreshToken({ refreshToken: request.payload.token }); - return h.response().code(204); - }, + client_id: clientId, + }) + .code(200) + .header('Content-Type', 'application/json;charset=UTF-8') + .header('Cache-Control', 'no-store') + .header('Pragma', 'no-cache'); }; + +const revokeToken = async function (request, h) { + if (request.payload.token_type_hint === 'access_token') return null; + + await usecases.revokeRefreshToken({ refreshToken: request.payload.token }); + return h.response().code(204); +}; + +const authenticationController = { + createToken, + authenticateExternalUser, + authenticateAnonymousUser, + authenticateApplication, + revokeToken, +}; + +export { authenticationController }; diff --git a/api/lib/application/authentication/index.js b/api/lib/application/authentication/index.js index 38d569127ed..836c996cd98 100644 --- a/api/lib/application/authentication/index.js +++ b/api/lib/application/authentication/index.js @@ -1,11 +1,11 @@ -const Joi = require('joi'); -const { sendJsonApiError, BadRequestError } = require('../http-errors.js'); -const AuthenticationController = require('./authentication-controller.js'); -const responseAuthenticationObjectDoc = require('../../infrastructure/open-api-doc/authentication/response-authentication-doc.js'); -const responseErrorObjectDoc = require('../../infrastructure/open-api-doc/livret-scolaire/response-object-error-doc.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import Joi from 'joi'; +import { sendJsonApiError, BadRequestError } from '../http-errors.js'; +import { authenticationController as AuthenticationController } from './authentication-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { responseAuthenticationDoc } from '../../infrastructure/open-api-doc/authentication/response-authentication-doc.js'; +import { responseObjectErrorDoc } from '../../infrastructure/open-api-doc/livret-scolaire/response-object-error-doc.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'POST', @@ -72,9 +72,9 @@ exports.register = async (server) => { response: { failAction: 'log', status: { - 200: responseAuthenticationObjectDoc, - 401: responseErrorObjectDoc, - 403: responseErrorObjectDoc, + 200: responseAuthenticationDoc, + 401: responseObjectErrorDoc, + 403: responseObjectErrorDoc, }, }, handler: AuthenticationController.authenticateApplication, @@ -155,4 +155,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'authentication-api'; +const name = 'authentication-api'; +export { register, name }; diff --git a/api/lib/application/authentication/oidc/index.js b/api/lib/application/authentication/oidc/index.js index 7045a0e63ab..8c6cfbc6af1 100644 --- a/api/lib/application/authentication/oidc/index.js +++ b/api/lib/application/authentication/oidc/index.js @@ -1,10 +1,10 @@ -const Joi = require('joi'); -const OidcIdentityProviders = require('../../../domain/constants/oidc-identity-providers.js'); -const oidcController = require('./oidc-controller.js'); +import Joi from 'joi'; +import * as OidcIdentityProviders from '../../../domain/constants/oidc-identity-providers.js'; +import { oidcController } from './oidc-controller.js'; const validProviders = Object.values(OidcIdentityProviders).map((provider) => provider.service.code); -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'GET', @@ -171,4 +171,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'oidc-authentication-api'; +const name = 'oidc-authentication-api'; +export { register, name }; diff --git a/api/lib/application/authentication/oidc/oidc-controller.js b/api/lib/application/authentication/oidc/oidc-controller.js index 1e5abf6a4cc..18d6e8cb86d 100644 --- a/api/lib/application/authentication/oidc/oidc-controller.js +++ b/api/lib/application/authentication/oidc/oidc-controller.js @@ -1,137 +1,147 @@ -const authenticationServiceRegistry = require('../../../domain/services/authentication/authentication-service-registry.js'); -const serializer = require('../../../infrastructure/serializers/jsonapi/oidc-identity-providers-serializer.js'); -const usecases = require('../../../domain/usecases/index.js'); -const { UnauthorizedError } = require('../../http-errors.js'); -const oidcSerializer = require('../../../infrastructure/serializers/jsonapi/oidc-serializer.js'); - -module.exports = { - async getIdentityProviders(request, h) { - const identityProviders = usecases.getIdentityProviders(); - return h.response(serializer.serialize(identityProviders)).code(200); - }, - - async getRedirectLogoutUrl( - request, - h, - dependencies = { - authenticationServiceRegistry, - } - ) { - const userId = request.auth.credentials.userId; - const { identity_provider: identityProvider, logout_url_uuid: logoutUrlUUID } = request.query; - const oidcAuthenticationService = - dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); - const redirectLogoutUrl = await oidcAuthenticationService.getRedirectLogoutUrl({ - userId, - logoutUrlUUID, - }); - - return h.response({ redirectLogoutUrl }).code(200); - }, - - async findUserForReconciliation( - request, - h, - dependencies = { - oidcSerializer, - } - ) { - const { email, password, identityProvider, authenticationKey } = request.deserializedPayload; - - const result = await usecases.findUserForOidcReconciliation({ - email, - password, - identityProvider, - authenticationKey, - }); - - return h.response(dependencies.oidcSerializer.serialize(result)).code(200); - }, - - async reconcileUser( - request, - h, - dependencies = { - authenticationServiceRegistry, - } - ) { - const { identityProvider, authenticationKey } = request.deserializedPayload; - const oidcAuthenticationService = - dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); - - const result = await usecases.reconcileOidcUser({ - authenticationKey, - oidcAuthenticationService, - }); - - return h.response({ access_token: result.accessToken, logout_url_uuid: result.logoutUrlUUID }).code(200); - }, - - async getAuthenticationUrl( - request, - h, - dependencies = { - authenticationServiceRegistry, - } - ) { - const { identity_provider: identityProvider } = request.query; - const oidcAuthenticationService = - dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); - const result = oidcAuthenticationService.getAuthenticationUrl({ redirectUri: request.query['redirect_uri'] }); - return h.response(result).code(200); - }, - - async authenticateUser( - request, - h, - dependencies = { - authenticationServiceRegistry, - } - ) { - const { code, identityProvider, redirectUri, stateSent, stateReceived } = request.deserializedPayload; - - const oidcAuthenticationService = - dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); - - const result = await usecases.authenticateOidcUser({ - code, - redirectUri, - stateReceived, - stateSent, - oidcAuthenticationService, - }); - - if (result.isAuthenticationComplete) { - return h.response({ access_token: result.pixAccessToken, logout_url_uuid: result.logoutUrlUUID }).code(200); - } else { - const message = "L'utilisateur n'a pas de compte Pix"; - const responseCode = 'SHOULD_VALIDATE_CGU'; - const { authenticationKey, givenName, familyName } = result; - const meta = { authenticationKey, givenName, familyName }; - throw new UnauthorizedError(message, responseCode, meta); - } - }, - - async createUser( - request, - h, - dependencies = { - authenticationServiceRegistry, - } - ) { - const { identityProvider, authenticationKey } = request.deserializedPayload; - const localeFromCookie = request.state?.locale; - - const oidcAuthenticationService = - dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); - const { accessToken, logoutUrlUUID } = await usecases.createOidcUser({ - authenticationKey, - identityProvider, - localeFromCookie, - oidcAuthenticationService, - }); - - const response = { access_token: accessToken, logout_url_uuid: logoutUrlUUID }; - return h.response(response).code(200); - }, +import * as authenticationServiceRegistry from '../../../domain/services/authentication/authentication-service-registry.js'; +import * as serializer from '../../../infrastructure/serializers/jsonapi/oidc-identity-providers-serializer.js'; +import { usecases } from '../../../domain/usecases/index.js'; +import { UnauthorizedError } from '../../http-errors.js'; +import * as oidcSerializer from '../../../infrastructure/serializers/jsonapi/oidc-serializer.js'; + +const getIdentityProviders = async function (request, h) { + const identityProviders = usecases.getIdentityProviders(); + return h.response(serializer.serialize(identityProviders)).code(200); }; + +const getRedirectLogoutUrl = async function ( + request, + h, + dependencies = { + authenticationServiceRegistry, + } +) { + const userId = request.auth.credentials.userId; + const { identity_provider: identityProvider, logout_url_uuid: logoutUrlUUID } = request.query; + const oidcAuthenticationService = + dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); + const redirectLogoutUrl = await oidcAuthenticationService.getRedirectLogoutUrl({ + userId, + logoutUrlUUID, + }); + + return h.response({ redirectLogoutUrl }).code(200); +}; + +const findUserForReconciliation = async function ( + request, + h, + dependencies = { + oidcSerializer, + } +) { + const { email, password, identityProvider, authenticationKey } = request.deserializedPayload; + + const result = await usecases.findUserForOidcReconciliation({ + email, + password, + identityProvider, + authenticationKey, + }); + + return h.response(dependencies.oidcSerializer.serialize(result)).code(200); +}; + +const reconcileUser = async function ( + request, + h, + dependencies = { + authenticationServiceRegistry, + } +) { + const { identityProvider, authenticationKey } = request.deserializedPayload; + const oidcAuthenticationService = + dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); + + const result = await usecases.reconcileOidcUser({ + authenticationKey, + oidcAuthenticationService, + }); + + return h.response({ access_token: result.accessToken, logout_url_uuid: result.logoutUrlUUID }).code(200); +}; + +const getAuthenticationUrl = async function ( + request, + h, + dependencies = { + authenticationServiceRegistry, + } +) { + const { identity_provider: identityProvider } = request.query; + const oidcAuthenticationService = + dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); + const result = oidcAuthenticationService.getAuthenticationUrl({ redirectUri: request.query['redirect_uri'] }); + return h.response(result).code(200); +}; + +const authenticateUser = async function ( + request, + h, + dependencies = { + authenticationServiceRegistry, + } +) { + const { code, identityProvider, redirectUri, stateSent, stateReceived } = request.deserializedPayload; + + const oidcAuthenticationService = + dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); + + const result = await usecases.authenticateOidcUser({ + code, + redirectUri, + stateReceived, + stateSent, + oidcAuthenticationService, + }); + + if (result.isAuthenticationComplete) { + return h.response({ access_token: result.pixAccessToken, logout_url_uuid: result.logoutUrlUUID }).code(200); + } else { + const message = "L'utilisateur n'a pas de compte Pix"; + const responseCode = 'SHOULD_VALIDATE_CGU'; + const { authenticationKey, givenName, familyName } = result; + const meta = { authenticationKey, givenName, familyName }; + throw new UnauthorizedError(message, responseCode, meta); + } +}; + +const createUser = async function ( + request, + h, + dependencies = { + authenticationServiceRegistry, + } +) { + const { identityProvider, authenticationKey } = request.deserializedPayload; + const localeFromCookie = request.state?.locale; + + const oidcAuthenticationService = + dependencies.authenticationServiceRegistry.lookupAuthenticationService(identityProvider); + const { accessToken, logoutUrlUUID } = await usecases.createOidcUser({ + authenticationKey, + identityProvider, + localeFromCookie, + oidcAuthenticationService, + }); + + const response = { access_token: accessToken, logout_url_uuid: logoutUrlUUID }; + return h.response(response).code(200); +}; + +const oidcController = { + getIdentityProviders, + getRedirectLogoutUrl, + findUserForReconciliation, + reconcileUser, + getAuthenticationUrl, + authenticateUser, + createUser, +}; + +export { oidcController }; diff --git a/api/lib/application/badges/badges-controller.js b/api/lib/application/badges/badges-controller.js index 6ddc622abe3..fa94c25672e 100644 --- a/api/lib/application/badges/badges-controller.js +++ b/api/lib/application/badges/badges-controller.js @@ -1,20 +1,22 @@ -const usecases = require('../../domain/usecases/index.js'); -const badgeSerializer = require('../../infrastructure/serializers/jsonapi/badge-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as badgeSerializer from '../../infrastructure/serializers/jsonapi/badge-serializer.js'; -module.exports = { - async updateBadge(request, h) { - const badgeId = request.params.id; - const badge = badgeSerializer.deserialize(request.payload); +const updateBadge = async function (request, h) { + const badgeId = request.params.id; + const badge = badgeSerializer.deserialize(request.payload); - const updatedBadge = await usecases.updateBadge({ badgeId, badge }); + const updatedBadge = await usecases.updateBadge({ badgeId, badge }); - return h.response(badgeSerializer.serialize(updatedBadge)).code(204); - }, + return h.response(badgeSerializer.serialize(updatedBadge)).code(204); +}; - async deleteUnassociatedBadge(request, h) { - const badgeId = request.params.id; - await usecases.deleteUnassociatedBadge({ badgeId }); +const deleteUnassociatedBadge = async function (request, h) { + const badgeId = request.params.id; + await usecases.deleteUnassociatedBadge({ badgeId }); - return h.response().code(204); - }, + return h.response().code(204); }; + +const badgesController = { updateBadge, deleteUnassociatedBadge }; + +export { badgesController }; diff --git a/api/lib/application/badges/index.js b/api/lib/application/badges/index.js index 16d7f8f0b6d..4581bf8cc22 100644 --- a/api/lib/application/badges/index.js +++ b/api/lib/application/badges/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const badgesController = require('./badges-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import Joi from 'joi'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { badgesController } from './badges-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'PATCH', @@ -84,4 +84,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'badges-api'; +const name = 'badges-api'; +export { register, name }; diff --git a/api/lib/application/cache/cache-controller.js b/api/lib/application/cache/cache-controller.js index de57e8aa6bb..bc19c5fc2e3 100644 --- a/api/lib/application/cache/cache-controller.js +++ b/api/lib/application/cache/cache-controller.js @@ -1,21 +1,24 @@ -const LearningContentDatasources = require('../../infrastructure/datasources/learning-content/index.js'); -const learningContentDatasource = require('../../infrastructure/datasources/learning-content/datasource.js'); -const logger = require('../../infrastructure/logger.js'); -const _ = require('lodash'); +import * as LearningContentDatasources from '../../infrastructure/datasources/learning-content/index.js'; +import * as learningContentDatasource from '../../infrastructure/datasources/learning-content/datasource.js'; +import { logger } from '../../infrastructure/logger.js'; +import _ from 'lodash'; -module.exports = { - refreshCacheEntries(_, h, dependencies = { learningContentDatasource }) { - dependencies.learningContentDatasource - .refreshLearningContentCacheRecords() - .catch((e) => logger.error('Error while reloading cache', e)); - return h.response({}).code(202); - }, +const refreshCacheEntries = function (_, h, dependencies = { learningContentDatasource }) { + dependencies.learningContentDatasource + .refreshLearningContentCacheRecords() + .catch((e) => logger.error('Error while reloading cache', e)); + return h.response({}).code(202); +}; - refreshCacheEntry(request) { - const updatedRecord = request.payload; - const recordId = request.params.id; - const datasource = - LearningContentDatasources[_.findKey(LearningContentDatasources, { modelName: request.params.model })]; - return datasource.refreshLearningContentCacheRecord(recordId, updatedRecord).then(() => null); - }, +const refreshCacheEntry = function (request) { + const updatedRecord = request.payload; + const recordId = request.params.id; + const datasource = + // eslint-disable-next-line import/namespace + LearningContentDatasources[_.findKey(LearningContentDatasources, { modelName: request.params.model })]; + return datasource.refreshLearningContentCacheRecord(recordId, updatedRecord).then(() => null); }; + +const cacheController = { refreshCacheEntries, refreshCacheEntry }; + +export { cacheController }; diff --git a/api/lib/application/cache/index.js b/api/lib/application/cache/index.js index 4d74d113c70..adb20595e15 100644 --- a/api/lib/application/cache/index.js +++ b/api/lib/application/cache/index.js @@ -1,7 +1,7 @@ -const securityPreHandlers = require('../security-pre-handlers.js'); -const CacheController = require('./cache-controller.js'); +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { cacheController } from './cache-controller.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'PATCH', @@ -13,7 +13,7 @@ exports.register = async function (server) { assign: 'hasRoleSuperAdmin', }, ], - handler: CacheController.refreshCacheEntry, + handler: cacheController.refreshCacheEntry, tags: ['api', 'cache'], notes: [ 'Cette route est restreinte aux utilisateurs authentifiés avec le rôle Super Admin', @@ -32,7 +32,7 @@ exports.register = async function (server) { assign: 'hasRoleSuperAdmin', }, ], - handler: CacheController.refreshCacheEntries, + handler: cacheController.refreshCacheEntries, tags: ['api', 'cache'], notes: [ 'Cette route est restreinte aux utilisateurs authentifiés avec le rôle Super Admin', @@ -43,4 +43,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'cache-api'; +const name = 'cache-api'; +export { register, name }; diff --git a/api/lib/application/campaign-participations/campaign-participation-controller.js b/api/lib/application/campaign-participations/campaign-participation-controller.js index fcfd45ef568..b0458ac7fb9 100644 --- a/api/lib/application/campaign-participations/campaign-participation-controller.js +++ b/api/lib/application/campaign-participations/campaign-participation-controller.js @@ -1,187 +1,202 @@ -const monitoringTools = require('../../infrastructure/monitoring-tools.js'); -const usecases = require('../../domain/usecases/index.js'); -const events = require('../../domain/events/index.js'); -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const campaignParticipationSerializer = require('../../infrastructure/serializers/jsonapi/campaign-participation-serializer.js'); -const campaignAnalysisSerializer = require('../../infrastructure/serializers/jsonapi/campaign-analysis-serializer.js'); -const campaignAssessmentParticipationSerializer = require('../../infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer.js'); -const campaignAssessmentParticipationResultSerializer = require('../../infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer.js'); -const campaignProfileSerializer = require('../../infrastructure/serializers/jsonapi/campaign-profile-serializer.js'); -const campaignAssessmentResultMinimalSerializer = require('../../infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer.js'); -const trainingSerializer = require('../../infrastructure/serializers/jsonapi/training-serializer.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); -const { extractLocaleFromRequest } = require('../../infrastructure/utils/request-response-utils.js'); - -module.exports = { - async save(request, h, dependencies = { campaignParticipationSerializer, monitoringTools }) { - const userId = request.auth.credentials.userId; - const campaignParticipation = await dependencies.campaignParticipationSerializer.deserialize(request.payload); - - const { event, campaignParticipation: campaignParticipationCreated } = await DomainTransaction.execute( - (domainTransaction) => { - return usecases.startCampaignParticipation({ campaignParticipation, userId, domainTransaction }); - } - ); - - events.eventDispatcher - .dispatch(event) - .catch((error) => dependencies.monitoringTools.logErrorWithCorrelationIds({ message: error })); - - return h.response(dependencies.campaignParticipationSerializer.serialize(campaignParticipationCreated)).created(); - }, - - async shareCampaignResult(request) { - const userId = request.auth.credentials.userId; - const campaignParticipationId = request.params.id; - - await DomainTransaction.execute(async (domainTransaction) => { - const event = await usecases.shareCampaignResult({ - userId, - campaignParticipationId, - domainTransaction, - }); - await events.eventBus.publish(event, domainTransaction); - return event; - }); +import { monitoringTools } from '../../infrastructure/monitoring-tools.js'; +import { usecases } from '../../domain/usecases/index.js'; +import * as events from '../../domain/events/index.js'; +import { extractParameters } from '../../infrastructure/utils/query-params-utils.js'; +import * as campaignParticipationSerializer from '../../infrastructure/serializers/jsonapi/campaign-participation-serializer.js'; +import * as campaignAnalysisSerializer from '../../infrastructure/serializers/jsonapi/campaign-analysis-serializer.js'; +import * as campaignAssessmentParticipationSerializer from '../../infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer.js'; +import * as campaignAssessmentParticipationResultSerializer from '../../infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer.js'; +import * as campaignProfileSerializer from '../../infrastructure/serializers/jsonapi/campaign-profile-serializer.js'; +import * as campaignAssessmentResultMinimalSerializer from '../../infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer.js'; +import * as trainingSerializer from '../../infrastructure/serializers/jsonapi/training-serializer.js'; +import { + extractUserIdFromRequest, + extractLocaleFromRequest, +} from '../../infrastructure/utils/request-response-utils.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; + +const save = async function (request, h, dependencies = { campaignParticipationSerializer, monitoringTools }) { + const userId = request.auth.credentials.userId; + const campaignParticipation = await dependencies.campaignParticipationSerializer.deserialize(request.payload); + + const { event, campaignParticipation: campaignParticipationCreated } = await DomainTransaction.execute( + (domainTransaction) => { + return usecases.startCampaignParticipation({ campaignParticipation, userId, domainTransaction }); + } + ); - return null; - }, - - async beginImprovement(request) { - const userId = request.auth.credentials.userId; - const campaignParticipationId = request.params.id; - - return DomainTransaction.execute(async (domainTransaction) => { - await usecases.beginCampaignParticipationImprovement({ - campaignParticipationId, - userId, - domainTransaction, - }); - return null; - }); - }, + events.eventDispatcher + .dispatch(event) + .catch((error) => dependencies.monitoringTools.logErrorWithCorrelationIds({ message: error })); + + return h.response(dependencies.campaignParticipationSerializer.serialize(campaignParticipationCreated)).created(); +}; - async getAnalysis(request, h, dependencies = { campaignAnalysisSerializer }) { - const { userId } = request.auth.credentials; - const campaignParticipationId = request.params.id; - const locale = extractLocaleFromRequest(request); +const shareCampaignResult = async function (request) { + const userId = request.auth.credentials.userId; + const campaignParticipationId = request.params.id; - const campaignAnalysis = await usecases.computeCampaignParticipationAnalysis({ + await DomainTransaction.execute(async (domainTransaction) => { + const event = await usecases.shareCampaignResult({ userId, campaignParticipationId, - locale, + domainTransaction, + }); + await events.eventBus.publish(event, domainTransaction); + return event; + }); + + return null; +}; + +const beginImprovement = async function (request) { + const userId = request.auth.credentials.userId; + const campaignParticipationId = request.params.id; + + return DomainTransaction.execute(async (domainTransaction) => { + await usecases.beginCampaignParticipationImprovement({ + campaignParticipationId, + userId, + domainTransaction, }); - return dependencies.campaignAnalysisSerializer.serialize(campaignAnalysis); - }, + return null; + }); +}; - async getCampaignProfile(request, h, dependencies = { campaignProfileSerializer }) { - const { userId } = request.auth.credentials; - const { campaignId, campaignParticipationId } = request.params; - const locale = extractLocaleFromRequest(request); +const getAnalysis = async function (request, h, dependencies = { campaignAnalysisSerializer }) { + const { userId } = request.auth.credentials; + const campaignParticipationId = request.params.id; + const locale = extractLocaleFromRequest(request); + + const campaignAnalysis = await usecases.computeCampaignParticipationAnalysis({ + userId, + campaignParticipationId, + locale, + }); + return dependencies.campaignAnalysisSerializer.serialize(campaignAnalysis); +}; + +const getCampaignProfile = async function (request, h, dependencies = { campaignProfileSerializer }) { + const { userId } = request.auth.credentials; + const { campaignId, campaignParticipationId } = request.params; + const locale = extractLocaleFromRequest(request); - const campaignProfile = await usecases.getCampaignProfile({ userId, campaignId, campaignParticipationId, locale }); - return dependencies.campaignProfileSerializer.serialize(campaignProfile); - }, + const campaignProfile = await usecases.getCampaignProfile({ userId, campaignId, campaignParticipationId, locale }); + return dependencies.campaignProfileSerializer.serialize(campaignProfile); +}; - async getCampaignAssessmentParticipation(request) { - const { userId } = request.auth.credentials; - const { campaignId, campaignParticipationId } = request.params; +const getCampaignAssessmentParticipation = async function (request) { + const { userId } = request.auth.credentials; + const { campaignId, campaignParticipationId } = request.params; + + const campaignAssessmentParticipation = await usecases.getCampaignAssessmentParticipation({ + userId, + campaignId, + campaignParticipationId, + }); + return campaignAssessmentParticipationSerializer.serialize(campaignAssessmentParticipation); +}; - const campaignAssessmentParticipation = await usecases.getCampaignAssessmentParticipation({ +const deleteParticipation = async function (request, h) { + const { userId } = request.auth.credentials; + const { id, campaignParticipationId } = request.params; + await DomainTransaction.execute(async (domainTransaction) => { + await usecases.deleteCampaignParticipation({ userId, - campaignId, + campaignId: id, campaignParticipationId, + domainTransaction, }); - return campaignAssessmentParticipationSerializer.serialize(campaignAssessmentParticipation); - }, - - async deleteParticipation(request, h) { - const { userId } = request.auth.credentials; - const { id, campaignParticipationId } = request.params; - await DomainTransaction.execute(async (domainTransaction) => { - await usecases.deleteCampaignParticipation({ - userId, - campaignId: id, - campaignParticipationId, - domainTransaction, - }); - }); - return h.response({}).code(204); - }, - - async getCampaignAssessmentParticipationResult( - request, - h, - dependencies = { campaignAssessmentParticipationResultSerializer } - ) { - const { userId } = request.auth.credentials; - const { campaignId, campaignParticipationId } = request.params; - const locale = extractLocaleFromRequest(request); - - const campaignAssessmentParticipationResult = await usecases.getCampaignAssessmentParticipationResult({ + }); + return h.response({}).code(204); +}; + +const getCampaignAssessmentParticipationResult = async function ( + request, + h, + dependencies = { campaignAssessmentParticipationResultSerializer } +) { + const { userId } = request.auth.credentials; + const { campaignId, campaignParticipationId } = request.params; + const locale = extractLocaleFromRequest(request); + + const campaignAssessmentParticipationResult = await usecases.getCampaignAssessmentParticipationResult({ + userId, + campaignId, + campaignParticipationId, + locale, + }); + return dependencies.campaignAssessmentParticipationResultSerializer.serialize(campaignAssessmentParticipationResult); +}; + +const findAssessmentParticipationResults = async function (request) { + const campaignId = request.params.id; + const { page, filter: filters } = extractParameters(request.query); + if (filters.divisions && !Array.isArray(filters.divisions)) { + filters.divisions = [filters.divisions]; + } + if (filters.groups && !Array.isArray(filters.groups)) { + filters.groups = [filters.groups]; + } + if (filters.badges && !Array.isArray(filters.badges)) { + filters.badges = [filters.badges]; + } + if (filters.stages && !Array.isArray(filters.stages)) { + filters.stages = [filters.stages]; + } + const currentUserId = extractUserIdFromRequest(request); + const paginatedParticipations = await usecases.findAssessmentParticipationResultList({ + userId: currentUserId, + campaignId, + page, + filters, + }); + return campaignAssessmentResultMinimalSerializer.serialize(paginatedParticipations); +}; + +const updateParticipantExternalId = async function (request, h) { + const campaignParticipationId = request.params.id; + const participantExternalId = request.payload.data.attributes['participant-external-id']; + + await usecases.updateParticipantExternalId({ campaignParticipationId, participantExternalId }); + return h.response({}).code(204); +}; + +const deleteCampaignParticipationForAdmin = async function (request, h) { + const { userId } = request.auth.credentials; + const { id: campaignParticipationId } = request.params; + await DomainTransaction.execute(async (domainTransaction) => { + await usecases.deleteCampaignParticipationForAdmin({ userId, - campaignId, campaignParticipationId, - locale, + domainTransaction, }); - return dependencies.campaignAssessmentParticipationResultSerializer.serialize( - campaignAssessmentParticipationResult - ); - }, - - async findAssessmentParticipationResults(request) { - const campaignId = request.params.id; - const { page, filter: filters } = queryParamsUtils.extractParameters(request.query); - if (filters.divisions && !Array.isArray(filters.divisions)) { - filters.divisions = [filters.divisions]; - } - if (filters.groups && !Array.isArray(filters.groups)) { - filters.groups = [filters.groups]; - } - if (filters.badges && !Array.isArray(filters.badges)) { - filters.badges = [filters.badges]; - } - if (filters.stages && !Array.isArray(filters.stages)) { - filters.stages = [filters.stages]; - } - const currentUserId = requestResponseUtils.extractUserIdFromRequest(request); - const paginatedParticipations = await usecases.findAssessmentParticipationResultList({ - userId: currentUserId, - campaignId, - page, - filters, - }); - return campaignAssessmentResultMinimalSerializer.serialize(paginatedParticipations); - }, - - async updateParticipantExternalId(request, h) { - const campaignParticipationId = request.params.id; - const participantExternalId = request.payload.data.attributes['participant-external-id']; - - await usecases.updateParticipantExternalId({ campaignParticipationId, participantExternalId }); - return h.response({}).code(204); - }, - - async deleteCampaignParticipationForAdmin(request, h) { - const { userId } = request.auth.credentials; - const { id: campaignParticipationId } = request.params; - await DomainTransaction.execute(async (domainTransaction) => { - await usecases.deleteCampaignParticipationForAdmin({ - userId, - campaignParticipationId, - domainTransaction, - }); - }); - return h.response({}).code(204); - }, + }); + return h.response({}).code(204); +}; - async findTrainings(request, h, dependencies = { trainingSerializer }) { - const { userId } = request.auth.credentials; - const { id: campaignParticipationId } = request.params; - const locale = extractLocaleFromRequest(request); +const findTrainings = async function (request, h, dependencies = { trainingSerializer }) { + const { userId } = request.auth.credentials; + const { id: campaignParticipationId } = request.params; + const locale = extractLocaleFromRequest(request); - const trainings = await usecases.findCampaignParticipationTrainings({ userId, campaignParticipationId, locale }); - return dependencies.trainingSerializer.serialize(trainings); - }, + const trainings = await usecases.findCampaignParticipationTrainings({ userId, campaignParticipationId, locale }); + return dependencies.trainingSerializer.serialize(trainings); }; + +const campaignParticipationController = { + save, + shareCampaignResult, + beginImprovement, + getAnalysis, + getCampaignProfile, + getCampaignAssessmentParticipation, + deleteParticipation, + getCampaignAssessmentParticipationResult, + findAssessmentParticipationResults, + updateParticipantExternalId, + deleteCampaignParticipationForAdmin, + findTrainings, +}; + +export { campaignParticipationController }; diff --git a/api/lib/application/campaign-participations/index.js b/api/lib/application/campaign-participations/index.js index 747bec9d9b9..42a2117245c 100644 --- a/api/lib/application/campaign-participations/index.js +++ b/api/lib/application/campaign-participations/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); -const campaignParticipationController = require('./campaign-participation-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import Joi from 'joi'; +import { campaignParticipationController } from './campaign-participation-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'PATCH', @@ -256,4 +256,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'campaign-participations-api'; +const name = 'campaign-participations-api'; +export { register, name }; diff --git a/api/lib/application/campaigns-administration/campaign-controller.js b/api/lib/application/campaigns-administration/campaign-controller.js index cbced17312f..43deec62854 100644 --- a/api/lib/application/campaigns-administration/campaign-controller.js +++ b/api/lib/application/campaigns-administration/campaign-controller.js @@ -1,16 +1,18 @@ -const usecases = require('../../domain/usecases/index.js'); -const csvCampaignsIdsParser = require('../../infrastructure/serializers/csv/campaigns-administration/csv-campaigns-ids-parser.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as csvCampaignsIdsParser from '../../infrastructure/serializers/csv/campaigns-administration/csv-campaigns-ids-parser.js'; -module.exports = { - async archiveCampaigns(request, h, dependencies = { csvCampaignsIdsParser }) { - const { userId } = request.auth.credentials; - const campaignIds = await dependencies.csvCampaignsIdsParser.extractCampaignsIds(request.payload.path); +const archiveCampaigns = async function (request, h, dependencies = { csvCampaignsIdsParser }) { + const { userId } = request.auth.credentials; + const campaignIds = await dependencies.csvCampaignsIdsParser.extractCampaignsIds(request.payload.path); - await usecases.campaignAdministrationArchiveCampaign({ - userId, - campaignIds, - }); + await usecases.archiveCampaigns({ + userId, + campaignIds, + }); - return h.response(null).code(204); - }, + return h.response(null).code(204); }; + +const campaignController = { archiveCampaigns }; + +export { campaignController }; diff --git a/api/lib/application/campaigns-administration/index.js b/api/lib/application/campaigns-administration/index.js index b582ba35489..1d541aa92d9 100644 --- a/api/lib/application/campaigns-administration/index.js +++ b/api/lib/application/campaigns-administration/index.js @@ -1,13 +1,13 @@ -const { sendJsonApiError, PayloadTooLargeError } = require('../http-errors.js'); - -const campaignController = require('./campaign-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import { sendJsonApiError, PayloadTooLargeError } from '../http-errors.js'; +import { campaignController } from './campaign-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; const TWENTY_MEGABYTES = 1048576 * 20; const ERRORS = { PAYLOAD_TOO_LARGE: 'PAYLOAD_TOO_LARGE', }; -exports.register = async function (server) { + +const register = async function (server) { server.route([ { method: 'POST', @@ -47,4 +47,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'campaigns-administration-api'; +const name = 'campaigns-administration-api'; +export { register, name }; diff --git a/api/lib/application/campaigns/campaign-controller.js b/api/lib/application/campaigns/campaign-controller.js index b67f2aaea95..435164dcbbe 100644 --- a/api/lib/application/campaigns/campaign-controller.js +++ b/api/lib/application/campaigns/campaign-controller.js @@ -1,246 +1,268 @@ -const _ = require('lodash'); -const { PassThrough } = require('stream'); - -const { MissingQueryParamError } = require('../http-errors.js'); -const usecases = require('../../domain/usecases/index.js'); -const tokenService = require('../../../lib/domain/services/token-service.js'); - -const campaignToJoinSerializer = require('../../infrastructure/serializers/jsonapi/campaign-to-join-serializer.js'); -const campaignAnalysisSerializer = require('../../infrastructure/serializers/jsonapi/campaign-analysis-serializer.js'); -const campaignReportSerializer = require('../../infrastructure/serializers/jsonapi/campaign-report-serializer.js'); -const campaignCollectiveResultSerializer = require('../../infrastructure/serializers/jsonapi/campaign-collective-result-serializer.js'); -const campaignProfilesCollectionParticipationSummarySerializer = require('../../infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer.js'); -const campaignParticipantsActivitySerializer = require('../../infrastructure/serializers/jsonapi/campaign-participant-activity-serializer.js'); -const divisionSerializer = require('../../infrastructure/serializers/jsonapi/division-serializer.js'); -const groupSerializer = require('../../infrastructure/serializers/jsonapi/group-serializer.js'); - -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); -const { extractLocaleFromRequest } = require('../../infrastructure/utils/request-response-utils.js'); -const { ForbiddenAccess } = require('../../domain/errors.js'); - -module.exports = { - async save(request, h, dependencies = { campaignReportSerializer }) { - const { userId: creatorId } = request.auth.credentials; - const { - name, - type, - title, - 'multiple-sendings': multipleSendings, - 'id-pix-label': idPixLabel, - 'custom-landing-page-text': customLandingPageText, - 'owner-id': ownerId, - } = request.payload.data.attributes; - // eslint-disable-next-line no-restricted-syntax - const targetProfileId = parseInt(_.get(request, 'payload.data.relationships.target-profile.data.id')) || null; - // eslint-disable-next-line no-restricted-syntax - const organizationId = parseInt(_.get(request, 'payload.data.relationships.organization.data.id')) || null; - - const campaign = { - name, - type, - title, - idPixLabel, - customLandingPageText, - creatorId, - ownerId: _getOwnerId(ownerId, creatorId), - organizationId, - targetProfileId, - multipleSendings, - }; - - const createdCampaign = await usecases.createCampaign({ campaign }); - return h.response(dependencies.campaignReportSerializer.serialize(createdCampaign)).created(); - }, - - async getByCode(request) { - const filters = queryParamsUtils.extractParameters(request.query).filter; - await _validateFilters(filters); - - const campaignToJoin = await usecases.getCampaignByCode({ code: filters.code }); - return campaignToJoinSerializer.serialize(campaignToJoin); - }, - - async getById( - request, - h, - dependencies = { - campaignReportSerializer, - tokenService, - } - ) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - const tokenForCampaignResults = dependencies.tokenService.createTokenForCampaignResults({ userId, campaignId }); - - const campaign = await usecases.getCampaign({ campaignId, userId }); - return dependencies.campaignReportSerializer.serialize(campaign, {}, { tokenForCampaignResults }); - }, - - async getCsvAssessmentResults(request, h, dependencies = { tokenService }) { - const token = request.query.accessToken; - const { userId, campaignId: extractedCampaignId } = - dependencies.tokenService.extractCampaignResultsTokenContent(token); - const campaignId = request.params.id; - - if (extractedCampaignId !== campaignId) { - throw new ForbiddenAccess(); - } - - const writableStream = new PassThrough(); - - const { fileName } = await usecases.startWritingCampaignAssessmentResultsToStream({ - userId, - campaignId, - writableStream, - i18n: request.i18n, - }); - const escapedFileName = requestResponseUtils.escapeFileName(fileName); - - writableStream.headers = { - 'content-type': 'text/csv;charset=utf-8', - 'content-disposition': `attachment; filename="${escapedFileName}"`, - - // WHY: to avoid compression because when compressing, the server buffers - // for too long causing a response timeout. - 'content-encoding': 'identity', - }; - - return writableStream; - }, - - async getCsvProfilesCollectionResults(request, h, dependencies = { tokenService }) { - const token = request.query.accessToken; - const { userId, campaignId: extractedCampaignId } = - dependencies.tokenService.extractCampaignResultsTokenContent(token); - const campaignId = request.params.id; - - if (extractedCampaignId !== campaignId) { - throw new ForbiddenAccess(); - } - - const writableStream = new PassThrough(); - - const { fileName } = await usecases.startWritingCampaignProfilesCollectionResultsToStream({ - userId, - campaignId, - writableStream, - i18n: request.i18n, - }); - const escapedFileName = requestResponseUtils.escapeFileName(fileName); - - writableStream.headers = { - 'content-type': 'text/csv;charset=utf-8', - 'content-disposition': `attachment; filename="${escapedFileName}"`, - - // WHY: to avoid compression because when compressing, the server buffers - // for too long causing a response timeout. - 'content-encoding': 'identity', - }; - - return writableStream; - }, - - update(request, h, dependencies = { campaignReportSerializer }) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - return usecases - .updateCampaign({ userId, campaignId, ...request.deserializedPayload }) - .then(dependencies.campaignReportSerializer.serialize); - }, - - archiveCampaign(request, h, dependencies = { campaignReportSerializer }) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - return usecases.archiveCampaign({ userId, campaignId }).then(dependencies.campaignReportSerializer.serialize); - }, - - unarchiveCampaign(request, h, dependencies = { campaignReportSerializer }) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - return usecases.unarchiveCampaign({ userId, campaignId }).then(dependencies.campaignReportSerializer.serialize); - }, - - async getCollectiveResult(request, h, dependencies = { campaignCollectiveResultSerializer }) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - const locale = extractLocaleFromRequest(request); - - const campaignCollectiveResult = await usecases.computeCampaignCollectiveResult({ userId, campaignId, locale }); - return dependencies.campaignCollectiveResultSerializer.serialize(campaignCollectiveResult); - }, - - async getAnalysis(request, h, dependencies = { campaignAnalysisSerializer }) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - const locale = extractLocaleFromRequest(request); - - const campaignAnalysis = await usecases.computeCampaignAnalysis({ userId, campaignId, locale }); - return dependencies.campaignAnalysisSerializer.serialize(campaignAnalysis); - }, - - async findProfilesCollectionParticipations(request) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - const { page, filter: filters } = queryParamsUtils.extractParameters(request.query); - if (filters.divisions && !Array.isArray(filters.divisions)) { - filters.divisions = [filters.divisions]; - } - if (filters.groups && !Array.isArray(filters.groups)) { - filters.groups = [filters.groups]; - } - const results = await usecases.findCampaignProfilesCollectionParticipationSummaries({ - userId, - campaignId, - page, - filters, - }); - return campaignProfilesCollectionParticipationSummarySerializer.serialize(results); - }, - - async findParticipantsActivity(request, h, dependencies = { campaignParticipantsActivitySerializer }) { - const campaignId = request.params.id; - - const { page, filter: filters } = queryParamsUtils.extractParameters(request.query); - if (filters.divisions && !Array.isArray(filters.divisions)) { - filters.divisions = [filters.divisions]; - } - if (filters.groups && !Array.isArray(filters.groups)) { - filters.groups = [filters.groups]; - } - - const { userId } = request.auth.credentials; - const paginatedParticipations = await usecases.findPaginatedCampaignParticipantsActivities({ - userId, - campaignId, - page, - filters, - }); - - return dependencies.campaignParticipantsActivitySerializer.serialize(paginatedParticipations); - }, - - async division(request) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - const divisions = await usecases.getParticipantsDivision({ userId, campaignId }); - return divisionSerializer.serialize(divisions); - }, - - async getGroups(request) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - const groups = await usecases.getParticipantsGroup({ userId, campaignId }); - return groupSerializer.serialize(groups); - }, +import _ from 'lodash'; +import stream from 'stream'; + +const { PassThrough } = stream; + +import { MissingQueryParamError } from '../http-errors.js'; +import { usecases } from '../../domain/usecases/index.js'; +import { tokenService } from '../../../lib/domain/services/token-service.js'; + +import * as campaignToJoinSerializer from '../../infrastructure/serializers/jsonapi/campaign-to-join-serializer.js'; +import * as campaignAnalysisSerializer from '../../infrastructure/serializers/jsonapi/campaign-analysis-serializer.js'; +import * as campaignReportSerializer from '../../infrastructure/serializers/jsonapi/campaign-report-serializer.js'; +import * as campaignCollectiveResultSerializer from '../../infrastructure/serializers/jsonapi/campaign-collective-result-serializer.js'; +import * as campaignProfilesCollectionParticipationSummarySerializer from '../../infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer.js'; +import * as campaignParticipantsActivitySerializer from '../../infrastructure/serializers/jsonapi/campaign-participant-activity-serializer.js'; +import * as divisionSerializer from '../../infrastructure/serializers/jsonapi/division-serializer.js'; +import * as groupSerializer from '../../infrastructure/serializers/jsonapi/group-serializer.js'; + +import { extractParameters } from '../../infrastructure/utils/query-params-utils.js'; +import { escapeFileName, extractLocaleFromRequest } from '../../infrastructure/utils/request-response-utils.js'; +import { ForbiddenAccess } from '../../domain/errors.js'; + +const save = async function (request, h, dependencies = { campaignReportSerializer }) { + const { userId: creatorId } = request.auth.credentials; + const { + name, + type, + title, + 'multiple-sendings': multipleSendings, + 'id-pix-label': idPixLabel, + 'custom-landing-page-text': customLandingPageText, + 'owner-id': ownerId, + } = request.payload.data.attributes; + // eslint-disable-next-line no-restricted-syntax + const targetProfileId = parseInt(_.get(request, 'payload.data.relationships.target-profile.data.id')) || null; + // eslint-disable-next-line no-restricted-syntax + const organizationId = parseInt(_.get(request, 'payload.data.relationships.organization.data.id')) || null; + + const campaign = { + name, + type, + title, + idPixLabel, + customLandingPageText, + creatorId, + ownerId: _getOwnerId(ownerId, creatorId), + organizationId, + targetProfileId, + multipleSendings, + }; + + const createdCampaign = await usecases.createCampaign({ campaign }); + return h.response(dependencies.campaignReportSerializer.serialize(createdCampaign)).created(); }; +const getByCode = async function (request) { + const filters = extractParameters(request.query).filter; + await _validateFilters(filters); + + const campaignToJoin = await usecases.getCampaignByCode({ code: filters.code }); + return campaignToJoinSerializer.serialize(campaignToJoin); +}; + +const getById = async function ( + request, + h, + dependencies = { + campaignReportSerializer, + tokenService, + } +) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + const tokenForCampaignResults = dependencies.tokenService.createTokenForCampaignResults({ userId, campaignId }); + + const campaign = await usecases.getCampaign({ campaignId, userId }); + return dependencies.campaignReportSerializer.serialize(campaign, {}, { tokenForCampaignResults }); +}; + +const getCsvAssessmentResults = async function (request, h, dependencies = { tokenService }) { + const token = request.query.accessToken; + const { userId, campaignId: extractedCampaignId } = + dependencies.tokenService.extractCampaignResultsTokenContent(token); + const campaignId = request.params.id; + + if (extractedCampaignId !== campaignId) { + throw new ForbiddenAccess(); + } + + const writableStream = new PassThrough(); + + const { fileName } = await usecases.startWritingCampaignAssessmentResultsToStream({ + userId, + campaignId, + writableStream, + i18n: request.i18n, + }); + const escapedFileName = escapeFileName(fileName); + + writableStream.headers = { + 'content-type': 'text/csv;charset=utf-8', + 'content-disposition': `attachment; filename="${escapedFileName}"`, + + // WHY: to avoid compression because when compressing, the server buffers + // for too long causing a response timeout. + 'content-encoding': 'identity', + }; + + return writableStream; +}; + +const getCsvProfilesCollectionResults = async function (request, h, dependencies = { tokenService }) { + const token = request.query.accessToken; + const { userId, campaignId: extractedCampaignId } = + dependencies.tokenService.extractCampaignResultsTokenContent(token); + const campaignId = request.params.id; + + if (extractedCampaignId !== campaignId) { + throw new ForbiddenAccess(); + } + + const writableStream = new PassThrough(); + + const { fileName } = await usecases.startWritingCampaignProfilesCollectionResultsToStream({ + userId, + campaignId, + writableStream, + i18n: request.i18n, + }); + const escapedFileName = escapeFileName(fileName); + + writableStream.headers = { + 'content-type': 'text/csv;charset=utf-8', + 'content-disposition': `attachment; filename="${escapedFileName}"`, + + // WHY: to avoid compression because when compressing, the server buffers + // for too long causing a response timeout. + 'content-encoding': 'identity', + }; + + return writableStream; +}; + +const update = function (request, h, dependencies = { campaignReportSerializer }) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + return usecases + .updateCampaign({ userId, campaignId, ...request.deserializedPayload }) + .then(dependencies.campaignReportSerializer.serialize); +}; + +const archiveCampaign = function (request, h, dependencies = { campaignReportSerializer }) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + return usecases.archiveCampaign({ userId, campaignId }).then(dependencies.campaignReportSerializer.serialize); +}; + +const unarchiveCampaign = function (request, h, dependencies = { campaignReportSerializer }) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + return usecases.unarchiveCampaign({ userId, campaignId }).then(dependencies.campaignReportSerializer.serialize); +}; + +const getCollectiveResult = async function (request, h, dependencies = { campaignCollectiveResultSerializer }) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + const locale = extractLocaleFromRequest(request); + + const campaignCollectiveResult = await usecases.computeCampaignCollectiveResult({ userId, campaignId, locale }); + return dependencies.campaignCollectiveResultSerializer.serialize(campaignCollectiveResult); +}; + +const getAnalysis = async function (request, h, dependencies = { campaignAnalysisSerializer }) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + const locale = extractLocaleFromRequest(request); + + const campaignAnalysis = await usecases.computeCampaignAnalysis({ userId, campaignId, locale }); + return dependencies.campaignAnalysisSerializer.serialize(campaignAnalysis); +}; + +const findProfilesCollectionParticipations = async function (request) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + const { page, filter: filters } = extractParameters(request.query); + if (filters.divisions && !Array.isArray(filters.divisions)) { + filters.divisions = [filters.divisions]; + } + if (filters.groups && !Array.isArray(filters.groups)) { + filters.groups = [filters.groups]; + } + const results = await usecases.findCampaignProfilesCollectionParticipationSummaries({ + userId, + campaignId, + page, + filters, + }); + return campaignProfilesCollectionParticipationSummarySerializer.serialize(results); +}; + +const findParticipantsActivity = async function ( + request, + h, + dependencies = { campaignParticipantsActivitySerializer } +) { + const campaignId = request.params.id; + + const { page, filter: filters } = extractParameters(request.query); + if (filters.divisions && !Array.isArray(filters.divisions)) { + filters.divisions = [filters.divisions]; + } + if (filters.groups && !Array.isArray(filters.groups)) { + filters.groups = [filters.groups]; + } + + const { userId } = request.auth.credentials; + const paginatedParticipations = await usecases.findPaginatedCampaignParticipantsActivities({ + userId, + campaignId, + page, + filters, + }); + + return dependencies.campaignParticipantsActivitySerializer.serialize(paginatedParticipations); +}; + +const division = async function (request) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + const divisions = await usecases.getParticipantsDivision({ userId, campaignId }); + return divisionSerializer.serialize(divisions); +}; + +const getGroups = async function (request) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + const groups = await usecases.getParticipantsGroup({ userId, campaignId }); + return groupSerializer.serialize(groups); +}; + +const campaignController = { + save, + getByCode, + getById, + getCsvAssessmentResults, + getCsvProfilesCollectionResults, + update, + archiveCampaign, + unarchiveCampaign, + getCollectiveResult, + getAnalysis, + findProfilesCollectionParticipations, + findParticipantsActivity, + division, + getGroups, +}; + +export { campaignController }; + function _validateFilters(filters) { if (typeof filters.code === 'undefined') { throw new MissingQueryParamError('filter.code'); diff --git a/api/lib/application/campaigns/campaign-management-controller.js b/api/lib/application/campaigns/campaign-management-controller.js index 42b4dd1f8e2..618f2538c31 100644 --- a/api/lib/application/campaigns/campaign-management-controller.js +++ b/api/lib/application/campaigns/campaign-management-controller.js @@ -1,36 +1,42 @@ -const usecases = require('../../domain/usecases/index.js'); -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const campaignDetailsManagementSerializer = require('../../infrastructure/serializers/jsonapi/campaign-details-management-serializer.js'); -const participationForCampaignManagementSerializer = require('../../infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer.js'); -const commonDeserializer = require('../../infrastructure/serializers/jsonapi/deserializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import { extractParameters } from '../../infrastructure/utils/query-params-utils.js'; +import * as campaignDetailsManagementSerializer from '../../infrastructure/serializers/jsonapi/campaign-details-management-serializer.js'; +import * as participationForCampaignManagementSerializer from '../../infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer.js'; +import { deserializer } from '../../infrastructure/serializers/jsonapi/deserializer.js'; -module.exports = { - async getCampaignDetails(request) { - const campaignId = request.params.id; - const campaign = await usecases.getCampaignDetailsManagement({ campaignId }); - return campaignDetailsManagementSerializer.serialize(campaign); - }, - - async findPaginatedParticipationsForCampaignManagement(request) { - const campaignId = request.params.id; - const { page } = queryParamsUtils.extractParameters(request.query); - - const { models: participationsForCampaignManagement, meta } = - await usecases.findPaginatedParticipationsForCampaignManagement({ - campaignId, - page, - }); - return participationForCampaignManagementSerializer.serialize(participationsForCampaignManagement, meta); - }, +const getCampaignDetails = async function (request) { + const campaignId = request.params.id; + const campaign = await usecases.getCampaignDetailsManagement({ campaignId }); + return campaignDetailsManagementSerializer.serialize(campaign); +}; - async updateCampaignDetailsManagement(request, h) { - const campaignId = request.params.id; +const findPaginatedParticipationsForCampaignManagement = async function (request) { + const campaignId = request.params.id; + const { page } = extractParameters(request.query); - const campaignDetailsManagement = await commonDeserializer.deserialize(request.payload); - await usecases.updateCampaignDetailsManagement({ + const { models: participationsForCampaignManagement, meta } = + await usecases.findPaginatedParticipationsForCampaignManagement({ campaignId, - ...campaignDetailsManagement, + page, }); - return h.response({}).code(204); - }, + return participationForCampaignManagementSerializer.serialize(participationsForCampaignManagement, meta); }; + +const updateCampaignDetailsManagement = async function (request, h) { + const campaignId = request.params.id; + + const campaignDetailsManagement = await deserializer.deserialize(request.payload); + await usecases.updateCampaignDetailsManagement({ + campaignId, + ...campaignDetailsManagement, + }); + return h.response({}).code(204); +}; + +const campaignManagementController = { + getCampaignDetails, + findPaginatedParticipationsForCampaignManagement, + updateCampaignDetailsManagement, +}; + +export { campaignManagementController }; diff --git a/api/lib/application/campaigns/campaign-stats-controller.js b/api/lib/application/campaigns/campaign-stats-controller.js index 189b9c4cd39..091b8487384 100644 --- a/api/lib/application/campaigns/campaign-stats-controller.js +++ b/api/lib/application/campaigns/campaign-stats-controller.js @@ -1,55 +1,62 @@ -const usecases = require('../../domain/usecases/index.js'); -const participationsByStageSerializer = require('../../infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer.js'); -const participationsByStatusSerializer = require('../../infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer.js'); -const participationsByDaySerializer = require('../../infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer.js'); -const participationsCountByMasteryRateSerializer = require('../../infrastructure/serializers/jsonapi/participations-count-by-mastery-rate.js'); - -module.exports = { - async getParticipationsByStage(request) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - const participationsByStage = await usecases.getCampaignParticipationsCountByStage({ userId, campaignId }); - - return participationsByStageSerializer.serialize({ - campaignId, - data: participationsByStage, - }); - }, - - async getParticipationsByStatus(request) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - const participantsCounts = await usecases.getCampaignParticipationsCountsByStatus({ userId, campaignId }); - - return participationsByStatusSerializer.serialize({ - campaignId, - ...participantsCounts, - }); - }, - - async getParticipationsByDay(request) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - const participantsCounts = await usecases.getCampaignParticipationsActivityByDay({ userId, campaignId }); - - return participationsByDaySerializer.serialize({ - campaignId, - ...participantsCounts, - }); - }, - - async getParticipationsCountByMasteryRate(request) { - const { userId } = request.auth.credentials; - const campaignId = request.params.id; - - const resultDistribution = await usecases.getParticipationsCountByMasteryRate({ userId, campaignId }); - - return participationsCountByMasteryRateSerializer.serialize({ - campaignId, - resultDistribution, - }); - }, +import { usecases } from '../../domain/usecases/index.js'; +import * as participationsByStageSerializer from '../../infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer.js'; +import * as participationsByStatusSerializer from '../../infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer.js'; +import * as participationsByDaySerializer from '../../infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer.js'; +import * as participationsCountByMasteryRateSerializer from '../../infrastructure/serializers/jsonapi/participations-count-by-mastery-rate.js'; + +const getParticipationsByStage = async function (request) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + const participationsByStage = await usecases.getCampaignParticipationsCountByStage({ userId, campaignId }); + + return participationsByStageSerializer.serialize({ + campaignId, + data: participationsByStage, + }); }; + +const getParticipationsByStatus = async function (request) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + const participantsCounts = await usecases.getCampaignParticipationsCountsByStatus({ userId, campaignId }); + + return participationsByStatusSerializer.serialize({ + campaignId, + ...participantsCounts, + }); +}; + +const getParticipationsByDay = async function (request) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + const participantsCounts = await usecases.getCampaignParticipationsActivityByDay({ userId, campaignId }); + + return participationsByDaySerializer.serialize({ + campaignId, + ...participantsCounts, + }); +}; + +const getParticipationsCountByMasteryRate = async function (request) { + const { userId } = request.auth.credentials; + const campaignId = request.params.id; + + const resultDistribution = await usecases.getParticipationsCountByMasteryRate({ userId, campaignId }); + + return participationsCountByMasteryRateSerializer.serialize({ + campaignId, + resultDistribution, + }); +}; + +const campaignStatsController = { + getParticipationsByStage, + getParticipationsByStatus, + getParticipationsByDay, + getParticipationsCountByMasteryRate, +}; + +export { campaignStatsController }; diff --git a/api/lib/application/campaigns/index.js b/api/lib/application/campaigns/index.js index 96b337b0dfe..cdb051ba834 100644 --- a/api/lib/application/campaigns/index.js +++ b/api/lib/application/campaigns/index.js @@ -1,14 +1,14 @@ -const Joi = require('joi'); -const campaignController = require('./campaign-controller.js'); -const campaignManagementController = require('./campaign-management-controller.js'); -const campaignStatsController = require('./campaign-stats-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); +import Joi from 'joi'; +import { campaignController } from './campaign-controller.js'; +import { campaignManagementController } from './campaign-management-controller.js'; +import { campaignStatsController } from './campaign-stats-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; const campaignParticipationStatuses = Object.values(CampaignParticipationStatuses); -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -440,4 +440,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'campaigns-api'; +const name = 'campaigns-api'; +export { register, name }; diff --git a/api/lib/application/certification-candidates/certification-candidates-controller.js b/api/lib/application/certification-candidates/certification-candidates-controller.js index 1791502d415..3432bf04351 100644 --- a/api/lib/application/certification-candidates/certification-candidates-controller.js +++ b/api/lib/application/certification-candidates/certification-candidates-controller.js @@ -1,42 +1,49 @@ -const usecases = require('../../domain/usecases/index.js'); -const certificationCandidateSubscriptionSerializer = require('../../infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as certificationCandidateSubscriptionSerializer from '../../infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer.js'; -module.exports = { - async authorizeToStart(request, h) { - const certificationCandidateForSupervisingId = request.params.id; +const authorizeToStart = async function (request, h) { + const certificationCandidateForSupervisingId = request.params.id; - const authorizedToStart = request.payload['authorized-to-start']; - await usecases.authorizeCertificationCandidateToStart({ - certificationCandidateForSupervisingId, - authorizedToStart, - }); + const authorizedToStart = request.payload['authorized-to-start']; + await usecases.authorizeCertificationCandidateToStart({ + certificationCandidateForSupervisingId, + authorizedToStart, + }); - return h.response().code(204); - }, + return h.response().code(204); +}; + +const authorizeToResume = async function (request, h) { + const certificationCandidateId = request.params.id; - async authorizeToResume(request, h) { - const certificationCandidateId = request.params.id; + await usecases.authorizeCertificationCandidateToResume({ + certificationCandidateId, + }); - await usecases.authorizeCertificationCandidateToResume({ - certificationCandidateId, - }); + return h.response().code(204); +}; - return h.response().code(204); - }, +const getSubscriptions = async function (request) { + const certificationCandidateId = request.params.id; + const certificationCandidateSubscription = await usecases.getCertificationCandidateSubscription({ + certificationCandidateId, + }); + return certificationCandidateSubscriptionSerializer.serialize(certificationCandidateSubscription); +}; - async getSubscriptions(request) { - const certificationCandidateId = request.params.id; - const certificationCandidateSubscription = await usecases.getCertificationCandidateSubscription({ - certificationCandidateId, - }); - return certificationCandidateSubscriptionSerializer.serialize(certificationCandidateSubscription); - }, +const endAssessmentBySupervisor = async function (request) { + const certificationCandidateId = request.params.id; - async endAssessmentBySupervisor(request) { - const certificationCandidateId = request.params.id; + await usecases.endAssessmentBySupervisor({ certificationCandidateId }); - await usecases.endAssessmentBySupervisor({ certificationCandidateId }); + return null; +}; - return null; - }, +const certificationCandidatesController = { + authorizeToStart, + authorizeToResume, + getSubscriptions, + endAssessmentBySupervisor, }; + +export { certificationCandidatesController }; diff --git a/api/lib/application/certification-candidates/index.js b/api/lib/application/certification-candidates/index.js index 34e6ae166f1..c1288ace109 100644 --- a/api/lib/application/certification-candidates/index.js +++ b/api/lib/application/certification-candidates/index.js @@ -1,9 +1,9 @@ -const certificationCandidatesController = require('./certification-candidates-controller.js'); -const assessmentSupervisorAuthorization = require('../preHandlers/session-supervisor-authorization.js'); -const Joi = require('joi'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { certificationCandidatesController } from './certification-candidates-controller.js'; +import { assessmentSupervisorAuthorization } from '../preHandlers/session-supervisor-authorization.js'; +import Joi from 'joi'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -93,4 +93,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'certification-candidates-api'; +const name = 'certification-candidates-api'; +export { register, name }; diff --git a/api/lib/application/certification-center-invitations/certification-center-invitation-controller.js b/api/lib/application/certification-center-invitations/certification-center-invitation-controller.js index d0cf6360148..d188d247418 100644 --- a/api/lib/application/certification-center-invitations/certification-center-invitation-controller.js +++ b/api/lib/application/certification-center-invitations/certification-center-invitation-controller.js @@ -1,36 +1,42 @@ -const usecases = require('../../domain/usecases/index.js'); -const certificationCenterInvitationSerializer = require('../../infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as certificationCenterInvitationSerializer from '../../infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js'; -module.exports = { - async acceptCertificationCenterInvitation(request, h) { - const certificationCenterInvitationId = request.params.id; - const { code, email: rawEmail } = request.deserializedPayload; - const localeFromCookie = request.state?.locale; - const email = rawEmail.trim().toLowerCase(); +const acceptCertificationCenterInvitation = async function (request, h) { + const certificationCenterInvitationId = request.params.id; + const { code, email: rawEmail } = request.deserializedPayload; + const localeFromCookie = request.state?.locale; + const email = rawEmail.trim().toLowerCase(); - await usecases.acceptCertificationCenterInvitation({ - certificationCenterInvitationId, - code, - email, - localeFromCookie, - }); - return h.response({}).code(204); - }, + await usecases.acceptCertificationCenterInvitation({ + certificationCenterInvitationId, + code, + email, + localeFromCookie, + }); + return h.response({}).code(204); +}; - async getCertificationCenterInvitation(request) { - const certificationCenterInvitationId = request.params.id; - const certificationCenterInvitationCode = request.query.code; +const getCertificationCenterInvitation = async function (request) { + const certificationCenterInvitationId = request.params.id; + const certificationCenterInvitationCode = request.query.code; - const certificationCenterInvitation = await usecases.getCertificationCenterInvitation({ - certificationCenterInvitationId, - certificationCenterInvitationCode, - }); - return certificationCenterInvitationSerializer.serialize(certificationCenterInvitation); - }, + const certificationCenterInvitation = await usecases.getCertificationCenterInvitation({ + certificationCenterInvitationId, + certificationCenterInvitationCode, + }); + return certificationCenterInvitationSerializer.serialize(certificationCenterInvitation); +}; - async cancelCertificationCenterInvitation(request, h) { - const certificationCenterInvitationId = request.params.certificationCenterInvitationId; - await usecases.cancelCertificationCenterInvitation({ certificationCenterInvitationId }); - return h.response().code(204); - }, +const cancelCertificationCenterInvitation = async function (request, h) { + const certificationCenterInvitationId = request.params.certificationCenterInvitationId; + await usecases.cancelCertificationCenterInvitation({ certificationCenterInvitationId }); + return h.response().code(204); }; + +const certificationCenterInvitationController = { + acceptCertificationCenterInvitation, + getCertificationCenterInvitation, + cancelCertificationCenterInvitation, +}; + +export { certificationCenterInvitationController }; diff --git a/api/lib/application/certification-center-invitations/index.js b/api/lib/application/certification-center-invitations/index.js index e653d782001..a690a54c951 100644 --- a/api/lib/application/certification-center-invitations/index.js +++ b/api/lib/application/certification-center-invitations/index.js @@ -1,10 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const certificationCenterInvitationController = require('./certification-center-invitation-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import { certificationCenterInvitationController } from './certification-center-invitation-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -81,4 +81,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'certification-center-invitations-api'; +const name = 'certification-center-invitations-api'; +export { register, name }; diff --git a/api/lib/application/certification-center-memberships/certification-center-membership-controller.js b/api/lib/application/certification-center-memberships/certification-center-membership-controller.js index b6e8810f3cb..5a2269f9b24 100644 --- a/api/lib/application/certification-center-memberships/certification-center-membership-controller.js +++ b/api/lib/application/certification-center-memberships/certification-center-membership-controller.js @@ -1,11 +1,13 @@ -const usecases = require('../../domain/usecases/index.js'); +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async disable(request, h) { - const certificationCenterMembershipId = request.params.id; - await usecases.disableCertificationCenterMembership({ - certificationCenterMembershipId, - }); - return h.response().code(204); - }, +const disable = async function (request, h) { + const certificationCenterMembershipId = request.params.id; + await usecases.disableCertificationCenterMembership({ + certificationCenterMembershipId, + }); + return h.response().code(204); }; + +const certificationCenterMembershipController = { disable }; + +export { certificationCenterMembershipController }; diff --git a/api/lib/application/certification-center-memberships/index.js b/api/lib/application/certification-center-memberships/index.js index fe978349474..0f213556a0c 100644 --- a/api/lib/application/certification-center-memberships/index.js +++ b/api/lib/application/certification-center-memberships/index.js @@ -1,7 +1,7 @@ -const certificationCenterMembershipController = require('./certification-center-membership-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import { certificationCenterMembershipController } from './certification-center-membership-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async function (server) { +const register = async function (server) { const adminRoutes = [ { method: 'DELETE', @@ -32,4 +32,5 @@ exports.register = async function (server) { server.route([...adminRoutes]); }; -exports.name = 'certification-center-memberships-api'; +const name = 'certification-center-memberships-api'; +export { register, name }; diff --git a/api/lib/application/certification-centers/certification-center-controller.js b/api/lib/application/certification-centers/certification-center-controller.js index cb3243860bf..a11bc921f1c 100644 --- a/api/lib/application/certification-centers/certification-center-controller.js +++ b/api/lib/application/certification-centers/certification-center-controller.js @@ -1,236 +1,263 @@ -const usecases = require('../../domain/usecases/index.js'); - -const certificationCenterSerializer = require('../../infrastructure/serializers/jsonapi/certification-center-serializer.js'); -const certificationCenterForAdminSerializer = require('../../infrastructure/serializers/jsonapi/certification-center-for-admin-serializer.js'); -const certificationCenterMembershipSerializer = require('../../infrastructure/serializers/jsonapi/certification-center-membership-serializer.js'); -const divisionSerializer = require('../../infrastructure/serializers/jsonapi/division-serializer.js'); -const studentCertificationSerializer = require('../../infrastructure/serializers/jsonapi/student-certification-serializer.js'); -const sessionSummarySerializer = require('../../infrastructure/serializers/jsonapi/session-summary-serializer.js'); -const certificationCenterInvitationSerializer = require('../../infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js'); -const sessionSerializer = require('../../infrastructure/serializers/jsonapi/session-serializer.js'); - -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const map = require('lodash/map'); -const csvHelpers = require('../../../scripts/helpers/csvHelpers.js'); -const csvSerializer = require('../../infrastructure/serializers/csv/csv-serializer.js'); -const { getHeaders } = require('../../infrastructure/files/sessions-import.js'); - -module.exports = { - async saveSession(request, _h, dependencies = { sessionSerializer }) { - const userId = request.auth.credentials.userId; - const session = dependencies.sessionSerializer.deserialize(request.payload); - - const newSession = await usecases.createSession({ userId, session }); - - return dependencies.sessionSerializer.serialize({ session: newSession }); - }, - - async create(request) { - const certificationCenter = certificationCenterForAdminSerializer.deserialize(request.payload); - const complementaryCertificationIds = map(request.payload.data.relationships?.habilitations?.data, 'id'); - const createdCertificationCenter = await usecases.createCertificationCenter({ - certificationCenter, - complementaryCertificationIds, - }); - return certificationCenterForAdminSerializer.serialize(createdCertificationCenter); - }, - - async update(request) { - const certificationCenter = certificationCenterForAdminSerializer.deserialize(request.payload); - const complementaryCertificationIds = map(request.payload.data.relationships?.habilitations?.data, 'id'); - const updatedCertificationCenter = await usecases.updateCertificationCenter({ - certificationCenter, - complementaryCertificationIds, - }); - return certificationCenterForAdminSerializer.serialize(updatedCertificationCenter); - }, +import { usecases } from '../../domain/usecases/index.js'; - async getCertificationCenterDetails(request) { - const certificationCenterId = request.params.id; +import * as certificationCenterSerializer from '../../infrastructure/serializers/jsonapi/certification-center-serializer.js'; +import * as certificationCenterForAdminSerializer from '../../infrastructure/serializers/jsonapi/certification-center-for-admin-serializer.js'; +import * as certificationCenterMembershipSerializer from '../../infrastructure/serializers/jsonapi/certification-center-membership-serializer.js'; +import * as divisionSerializer from '../../infrastructure/serializers/jsonapi/division-serializer.js'; +import * as studentCertificationSerializer from '../../infrastructure/serializers/jsonapi/student-certification-serializer.js'; +import * as sessionSummarySerializer from '../../infrastructure/serializers/jsonapi/session-summary-serializer.js'; +import * as certificationCenterInvitationSerializer from '../../infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js'; +import * as sessionSerializer from '../../infrastructure/serializers/jsonapi/session-serializer.js'; - const certificationCenterDetails = await usecases.getCertificationCenterForAdmin({ id: certificationCenterId }); - return certificationCenterForAdminSerializer.serialize(certificationCenterDetails); - }, +import { extractParameters } from '../../infrastructure/utils/query-params-utils.js'; +import lodash from 'lodash'; - async findPaginatedFilteredCertificationCenters(request) { - const options = queryParamsUtils.extractParameters(request.query); - const { models: organizations, pagination } = await usecases.findPaginatedFilteredCertificationCenters({ - filter: options.filter, - page: options.page, - }); +const { map } = lodash; - return certificationCenterSerializer.serialize(organizations, pagination); - }, +import * as csvHelpers from './csvHelpers.js'; +import * as csvSerializer from '../../infrastructure/serializers/csv/csv-serializer.js'; +import { getHeaders } from '../../infrastructure/files/sessions-import.js'; - async findPaginatedSessionSummaries(request) { - const certificationCenterId = request.params.id; - const userId = request.auth.credentials.userId; - const options = queryParamsUtils.extractParameters(request.query); +const saveSession = async function (request, _h, dependencies = { sessionSerializer }) { + const userId = request.auth.credentials.userId; + const session = dependencies.sessionSerializer.deserialize(request.payload); - const { models: sessionSummaries, meta } = await usecases.findPaginatedCertificationCenterSessionSummaries({ - userId, - certificationCenterId, - page: options.page, - }); + const newSession = await usecases.createSession({ userId, session }); - return sessionSummarySerializer.serialize(sessionSummaries, meta); - }, + return dependencies.sessionSerializer.serialize({ session: newSession }); +}; - async getStudents(request) { - const certificationCenterId = request.params.certificationCenterId; - const sessionId = request.params.sessionId; +const create = async function (request) { + const certificationCenter = certificationCenterForAdminSerializer.deserialize(request.payload); + const complementaryCertificationIds = map(request.payload.data.relationships?.habilitations?.data, 'id'); + const createdCertificationCenter = await usecases.createCertificationCenter({ + certificationCenter, + complementaryCertificationIds, + }); + return certificationCenterForAdminSerializer.serialize(createdCertificationCenter); +}; - const { filter, page } = queryParamsUtils.extractParameters(request.query); - if (filter.divisions && !Array.isArray(filter.divisions)) { - filter.divisions = [filter.divisions]; - } +const update = async function (request) { + const certificationCenter = certificationCenterForAdminSerializer.deserialize(request.payload); + const complementaryCertificationIds = map(request.payload.data.relationships?.habilitations?.data, 'id'); + const updatedCertificationCenter = await usecases.updateCertificationCenter({ + certificationCenter, + complementaryCertificationIds, + }); + return certificationCenterForAdminSerializer.serialize(updatedCertificationCenter); +}; - const { data, pagination } = await usecases.findStudentsForEnrolment({ - certificationCenterId, - sessionId, - page, - filter, - }); - return studentCertificationSerializer.serialize(data, pagination); - }, +const getCertificationCenterDetails = async function (request) { + const certificationCenterId = request.params.id; - async getDivisions(request) { - const certificationCenterId = request.params.certificationCenterId; - const divisions = await usecases.findDivisionsByCertificationCenter({ - certificationCenterId, - }); + const certificationCenterDetails = await usecases.getCertificationCenterForAdmin({ id: certificationCenterId }); + return certificationCenterForAdminSerializer.serialize(certificationCenterDetails); +}; - return divisionSerializer.serialize(divisions); - }, +const findPaginatedFilteredCertificationCenters = async function (request) { + const options = extractParameters(request.query); + const { models: organizations, pagination } = await usecases.findPaginatedFilteredCertificationCenters({ + filter: options.filter, + page: options.page, + }); - async findCertificationCenterMembershipsByCertificationCenter( - request, - h, - dependencies = { certificationCenterMembershipSerializer } - ) { - const certificationCenterId = request.params.certificationCenterId; - const certificationCenterMemberships = await usecases.findCertificationCenterMembershipsByCertificationCenter({ - certificationCenterId, - }); + return certificationCenterSerializer.serialize(organizations, pagination); +}; - return dependencies.certificationCenterMembershipSerializer.serialize(certificationCenterMemberships); - }, +const findPaginatedSessionSummaries = async function (request) { + const certificationCenterId = request.params.id; + const userId = request.auth.credentials.userId; + const options = extractParameters(request.query); - async findCertificationCenterMemberships(request, h, dependencies = { certificationCenterMembershipSerializer }) { - const certificationCenterId = request.params.certificationCenterId; - const certificationCenterMemberships = await usecases.findCertificationCenterMembershipsByCertificationCenter({ - certificationCenterId, - }); + const { models: sessionSummaries, meta } = await usecases.findPaginatedCertificationCenterSessionSummaries({ + userId, + certificationCenterId, + page: options.page, + }); - return dependencies.certificationCenterMembershipSerializer.serializeMembers(certificationCenterMemberships); - }, + return sessionSummarySerializer.serialize(sessionSummaries, meta); +}; - async createCertificationCenterMembershipByEmail( - request, - h, - dependencies = { certificationCenterMembershipSerializer } - ) { - const certificationCenterId = request.params.certificationCenterId; - const { email } = request.payload; +const getStudents = async function (request) { + const certificationCenterId = request.params.certificationCenterId; + const sessionId = request.params.sessionId; + + const { filter, page } = extractParameters(request.query); + if (filter.divisions && !Array.isArray(filter.divisions)) { + filter.divisions = [filter.divisions]; + } + + const { data, pagination } = await usecases.findStudentsForEnrolment({ + certificationCenterId, + sessionId, + page, + filter, + }); + return studentCertificationSerializer.serialize(data, pagination); +}; - const certificationCenterMembership = await usecases.createCertificationCenterMembershipByEmail({ - certificationCenterId, - email, - }); - return h - .response(dependencies.certificationCenterMembershipSerializer.serialize(certificationCenterMembership)) - .created(); - }, +const getDivisions = async function (request) { + const certificationCenterId = request.params.certificationCenterId; + const divisions = await usecases.findDivisionsByCertificationCenter({ + certificationCenterId, + }); - async findPendingInvitationsForAdmin(request, h) { - const certificationCenterId = request.params.certificationCenterId; + return divisionSerializer.serialize(divisions); +}; - const certificationCenterInvitations = await usecases.findPendingCertificationCenterInvitations({ - certificationCenterId, - }); - return h.response(certificationCenterInvitationSerializer.serializeForAdmin(certificationCenterInvitations)); - }, +const findCertificationCenterMembershipsByCertificationCenter = async function ( + request, + h, + dependencies = { certificationCenterMembershipSerializer } +) { + const certificationCenterId = request.params.certificationCenterId; + const certificationCenterMemberships = await usecases.findCertificationCenterMembershipsByCertificationCenter({ + certificationCenterId, + }); + + return dependencies.certificationCenterMembershipSerializer.serialize(certificationCenterMemberships); +}; - async updateReferer(request, h) { - const certificationCenterId = request.params.certificationCenterId; - const { userId, isReferer } = request.payload.data.attributes; +const findCertificationCenterMemberships = async function ( + request, + h, + dependencies = { certificationCenterMembershipSerializer } +) { + const certificationCenterId = request.params.certificationCenterId; + const certificationCenterMemberships = await usecases.findCertificationCenterMembershipsByCertificationCenter({ + certificationCenterId, + }); + + return dependencies.certificationCenterMembershipSerializer.serializeMembers(certificationCenterMemberships); +}; - await usecases.updateCertificationCenterReferer({ - userId, - certificationCenterId, - isReferer, - }); - return h.response().code(204); - }, - - async sendInvitationForAdmin(request, h, dependencies = { certificationCenterInvitationSerializer }) { - const certificationCenterId = request.params.certificationCenterId; - const invitationInformation = await certificationCenterInvitationSerializer.deserializeForAdmin(request.payload); - - const { certificationCenterInvitation, isInvitationCreated } = - await usecases.createOrUpdateCertificationCenterInvitationForAdmin({ - email: invitationInformation.email, - locale: invitationInformation.language, - certificationCenterId, - }); - - const serializedCertificationCenterInvitation = - dependencies.certificationCenterInvitationSerializer.serializeForAdmin(certificationCenterInvitation); - if (isInvitationCreated) { - return h.response(serializedCertificationCenterInvitation).created(); - } - return h.response(serializedCertificationCenterInvitation); - }, - - async getSessionsImportTemplate(request, h) { - const certificationCenterId = request.params.certificationCenterId; - const habilitationLabels = await usecases.getImportSessionComplementaryCertificationHabilitationsLabels({ - certificationCenterId, - }); - const certificationCenter = await usecases.getCertificationCenter({ id: certificationCenterId }); - const headers = getHeaders({ - habilitationLabels, - shouldDisplayBillingModeColumns: certificationCenter.hasBillingMode, - }); - return h - .response(headers) - .header('Content-Type', 'text/csv; charset=utf-8') - .header('content-disposition', 'filename=import-sessions') - .code(200); - }, +const createCertificationCenterMembershipByEmail = async function ( + request, + h, + dependencies = { certificationCenterMembershipSerializer } +) { + const certificationCenterId = request.params.certificationCenterId; + const { email } = request.payload; + + const certificationCenterMembership = await usecases.createCertificationCenterMembershipByEmail({ + certificationCenterId, + email, + }); + return h + .response(dependencies.certificationCenterMembershipSerializer.serialize(certificationCenterMembership)) + .created(); +}; + +const findPendingInvitationsForAdmin = async function (request, h) { + const certificationCenterId = request.params.certificationCenterId; - async validateSessionsForMassImport(request, h, dependencies = { csvHelpers, csvSerializer }) { - const certificationCenterId = request.params.certificationCenterId; - const authenticatedUserId = request.auth.credentials.userId; + const certificationCenterInvitations = await usecases.findPendingCertificationCenterInvitations({ + certificationCenterId, + }); + return h.response(certificationCenterInvitationSerializer.serializeForAdmin(certificationCenterInvitations)); +}; - const parsedCsvData = await dependencies.csvHelpers.parseCsvWithHeader(request.payload.path); +const updateReferer = async function (request, h) { + const certificationCenterId = request.params.certificationCenterId; + const { userId, isReferer } = request.payload.data.attributes; - const certificationCenter = await usecases.getCertificationCenter({ id: certificationCenterId }); + await usecases.updateCertificationCenterReferer({ + userId, + certificationCenterId, + isReferer, + }); + return h.response().code(204); +}; - const sessions = dependencies.csvSerializer.deserializeForSessionsImport({ - parsedCsvData, - hasBillingMode: certificationCenter.hasBillingMode, - }); - const sessionMassImportReport = await usecases.validateSessions({ - sessions, +const sendInvitationForAdmin = async function (request, h, dependencies = { certificationCenterInvitationSerializer }) { + const certificationCenterId = request.params.certificationCenterId; + const invitationInformation = await certificationCenterInvitationSerializer.deserializeForAdmin(request.payload); + + const { certificationCenterInvitation, isInvitationCreated } = + await usecases.createOrUpdateCertificationCenterInvitationForAdmin({ + email: invitationInformation.email, + locale: invitationInformation.language, certificationCenterId, - userId: authenticatedUserId, - i18n: request.i18n, }); - return h.response(sessionMassImportReport).code(200); - }, - async createSessionsForMassImport(request, h) { - const { certificationCenterId } = request.params; - const authenticatedUserId = request.auth.credentials.userId; + const serializedCertificationCenterInvitation = + dependencies.certificationCenterInvitationSerializer.serializeForAdmin(certificationCenterInvitation); + if (isInvitationCreated) { + return h.response(serializedCertificationCenterInvitation).created(); + } + return h.response(serializedCertificationCenterInvitation); +}; - const { cachedValidatedSessionsKey } = request.payload.data.attributes; +const getSessionsImportTemplate = async function (request, h) { + const certificationCenterId = request.params.certificationCenterId; + const habilitationLabels = await usecases.getImportSessionComplementaryCertificationHabilitationsLabels({ + certificationCenterId, + }); + const certificationCenter = await usecases.getCertificationCenter({ id: certificationCenterId }); + const headers = getHeaders({ + habilitationLabels, + shouldDisplayBillingModeColumns: certificationCenter.hasBillingMode, + }); + return h + .response(headers) + .header('Content-Type', 'text/csv; charset=utf-8') + .header('content-disposition', 'filename=import-sessions') + .code(200); +}; - await usecases.createSessions({ - cachedValidatedSessionsKey, - certificationCenterId, - userId: authenticatedUserId, - }); - return h.response().code(201); - }, +const validateSessionsForMassImport = async function (request, h, dependencies = { csvHelpers, csvSerializer }) { + const certificationCenterId = request.params.certificationCenterId; + const authenticatedUserId = request.auth.credentials.userId; + + const parsedCsvData = await dependencies.csvHelpers.parseCsvWithHeader(request.payload.path); + + const certificationCenter = await usecases.getCertificationCenter({ id: certificationCenterId }); + + const sessions = dependencies.csvSerializer.deserializeForSessionsImport({ + parsedCsvData, + hasBillingMode: certificationCenter.hasBillingMode, + }); + const sessionMassImportReport = await usecases.validateSessions({ + sessions, + certificationCenterId, + userId: authenticatedUserId, + i18n: request.i18n, + }); + return h.response(sessionMassImportReport).code(200); +}; + +const createSessionsForMassImport = async function (request, h) { + const { certificationCenterId } = request.params; + const authenticatedUserId = request.auth.credentials.userId; + + const { cachedValidatedSessionsKey } = request.payload.data.attributes; + + await usecases.createSessions({ + cachedValidatedSessionsKey, + certificationCenterId, + userId: authenticatedUserId, + }); + return h.response().code(201); }; + +const certificationCenterController = { + saveSession, + create, + update, + getCertificationCenterDetails, + findPaginatedFilteredCertificationCenters, + findPaginatedSessionSummaries, + getStudents, + getDivisions, + findCertificationCenterMembershipsByCertificationCenter, + findCertificationCenterMemberships, + createCertificationCenterMembershipByEmail, + findPendingInvitationsForAdmin, + updateReferer, + sendInvitationForAdmin, + getSessionsImportTemplate, + validateSessionsForMassImport, + createSessionsForMassImport, +}; + +export { certificationCenterController }; diff --git a/api/lib/application/certification-centers/csvHelpers.js b/api/lib/application/certification-centers/csvHelpers.js new file mode 100644 index 00000000000..f0df5410d51 --- /dev/null +++ b/api/lib/application/certification-centers/csvHelpers.js @@ -0,0 +1,119 @@ +import fs from 'fs'; + +const { readFile, access } = fs.promises; +import lodash from 'lodash'; + +const { difference, isEmpty } = lodash; +import papa from 'papaparse'; + +import { NotFoundError, FileValidationError } from '../../domain/errors.js'; + +const ERRORS = { + INVALID_FILE_EXTENSION: 'INVALID_FILE_EXTENSION', + MISSING_REQUIRED_FIELD_NAMES: 'MISSING_REQUIRED_FIELD_NAMES', + MISSING_REQUIRED_FIELD_VALUES: 'MISSING_REQUIRED_FIELD_VALUES', + EMPTY_FILE: 'EMPTY_FILE', +}; + +const optionsWithHeader = { + skipEmptyLines: true, + header: true, + transform: (value, columnName) => { + if (typeof value === 'string') { + value = value.trim(); + } + if (columnName === 'uai') { + value = value.toUpperCase(); + } + if (columnName === 'createdBy') { + value = !isEmpty(value) && value; + } + if (columnName === 'credit' && isEmpty(value)) { + value = 0; + } + if (columnName === 'locale' && isEmpty(value)) { + value = 'fr-fr'; + } + if (columnName === 'email' && !isEmpty(value)) { + value = value.replaceAll(' ', '').toLowerCase(); + } + return value; + }, +}; + +async function checkCsvHeader({ filePath, requiredFieldNames = [] }) { + if (isEmpty(requiredFieldNames)) { + throw new FileValidationError(ERRORS.MISSING_REQUIRED_FIELD_NAMES); + } + + const data = await parseCsv(filePath, { skipEmptyLines: true, header: true, preview: 1 }); + if (isEmpty(data)) { + throw new FileValidationError(ERRORS.EMPTY_FILE, 'File is empty'); + } + + const fieldNames = Object.keys(data[0]); + + const fieldNamesNotPresent = difference(requiredFieldNames, fieldNames); + + if (!isEmpty(fieldNamesNotPresent)) { + throw new FileValidationError(ERRORS.MISSING_REQUIRED_FIELD_NAMES, `Headers missing: ${fieldNamesNotPresent}`); + } +} + +async function readCsvFile(filePath) { + try { + await access(filePath, fs.constants.F_OK); + } catch (err) { + throw new NotFoundError(`File ${filePath} not found!`); + } + + const rawData = await readFile(filePath, 'utf8'); + + return rawData.replace(/^\uFEFF/, ''); +} + +async function parseCsv(filePath, options) { + const cleanedData = await readCsvFile(filePath); + return parseCsvData(cleanedData, options); +} + +async function parseCsvData(cleanedData, options) { + const { data } = papa.parse(cleanedData, options); + return data; +} + +function parseCsvWithHeader(filePath, options = optionsWithHeader) { + return parseCsv(filePath, options); +} + +async function parseCsvWithHeaderAndRequiredFields({ filePath, requiredFieldNames }) { + const csvData = []; + + const stepFunction = (results, parser) => { + requiredFieldNames.forEach((requiredFieldName) => { + if (!results.data[requiredFieldName]) { + parser.abort(); + throw new FileValidationError( + ERRORS.MISSING_REQUIRED_FIELD_VALUES, + `Field values are required for ${requiredFieldName}` + ); + } + }); + csvData.push(results.data); + }; + const options = { ...optionsWithHeader, step: stepFunction }; + + await parseCsv(filePath, options); + + return csvData; +} + +export { + checkCsvHeader, + readCsvFile, + parseCsvData, + parseCsv, + parseCsvWithHeader, + parseCsvWithHeaderAndRequiredFields, + optionsWithHeader, +}; diff --git a/api/lib/application/certification-centers/index.js b/api/lib/application/certification-centers/index.js index 5bc0f53eb09..03adfc1e20e 100644 --- a/api/lib/application/certification-centers/index.js +++ b/api/lib/application/certification-centers/index.js @@ -1,9 +1,9 @@ -const certificationCenterController = require('./certification-center-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const Joi = require('joi'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { certificationCenterController } from './certification-center-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import Joi from 'joi'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { const adminRoutes = [ { method: 'POST', @@ -458,4 +458,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'certification-centers-api'; +const name = 'certification-centers-api'; +export { register, name }; diff --git a/api/lib/application/certification-courses/certification-course-controller.js b/api/lib/application/certification-courses/certification-course-controller.js index 562bb8fd975..815fc32b544 100644 --- a/api/lib/application/certification-courses/certification-course-controller.js +++ b/api/lib/application/certification-courses/certification-course-controller.js @@ -1,107 +1,122 @@ -const certificationDetailsSerializer = require('../../infrastructure/serializers/jsonapi/certification-details-serializer.js'); -const certificationSerializer = require('../../infrastructure/serializers/jsonapi/certification-serializer.js'); -const juryCertificationSerializer = require('../../infrastructure/serializers/jsonapi/jury-certification-serializer.js'); -const certificationCourseSerializer = require('../../infrastructure/serializers/jsonapi/certification-course-serializer.js'); -const certifiedProfileRepository = require('../../infrastructure/repositories/certified-profile-repository.js'); -const certifiedProfileSerializer = require('../../infrastructure/serializers/jsonapi/certified-profile-serializer.js'); -const usecases = require('../../domain/usecases/index.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); - -const AssessmentResult = require('../../domain/models/AssessmentResult.js'); -const CompetenceMark = require('../../domain/models/CompetenceMark.js'); -const assessmentResultService = require('../../domain/services/assessment-result-service.js'); - -const { extractLocaleFromRequest } = require('../../infrastructure/utils/request-response-utils.js'); - -module.exports = { - async getCertificationDetails(request, h, dependencies = { certificationDetailsSerializer }) { - const certificationCourseId = request.params.id; - const certificationDetails = await usecases.getCertificationDetails({ certificationCourseId }); - - return dependencies.certificationDetailsSerializer.serialize(certificationDetails); - }, - - async getJuryCertification(request, h, dependencies = { juryCertificationSerializer }) { - const certificationCourseId = request.params.id; - const juryCertification = await usecases.getJuryCertification({ certificationCourseId }); - return dependencies.juryCertificationSerializer.serialize(juryCertification); - }, - - async update(request, h, dependencies = { certificationSerializer }) { - const certificationCourseId = request.params.id; - const userId = request.auth.credentials.userId; - const command = await dependencies.certificationSerializer.deserializeCertificationCandidateModificationCommand( - request.payload, - certificationCourseId, - userId - ); - await usecases.correctCandidateIdentityInCertificationCourse({ command }); - const updatedCertificationCourse = await usecases.getCertificationCourse({ - certificationCourseId: command.certificationCourseId, - }); - return dependencies.certificationSerializer.serializeFromCertificationCourse(updatedCertificationCourse); - }, - - async save(request, h, dependencies = { extractLocaleFromRequest, certificationCourseSerializer }) { - const userId = request.auth.credentials.userId; - const accessCode = request.payload.data.attributes['access-code']; - const sessionId = request.payload.data.attributes['session-id']; - const locale = dependencies.extractLocaleFromRequest(request); - - const { created, certificationCourse } = await DomainTransaction.execute((domainTransaction) => { - return usecases.retrieveLastOrCreateCertificationCourse({ - domainTransaction, - sessionId, - accessCode, - userId, - locale, - }); - }); +import * as certificationDetailsSerializer from '../../infrastructure/serializers/jsonapi/certification-details-serializer.js'; +import * as certificationSerializer from '../../infrastructure/serializers/jsonapi/certification-serializer.js'; +import * as juryCertificationSerializer from '../../infrastructure/serializers/jsonapi/jury-certification-serializer.js'; +import * as certificationCourseSerializer from '../../infrastructure/serializers/jsonapi/certification-course-serializer.js'; +import * as certifiedProfileRepository from '../../infrastructure/repositories/certified-profile-repository.js'; +import * as certifiedProfileSerializer from '../../infrastructure/serializers/jsonapi/certified-profile-serializer.js'; +import { usecases } from '../../domain/usecases/index.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import { AssessmentResult } from '../../domain/models/AssessmentResult.js'; +import { CompetenceMark } from '../../domain/models/CompetenceMark.js'; +import * as assessmentResultService from '../../domain/services/assessment-result-service.js'; + +import { extractLocaleFromRequest } from '../../infrastructure/utils/request-response-utils.js'; + +const getCertificationDetails = async function (request, h, dependencies = { certificationDetailsSerializer }) { + const certificationCourseId = request.params.id; + const certificationDetails = await usecases.getCertificationDetails({ certificationCourseId }); + + return dependencies.certificationDetailsSerializer.serialize(certificationDetails); +}; - const serialized = await dependencies.certificationCourseSerializer.serialize(certificationCourse); - - return created ? h.response(serialized).created() : serialized; - }, - - async get(request, h, dependencies = { certificationCourseSerializer }) { - const certificationCourseId = request.params.id; - const certificationCourse = await usecases.getCertificationCourse({ certificationCourseId }); - return dependencies.certificationCourseSerializer.serialize(certificationCourse); - }, - - async getCertifiedProfile(request, h, dependencies = { certifiedProfileRepository, certifiedProfileSerializer }) { - const certificationCourseId = request.params.id; - const certifiedProfile = await dependencies.certifiedProfileRepository.get(certificationCourseId); - return dependencies.certifiedProfileSerializer.serialize(certifiedProfile); - }, - - async cancel(request, h) { - const certificationCourseId = request.params.id; - await usecases.cancelCertificationCourse({ certificationCourseId }); - return h.response().code(200); - }, - - async uncancel(request, h) { - const certificationCourseId = request.params.id; - await usecases.uncancelCertificationCourse({ certificationCourseId }); - return h.response().code(200); - }, - - async saveAssessmentResult(request, h, dependencies = { assessmentResultService }) { - const jsonResult = request.payload.data.attributes; - const certificationCourseId = request.params.id; - const { assessmentResult, competenceMarks } = _deserializeResultsAdd(jsonResult); - const juryId = request.auth.credentials.userId; - // FIXME (re)calculate partner certifications which may be invalidated/validated - await dependencies.assessmentResultService.save({ - certificationCourseId, - assessmentResult: { ...assessmentResult, juryId }, - competenceMarks, +const getJuryCertification = async function (request, h, dependencies = { juryCertificationSerializer }) { + const certificationCourseId = request.params.id; + const juryCertification = await usecases.getJuryCertification({ certificationCourseId }); + return dependencies.juryCertificationSerializer.serialize(juryCertification); +}; + +const update = async function (request, h, dependencies = { certificationSerializer }) { + const certificationCourseId = request.params.id; + const userId = request.auth.credentials.userId; + const command = await dependencies.certificationSerializer.deserializeCertificationCandidateModificationCommand( + request.payload, + certificationCourseId, + userId + ); + await usecases.correctCandidateIdentityInCertificationCourse({ command }); + const updatedCertificationCourse = await usecases.getCertificationCourse({ + certificationCourseId: command.certificationCourseId, + }); + return dependencies.certificationSerializer.serializeFromCertificationCourse(updatedCertificationCourse); +}; + +const save = async function (request, h, dependencies = { extractLocaleFromRequest, certificationCourseSerializer }) { + const userId = request.auth.credentials.userId; + const accessCode = request.payload.data.attributes['access-code']; + const sessionId = request.payload.data.attributes['session-id']; + const locale = dependencies.extractLocaleFromRequest(request); + + const { created, certificationCourse } = await DomainTransaction.execute((domainTransaction) => { + return usecases.retrieveLastOrCreateCertificationCourse({ + domainTransaction, + sessionId, + accessCode, + userId, + locale, }); - return null; - }, + }); + + const serialized = await dependencies.certificationCourseSerializer.serialize(certificationCourse); + + return created ? h.response(serialized).created() : serialized; +}; + +const get = async function (request, h, dependencies = { certificationCourseSerializer }) { + const certificationCourseId = request.params.id; + const certificationCourse = await usecases.getCertificationCourse({ certificationCourseId }); + return dependencies.certificationCourseSerializer.serialize(certificationCourse); }; +const getCertifiedProfile = async function ( + request, + h, + dependencies = { certifiedProfileRepository, certifiedProfileSerializer } +) { + const certificationCourseId = request.params.id; + const certifiedProfile = await dependencies.certifiedProfileRepository.get(certificationCourseId); + return dependencies.certifiedProfileSerializer.serialize(certifiedProfile); +}; + +const cancel = async function (request, h) { + const certificationCourseId = request.params.id; + await usecases.cancelCertificationCourse({ certificationCourseId }); + return h.response().code(200); +}; + +const uncancel = async function (request, h) { + const certificationCourseId = request.params.id; + await usecases.uncancelCertificationCourse({ certificationCourseId }); + return h.response().code(200); +}; + +const saveAssessmentResult = async function (request, h, dependencies = { assessmentResultService }) { + const jsonResult = request.payload.data.attributes; + const certificationCourseId = request.params.id; + const { assessmentResult, competenceMarks } = _deserializeResultsAdd(jsonResult); + const juryId = request.auth.credentials.userId; + // FIXME (re)calculate partner certifications which may be invalidated/validated + await dependencies.assessmentResultService.save({ + certificationCourseId, + assessmentResult: { ...assessmentResult, juryId }, + competenceMarks, + }); + return null; +}; + +const certificationCourseController = { + getCertificationDetails, + getJuryCertification, + update, + save, + get, + getCertifiedProfile, + cancel, + uncancel, + saveAssessmentResult, +}; + +export { certificationCourseController }; + // TODO: Should be removed and replaced by a real serializer function _deserializeResultsAdd(json) { const assessmentResult = new AssessmentResult({ diff --git a/api/lib/application/certification-courses/index.js b/api/lib/application/certification-courses/index.js index 7d104c45c08..13971eb79ee 100644 --- a/api/lib/application/certification-courses/index.js +++ b/api/lib/application/certification-courses/index.js @@ -1,11 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const securityPreHandlers = require('../security-pre-handlers.js'); -const certificationCourseController = require('./certification-course-controller.js'); +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { certificationCourseController } from './certification-course-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -const identifiersType = require('../../domain/types/identifiers-type.js'); - -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -225,4 +224,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'certification-courses-api'; +const name = 'certification-courses-api'; +export { register, name }; diff --git a/api/lib/application/certification-issue-reports/certification-issue-report-controller.js b/api/lib/application/certification-issue-reports/certification-issue-report-controller.js index cf5ce09e6f4..a89453bc8ed 100644 --- a/api/lib/application/certification-issue-reports/certification-issue-report-controller.js +++ b/api/lib/application/certification-issue-reports/certification-issue-report-controller.js @@ -1,21 +1,23 @@ -const usecases = require('../../domain/usecases/index.js'); +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async deleteCertificationIssueReport(request) { - const certificationIssueReportId = request.params.id; - await usecases.deleteCertificationIssueReport({ certificationIssueReportId }); +const deleteCertificationIssueReport = async function (request) { + const certificationIssueReportId = request.params.id; + await usecases.deleteCertificationIssueReport({ certificationIssueReportId }); - return null; - }, + return null; +}; - async manuallyResolve(request, h) { - const certificationIssueReportId = request.params.id; - const resolution = request.payload.data.resolution; - await usecases.manuallyResolveCertificationIssueReport({ - certificationIssueReportId, - resolution, - }); +const manuallyResolve = async function (request, h) { + const certificationIssueReportId = request.params.id; + const resolution = request.payload.data.resolution; + await usecases.manuallyResolveCertificationIssueReport({ + certificationIssueReportId, + resolution, + }); - return h.response().code(204); - }, + return h.response().code(204); }; + +const certificationIssueReportController = { deleteCertificationIssueReport, manuallyResolve }; + +export { certificationIssueReportController }; diff --git a/api/lib/application/certification-issue-reports/index.js b/api/lib/application/certification-issue-reports/index.js index e74ae48eb50..a9104e68df6 100644 --- a/api/lib/application/certification-issue-reports/index.js +++ b/api/lib/application/certification-issue-reports/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); -const certificationIssueReportController = require('./certification-issue-report-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import Joi from 'joi'; +import { certificationIssueReportController } from './certification-issue-report-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'DELETE', @@ -72,4 +72,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'certification-issue-reports-api'; +const name = 'certification-issue-reports-api'; +export { register, name }; diff --git a/api/lib/application/certification-livret-scolaire/certification-controller.js b/api/lib/application/certification-livret-scolaire/certification-controller.js index e9a450b13e7..911c6260172 100644 --- a/api/lib/application/certification-livret-scolaire/certification-controller.js +++ b/api/lib/application/certification-livret-scolaire/certification-controller.js @@ -1,10 +1,12 @@ -const { getCertificationsResultsForLS } = require('../../domain/usecases/index.js'); -const certificationsResultsForLsSerializer = require('../../infrastructure/serializers/jsonapi/certifications-livret-scolaire/certification-ls-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as certificationsResultsForLsSerializer from '../../infrastructure/serializers/jsonapi/certifications-livret-scolaire/certification-ls-serializer.js'; -module.exports = { - async getCertificationsByOrganizationUAI(request) { - const uai = request.params.uai; - const certifications = await getCertificationsResultsForLS({ uai }); - return certificationsResultsForLsSerializer.serialize(certifications); - }, +const getCertificationsByOrganizationUAI = async function (request) { + const uai = request.params.uai; + const certifications = await usecases.getCertificationsResultsForLS({ uai }); + return certificationsResultsForLsSerializer.serialize(certifications); }; + +const certificationController = { getCertificationsByOrganizationUAI }; + +export { certificationController }; diff --git a/api/lib/application/certification-livret-scolaire/index.js b/api/lib/application/certification-livret-scolaire/index.js index 7be10826b9c..0a6fdd09b37 100644 --- a/api/lib/application/certification-livret-scolaire/index.js +++ b/api/lib/application/certification-livret-scolaire/index.js @@ -1,10 +1,10 @@ -const certificationController = require('./certification-controller.js'); -const Joi = require('joi'); +import { certificationController } from './certification-controller.js'; +import Joi from 'joi'; -const responseErrorObjectDoc = require('../../infrastructure/open-api-doc/livret-scolaire/response-object-error-doc.js'); -const certificationsResultsResponseDoc = require('../../infrastructure/open-api-doc/livret-scolaire/certifications-results-doc.js'); +import { responseObjectErrorDoc } from '../../infrastructure/open-api-doc/livret-scolaire/response-object-error-doc.js'; +import { certificationsResultsDoc } from '../../infrastructure/open-api-doc/livret-scolaire/certifications-results-doc.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -19,9 +19,9 @@ exports.register = async function (server) { response: { failAction: 'log', status: { - 200: certificationsResultsResponseDoc, - 204: certificationsResultsResponseDoc, - 403: responseErrorObjectDoc, + 200: certificationsResultsDoc, + 204: certificationsResultsDoc, + 403: responseObjectErrorDoc, }, }, validate: { @@ -42,4 +42,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'certifications-lsu-lsl-api'; +const name = 'certifications-lsu-lsl-api'; +export { register, name }; diff --git a/api/lib/application/certification-point-of-contacts/certification-point-of-contact-controller.js b/api/lib/application/certification-point-of-contacts/certification-point-of-contact-controller.js index 11ec752c06f..ee1d55e09ff 100644 --- a/api/lib/application/certification-point-of-contacts/certification-point-of-contact-controller.js +++ b/api/lib/application/certification-point-of-contacts/certification-point-of-contact-controller.js @@ -1,10 +1,11 @@ -const certificationPointOfContactSerializer = require('../../infrastructure/serializers/jsonapi/certification-point-of-contact-serializer.js'); -const usecases = require('../../domain/usecases/index.js'); +import * as certificationPointOfContactSerializer from '../../infrastructure/serializers/jsonapi/certification-point-of-contact-serializer.js'; +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async get(request) { - const authenticatedUserId = request.auth.credentials.userId; - const certificationPointOfContact = await usecases.getCertificationPointOfContact({ userId: authenticatedUserId }); - return certificationPointOfContactSerializer.serialize(certificationPointOfContact); - }, +const get = async function (request) { + const authenticatedUserId = request.auth.credentials.userId; + const certificationPointOfContact = await usecases.getCertificationPointOfContact({ userId: authenticatedUserId }); + return certificationPointOfContactSerializer.serialize(certificationPointOfContact); }; + +const certificationPointOfContactController = { get }; +export { certificationPointOfContactController }; diff --git a/api/lib/application/certification-point-of-contacts/index.js b/api/lib/application/certification-point-of-contacts/index.js index ba70f89f8f0..39ef19851e9 100644 --- a/api/lib/application/certification-point-of-contacts/index.js +++ b/api/lib/application/certification-point-of-contacts/index.js @@ -1,6 +1,6 @@ -const certificationPointOfContactController = require('./certification-point-of-contact-controller.js'); +import { certificationPointOfContactController } from './certification-point-of-contact-controller.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -17,4 +17,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'certification-point-of-contacts-api'; +const name = 'certification-point-of-contacts-api'; +export { register, name }; diff --git a/api/lib/application/certification-reports/certification-report-controller.js b/api/lib/application/certification-reports/certification-report-controller.js index c6a7b128d3b..fdef4ea6958 100644 --- a/api/lib/application/certification-reports/certification-report-controller.js +++ b/api/lib/application/certification-reports/certification-report-controller.js @@ -1,18 +1,20 @@ -const usecases = require('../../domain/usecases/index.js'); -const certificationIssueReportSerializer = require('../../infrastructure/serializers/jsonapi/certification-issue-report-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as certificationIssueReportSerializer from '../../infrastructure/serializers/jsonapi/certification-issue-report-serializer.js'; -module.exports = { - async saveCertificationIssueReport(request, h) { - const certificationIssueReportDTO = certificationIssueReportSerializer.deserialize(request); - const certificationIssueReportSaved = await usecases.saveCertificationIssueReport({ certificationIssueReportDTO }); +const saveCertificationIssueReport = async function (request, h) { + const certificationIssueReportDTO = certificationIssueReportSerializer.deserialize(request); + const certificationIssueReportSaved = await usecases.saveCertificationIssueReport({ certificationIssueReportDTO }); - return h.response(certificationIssueReportSerializer.serialize(certificationIssueReportSaved)).created(); - }, + return h.response(certificationIssueReportSerializer.serialize(certificationIssueReportSaved)).created(); +}; - async abort(request, h) { - const certificationCourseId = request.params.id; - const abortReason = request.payload.data.reason; - await usecases.abortCertificationCourse({ certificationCourseId, abortReason }); - return h.response().code(200); - }, +const abort = async function (request, h) { + const certificationCourseId = request.params.id; + const abortReason = request.payload.data.reason; + await usecases.abortCertificationCourse({ certificationCourseId, abortReason }); + return h.response().code(200); }; + +const certificationReportController = { saveCertificationIssueReport, abort }; + +export { certificationReportController }; diff --git a/api/lib/application/certification-reports/index.js b/api/lib/application/certification-reports/index.js index 221f8762f86..d1cd520ecef 100644 --- a/api/lib/application/certification-reports/index.js +++ b/api/lib/application/certification-reports/index.js @@ -1,10 +1,10 @@ -const Joi = require('joi'); -const certificationReportController = require('./certification-report-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const authorization = require('../preHandlers/authorization.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import Joi from 'joi'; +import { certificationReportController } from './certification-report-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { authorization } from '../preHandlers/authorization.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'POST', @@ -59,4 +59,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'certification-reports-api'; +const name = 'certification-reports-api'; +export { register, name }; diff --git a/api/lib/application/certifications/certification-controller.js b/api/lib/application/certifications/certification-controller.js index 6714add21f6..0311bb8ced7 100644 --- a/api/lib/application/certifications/certification-controller.js +++ b/api/lib/application/certifications/certification-controller.js @@ -1,85 +1,94 @@ -const usecases = require('../../domain/usecases/index.js'); -const events = require('../../domain/events/index.js'); -const privateCertificateSerializer = require('../../infrastructure/serializers/jsonapi/private-certificate-serializer.js'); -const shareableCertificateSerializer = require('../../infrastructure/serializers/jsonapi/shareable-certificate-serializer.js'); -const certificationAttestationPdf = require('../../infrastructure/utils/pdf/certification-attestation-pdf.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as events from '../../domain/events/index.js'; +import * as privateCertificateSerializer from '../../infrastructure/serializers/jsonapi/private-certificate-serializer.js'; +import * as shareableCertificateSerializer from '../../infrastructure/serializers/jsonapi/shareable-certificate-serializer.js'; +import * as certificationAttestationPdf from '../../infrastructure/utils/pdf/certification-attestation-pdf.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; -const moment = require('moment'); +import moment from 'moment'; -module.exports = { - async findUserCertifications(request) { - const userId = request.auth.credentials.userId; +const findUserCertifications = async function (request) { + const userId = request.auth.credentials.userId; - const privateCertificates = await usecases.findUserPrivateCertificates({ userId }); - return privateCertificateSerializer.serialize(privateCertificates); - }, + const privateCertificates = await usecases.findUserPrivateCertificates({ userId }); + return privateCertificateSerializer.serialize(privateCertificates); +}; + +const getCertification = async function (request, h, dependencies = { requestResponseUtils }) { + const userId = request.auth.credentials.userId; + const certificationId = request.params.id; + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - async getCertification(request, h, dependencies = { requestResponseUtils }) { - const userId = request.auth.credentials.userId; - const certificationId = request.params.id; - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const privateCertificate = await usecases.getPrivateCertificate({ + userId, + certificationId, + locale, + }); + return privateCertificateSerializer.serialize(privateCertificate); +}; - const privateCertificate = await usecases.getPrivateCertificate({ - userId, - certificationId, - locale, - }); - return privateCertificateSerializer.serialize(privateCertificate); - }, +const getCertificationByVerificationCode = async function (request, h, dependencies = { requestResponseUtils }) { + const verificationCode = request.payload.verificationCode; + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - async getCertificationByVerificationCode(request, h, dependencies = { requestResponseUtils }) { - const verificationCode = request.payload.verificationCode; - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const shareableCertificate = await usecases.getShareableCertificate({ verificationCode, locale }); + return shareableCertificateSerializer.serialize(shareableCertificate); +}; - const shareableCertificate = await usecases.getShareableCertificate({ verificationCode, locale }); - return shareableCertificateSerializer.serialize(shareableCertificate); - }, +const getPDFAttestation = async function (request, h, dependencies = { certificationAttestationPdf }) { + const userId = request.auth.credentials.userId; + const certificationId = request.params.id; + const isFrenchDomainExtension = request.query.isFrenchDomainExtension; + const attestation = await usecases.getCertificationAttestation({ + userId, + certificationId, + }); - async getPDFAttestation(request, h, dependencies = { certificationAttestationPdf }) { - const userId = request.auth.credentials.userId; - const certificationId = request.params.id; - const isFrenchDomainExtension = request.query.isFrenchDomainExtension; - const attestation = await usecases.getCertificationAttestation({ - userId, - certificationId, - }); + const { buffer } = await dependencies.certificationAttestationPdf.getCertificationAttestationsPdfBuffer({ + certificates: [attestation], + isFrenchDomainExtension, + }); - const { buffer } = await dependencies.certificationAttestationPdf.getCertificationAttestationsPdfBuffer({ - certificates: [attestation], - isFrenchDomainExtension, - }); + const fileName = `attestation-pix-${moment(attestation.deliveredAt).format('YYYYMMDD')}.pdf`; + return h + .response(buffer) + .header('Content-Disposition', `attachment; filename=${fileName}`) + .header('Content-Type', 'application/pdf'); +}; - const fileName = `attestation-pix-${moment(attestation.deliveredAt).format('YYYYMMDD')}.pdf`; - return h - .response(buffer) - .header('Content-Disposition', `attachment; filename=${fileName}`) - .header('Content-Type', 'application/pdf'); - }, +const neutralizeChallenge = async function (request, h, dependencies = { events }) { + const challengeRecId = request.payload.data.attributes.challengeRecId; + const certificationCourseId = request.payload.data.attributes.certificationCourseId; + const juryId = request.auth.credentials.userId; + const event = await usecases.neutralizeChallenge({ + challengeRecId, + certificationCourseId, + juryId, + }); + await dependencies.events.eventDispatcher.dispatch(event); + return h.response().code(204); +}; - async neutralizeChallenge(request, h, dependencies = { events }) { - const challengeRecId = request.payload.data.attributes.challengeRecId; - const certificationCourseId = request.payload.data.attributes.certificationCourseId; - const juryId = request.auth.credentials.userId; - const event = await usecases.neutralizeChallenge({ - challengeRecId, - certificationCourseId, - juryId, - }); - await dependencies.events.eventDispatcher.dispatch(event); - return h.response().code(204); - }, +const deneutralizeChallenge = async function (request, h, dependencies = { events }) { + const challengeRecId = request.payload.data.attributes.challengeRecId; + const certificationCourseId = request.payload.data.attributes.certificationCourseId; + const juryId = request.auth.credentials.userId; + const event = await usecases.deneutralizeChallenge({ + challengeRecId, + certificationCourseId, + juryId, + }); + await dependencies.events.eventDispatcher.dispatch(event); + return h.response().code(204); +}; - async deneutralizeChallenge(request, h, dependencies = { events }) { - const challengeRecId = request.payload.data.attributes.challengeRecId; - const certificationCourseId = request.payload.data.attributes.certificationCourseId; - const juryId = request.auth.credentials.userId; - const event = await usecases.deneutralizeChallenge({ - challengeRecId, - certificationCourseId, - juryId, - }); - await dependencies.events.eventDispatcher.dispatch(event); - return h.response().code(204); - }, +const certificationController = { + findUserCertifications, + getCertification, + getCertificationByVerificationCode, + getPDFAttestation, + neutralizeChallenge, + deneutralizeChallenge, }; + +export { certificationController }; diff --git a/api/lib/application/certifications/index.js b/api/lib/application/certifications/index.js index fc057293bcf..fb2670cdde6 100644 --- a/api/lib/application/certifications/index.js +++ b/api/lib/application/certifications/index.js @@ -1,10 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const certificationController = require('./certification-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import { certificationController } from './certification-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -137,4 +137,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'certifications-api'; +const name = 'certifications-api'; +export { register, name }; diff --git a/api/lib/application/challenges/challenge-controller.js b/api/lib/application/challenges/challenge-controller.js index fda0c1831b1..134af81cefa 100644 --- a/api/lib/application/challenges/challenge-controller.js +++ b/api/lib/application/challenges/challenge-controller.js @@ -1,9 +1,11 @@ -const challengeRepository = require('../../infrastructure/repositories/challenge-repository.js'); -const challengeSerializer = require('../../infrastructure/serializers/jsonapi/challenge-serializer.js'); +import * as challengeRepository from '../../infrastructure/repositories/challenge-repository.js'; +import * as challengeSerializer from '../../infrastructure/serializers/jsonapi/challenge-serializer.js'; -module.exports = { - async get(request, h, dependencies = { challengeRepository, challengeSerializer }) { - const challenge = await dependencies.challengeRepository.get(request.params.id); - return dependencies.challengeSerializer.serialize(challenge); - }, +const get = async function (request, h, dependencies = { challengeRepository, challengeSerializer }) { + const challenge = await dependencies.challengeRepository.get(request.params.id); + return dependencies.challengeSerializer.serialize(challenge); }; + +const challengeController = { get }; + +export { challengeController }; diff --git a/api/lib/application/challenges/index.js b/api/lib/application/challenges/index.js index ed4e68c5f0f..09fdf79a7a0 100644 --- a/api/lib/application/challenges/index.js +++ b/api/lib/application/challenges/index.js @@ -1,10 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const challengeController = require('./challenge-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const securityPreHandlers = require('../security-pre-handlers'); +import { challengeController } from './challenge-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -38,4 +38,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'challenges-api'; +const name = 'challenges-api'; +export { register, name }; diff --git a/api/lib/application/competence-evaluations/competence-evaluation-controller.js b/api/lib/application/competence-evaluations/competence-evaluation-controller.js index 2067cb01ca4..07d4b9b59ce 100644 --- a/api/lib/application/competence-evaluations/competence-evaluation-controller.js +++ b/api/lib/application/competence-evaluations/competence-evaluation-controller.js @@ -1,35 +1,37 @@ -const usecases = require('../../domain/usecases/index.js'); -const competenceEvaluationSerializer = require('../../infrastructure/serializers/jsonapi/competence-evaluation-serializer.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as competenceEvaluationSerializer from '../../infrastructure/serializers/jsonapi/competence-evaluation-serializer.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; -module.exports = { - async startOrResume(request, h, dependencies = { competenceEvaluationSerializer }) { - const userId = request.auth.credentials.userId; - const competenceId = request.payload.competenceId; +const startOrResume = async function (request, h, dependencies = { competenceEvaluationSerializer }) { + const userId = request.auth.credentials.userId; + const competenceId = request.payload.competenceId; - const { competenceEvaluation, created } = await usecases.startOrResumeCompetenceEvaluation({ + const { competenceEvaluation, created } = await usecases.startOrResumeCompetenceEvaluation({ + competenceId, + userId, + }); + const serializedCompetenceEvaluation = dependencies.competenceEvaluationSerializer.serialize(competenceEvaluation); + + return created ? h.response(serializedCompetenceEvaluation).created() : serializedCompetenceEvaluation; +}; + +const improve = async function (request, h, dependencies = { competenceEvaluationSerializer }) { + const userId = request.auth.credentials.userId; + const competenceId = request.payload.competenceId; + + const competenceEvaluation = await DomainTransaction.execute(async (domainTransaction) => { + const competenceEvaluation = await usecases.improveCompetenceEvaluation({ competenceId, userId, + domainTransaction, }); - const serializedCompetenceEvaluation = dependencies.competenceEvaluationSerializer.serialize(competenceEvaluation); - - return created ? h.response(serializedCompetenceEvaluation).created() : serializedCompetenceEvaluation; - }, - - async improve(request, h, dependencies = { competenceEvaluationSerializer }) { - const userId = request.auth.credentials.userId; - const competenceId = request.payload.competenceId; - - const competenceEvaluation = await DomainTransaction.execute(async (domainTransaction) => { - const competenceEvaluation = await usecases.improveCompetenceEvaluation({ - competenceId, - userId, - domainTransaction, - }); - return competenceEvaluation; - }); + return competenceEvaluation; + }); - const serializedCompetenceEvaluation = dependencies.competenceEvaluationSerializer.serialize(competenceEvaluation); - return h.response(serializedCompetenceEvaluation); - }, + const serializedCompetenceEvaluation = dependencies.competenceEvaluationSerializer.serialize(competenceEvaluation); + return h.response(serializedCompetenceEvaluation); }; + +const competenceEvaluationController = { startOrResume, improve }; + +export { competenceEvaluationController }; diff --git a/api/lib/application/competence-evaluations/index.js b/api/lib/application/competence-evaluations/index.js index 11b7418151b..61e4c228a11 100644 --- a/api/lib/application/competence-evaluations/index.js +++ b/api/lib/application/competence-evaluations/index.js @@ -1,6 +1,6 @@ -const competenceEvaluationController = require('./competence-evaluation-controller.js'); +import { competenceEvaluationController } from './competence-evaluation-controller.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -30,4 +30,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'competence-evaluations-api'; +const name = 'competence-evaluations-api'; +export { register, name }; diff --git a/api/lib/application/complementary-certification-course-results/complementary-certification-course-results-controller.js b/api/lib/application/complementary-certification-course-results/complementary-certification-course-results-controller.js index 041f111372e..214ac464050 100644 --- a/api/lib/application/complementary-certification-course-results/complementary-certification-course-results-controller.js +++ b/api/lib/application/complementary-certification-course-results/complementary-certification-course-results-controller.js @@ -1,13 +1,14 @@ -const usecases = require('../../domain/usecases/index.js'); +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async saveJuryComplementaryCertificationCourseResult(request, h) { - const { complementaryCertificationCourseId, juryLevel } = request.payload.data.attributes; +const saveJuryComplementaryCertificationCourseResult = async function (request, h) { + const { complementaryCertificationCourseId, juryLevel } = request.payload.data.attributes; - await usecases.saveJuryComplementaryCertificationCourseResult({ - complementaryCertificationCourseId, - juryLevel, - }); - return h.response().code(200); - }, + await usecases.saveJuryComplementaryCertificationCourseResult({ + complementaryCertificationCourseId, + juryLevel, + }); + return h.response().code(200); }; + +const complementaryCertificationCourseResultsController = { saveJuryComplementaryCertificationCourseResult }; +export { complementaryCertificationCourseResultsController }; diff --git a/api/lib/application/complementary-certification-course-results/index.js b/api/lib/application/complementary-certification-course-results/index.js index ef6f65ac2b4..90a2a3d73b7 100644 --- a/api/lib/application/complementary-certification-course-results/index.js +++ b/api/lib/application/complementary-certification-course-results/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const complementaryCertificationCourseResultsController = require('./complementary-certification-course-results-controller.js'); +import Joi from 'joi'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { complementaryCertificationCourseResultsController } from './complementary-certification-course-results-controller.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -41,4 +41,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'complementary-certification-course-results-api'; +const name = 'complementary-certification-course-results-api'; +export { register, name }; diff --git a/api/lib/application/complementary-certifications/complementary-certification-controller.js b/api/lib/application/complementary-certifications/complementary-certification-controller.js index b05f410b7ae..be6a822c1ef 100644 --- a/api/lib/application/complementary-certifications/complementary-certification-controller.js +++ b/api/lib/application/complementary-certifications/complementary-certification-controller.js @@ -1,9 +1,10 @@ -const usecases = require('../../domain/usecases/index.js'); -const complementaryCertificationSerializer = require('../../infrastructure/serializers/jsonapi/complementary-certification-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as complementaryCertificationSerializer from '../../infrastructure/serializers/jsonapi/complementary-certification-serializer.js'; -module.exports = { - async findComplementaryCertifications() { - const complementaryCertifications = await usecases.findComplementaryCertifications(); - return complementaryCertificationSerializer.serialize(complementaryCertifications); - }, +const findComplementaryCertifications = async function () { + const complementaryCertifications = await usecases.findComplementaryCertifications(); + return complementaryCertificationSerializer.serialize(complementaryCertifications); }; + +const complementaryCertificationController = { findComplementaryCertifications }; +export { complementaryCertificationController }; diff --git a/api/lib/application/complementary-certifications/index.js b/api/lib/application/complementary-certifications/index.js index c761c67d572..4a985ecff17 100644 --- a/api/lib/application/complementary-certifications/index.js +++ b/api/lib/application/complementary-certifications/index.js @@ -1,7 +1,7 @@ -const complementaryCertificationController = require('./complementary-certification-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import { complementaryCertificationController } from './complementary-certification-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -30,4 +30,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'complementary-certifications-api'; +const name = 'complementary-certifications-api'; +export { register, name }; diff --git a/api/lib/application/countries/country-controller.js b/api/lib/application/countries/country-controller.js index 2426de38548..d17fbe0fd46 100644 --- a/api/lib/application/countries/country-controller.js +++ b/api/lib/application/countries/country-controller.js @@ -1,9 +1,10 @@ -const usecases = require('../../domain/usecases/index.js'); -const countrySerializer = require('../../infrastructure/serializers/jsonapi/country-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as countrySerializer from '../../infrastructure/serializers/jsonapi/country-serializer.js'; -module.exports = { - async findCountries(_request, _h, dependencies = { countrySerializer }) { - const countries = await usecases.findCountries(); - return dependencies.countrySerializer.serialize(countries); - }, +const findCountries = async function (_request, _h, dependencies = { countrySerializer }) { + const countries = await usecases.findCountries(); + return dependencies.countrySerializer.serialize(countries); }; + +const countryController = { findCountries }; +export { countryController }; diff --git a/api/lib/application/countries/index.js b/api/lib/application/countries/index.js index d8c8a8993b5..ddf137dd187 100644 --- a/api/lib/application/countries/index.js +++ b/api/lib/application/countries/index.js @@ -1,6 +1,6 @@ -const countryController = require('./country-controller.js'); +import { countryController } from './country-controller.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -17,4 +17,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'certification-cpf-countries'; +const name = 'certification-cpf-countries'; +export { register, name }; diff --git a/api/lib/application/courses/course-controller.js b/api/lib/application/courses/course-controller.js index afeaa43d74f..d7e1c80276c 100644 --- a/api/lib/application/courses/course-controller.js +++ b/api/lib/application/courses/course-controller.js @@ -1,12 +1,14 @@ -const courseSerializer = require('../../infrastructure/serializers/jsonapi/course-serializer.js'); -const courseService = require('../../../lib/domain/services/course-service.js'); -const { extractUserIdFromRequest } = require('../../infrastructure/utils/request-response-utils.js'); +import * as courseSerializer from '../../infrastructure/serializers/jsonapi/course-serializer.js'; +import * as courseService from '../../../lib/domain/services/course-service.js'; +import { extractUserIdFromRequest } from '../../infrastructure/utils/request-response-utils.js'; -module.exports = { - get(request, h, dependencies = { courseService, courseSerializer }) { - const courseId = request.params.id; - const userId = extractUserIdFromRequest(request); +const get = function (request, h, dependencies = { courseService, courseSerializer }) { + const courseId = request.params.id; + const userId = extractUserIdFromRequest(request); - return dependencies.courseService.getCourse({ courseId, userId }).then(dependencies.courseSerializer.serialize); - }, + return dependencies.courseService.getCourse({ courseId, userId }).then(dependencies.courseSerializer.serialize); }; + +const courseController = { get }; + +export { courseController }; diff --git a/api/lib/application/courses/index.js b/api/lib/application/courses/index.js index aa2f7436dc9..0788373361f 100644 --- a/api/lib/application/courses/index.js +++ b/api/lib/application/courses/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const courseController = require('./course-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { courseController } from './course-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -22,4 +22,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'courses-api'; +const name = 'courses-api'; +export { register, name }; diff --git a/api/lib/application/error-manager.js b/api/lib/application/error-manager.js index c4df38a4bda..09646df5866 100644 --- a/api/lib/application/error-manager.js +++ b/api/lib/application/error-manager.js @@ -1,15 +1,19 @@ -const _ = require('lodash'); -const JSONAPIError = require('jsonapi-serializer').Error; -const { HttpErrors } = require('./http-errors.js'); -const DomainErrors = require('../domain/errors.js'); -const errorSerializer = require('../infrastructure/serializers/jsonapi/error-serializer.js'); -const { extractLocaleFromRequest } = require('../infrastructure/utils/request-response-utils.js'); -const translations = require('../../translations/index.js'); +import _ from 'lodash'; +import jsonapiSerializer from 'jsonapi-serializer'; +const { Error: JSONAPIError } = jsonapiSerializer; + +import { HttpErrors } from './http-errors.js'; +import * as DomainErrors from '../domain/errors.js'; +import * as errorSerializer from '../infrastructure/serializers/jsonapi/error-serializer.js'; +import { extractLocaleFromRequest } from '../infrastructure/utils/request-response-utils.js'; +import * as translations from '../../translations/index.js'; const NOT_VALID_RELATIONSHIPS = ['externalId', 'participantExternalId']; function translateMessage(locale, key) { + // eslint-disable-next-line import/namespace if (translations[locale]['entity-validation-errors'][key]) { + // eslint-disable-next-line import/namespace return translations[locale]['entity-validation-errors'][key]; } return key; @@ -524,4 +528,4 @@ function handle(request, h, error) { return h.response(errorSerializer.serialize(httpError)).code(httpError.status); } -module.exports = { handle }; +export { handle }; diff --git a/api/lib/application/feature-toggles/feature-toggle-controller.js b/api/lib/application/feature-toggles/feature-toggle-controller.js index dcad6e7328b..a48b66c15f8 100644 --- a/api/lib/application/feature-toggles/feature-toggle-controller.js +++ b/api/lib/application/feature-toggles/feature-toggle-controller.js @@ -1,8 +1,10 @@ -const settings = require('../../config.js'); -const serializer = require('../../infrastructure/serializers/jsonapi/feature-toggle-serializer.js'); +import { config } from '../../config.js'; +import * as serializer from '../../infrastructure/serializers/jsonapi/feature-toggle-serializer.js'; -module.exports = { - getActiveFeatures() { - return serializer.serialize(settings.featureToggles); - }, +const getActiveFeatures = function () { + return serializer.serialize(config.featureToggles); }; + +const featureToggleController = { getActiveFeatures }; + +export { featureToggleController }; diff --git a/api/lib/application/feature-toggles/index.js b/api/lib/application/feature-toggles/index.js index 54a3d2f2bdc..859d65a2526 100644 --- a/api/lib/application/feature-toggles/index.js +++ b/api/lib/application/feature-toggles/index.js @@ -1,6 +1,6 @@ -const featureToggleController = require('./feature-toggle-controller.js'); +import { featureToggleController } from './feature-toggle-controller.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'GET', @@ -14,4 +14,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'feature-toggles-api'; +const name = 'feature-toggles-api'; +export { register, name }; diff --git a/api/lib/application/feedbacks/feedback-controller.js b/api/lib/application/feedbacks/feedback-controller.js index b2fd41e1067..b46df9783c2 100644 --- a/api/lib/application/feedbacks/feedback-controller.js +++ b/api/lib/application/feedbacks/feedback-controller.js @@ -1,18 +1,19 @@ -const { BadRequestError } = require('../http-errors.js'); -const _ = require('../../infrastructure/utils/lodash-utils.js'); -const serializer = require('../../infrastructure/serializers/jsonapi/feedback-serializer.js'); +import { BadRequestError } from '../http-errors.js'; +import { _ } from '../../infrastructure/utils/lodash-utils.js'; +import * as serializer from '../../infrastructure/serializers/jsonapi/feedback-serializer.js'; -module.exports = { - async save(request, h) { - const newUserAgent = request.headers['user-agent'].slice(0, 255); - const feedback = await serializer.deserialize(request.payload, newUserAgent); +const save = async function (request, h) { + const newUserAgent = request.headers['user-agent'].slice(0, 255); + const feedback = await serializer.deserialize(request.payload, newUserAgent); - if (_.isBlank(feedback.get('content'))) { - throw new BadRequestError('Feedback content must not be blank'); - } + if (_.isBlank(feedback.get('content'))) { + throw new BadRequestError('Feedback content must not be blank'); + } - const persistedFeedback = await feedback.save(); + const persistedFeedback = await feedback.save(); - return h.response(serializer.serialize(persistedFeedback.toJSON())).created(); - }, + return h.response(serializer.serialize(persistedFeedback.toJSON())).created(); }; + +const feedbackController = { save }; +export { feedbackController }; diff --git a/api/lib/application/feedbacks/index.js b/api/lib/application/feedbacks/index.js index 0796b9f8291..9c4e4cd200a 100644 --- a/api/lib/application/feedbacks/index.js +++ b/api/lib/application/feedbacks/index.js @@ -1,8 +1,8 @@ -const feedbackController = require('./feedback-controller.js'); -const Joi = require('joi'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { feedbackController } from './feedback-controller.js'; +import Joi from 'joi'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'POST', @@ -46,4 +46,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'feedbacks-api'; +const name = 'feedbacks-api'; +export { register, name }; diff --git a/api/lib/application/frameworks/frameworks-controller.js b/api/lib/application/frameworks/frameworks-controller.js index a4b450e896c..59518c4f596 100644 --- a/api/lib/application/frameworks/frameworks-controller.js +++ b/api/lib/application/frameworks/frameworks-controller.js @@ -1,37 +1,44 @@ -const usecases = require('../../domain/usecases/index.js'); -const frameworkAreasSerializer = require('../../infrastructure/serializers/jsonapi/framework-areas-serializer.js'); -const frameworkSerializer = require('../../infrastructure/serializers/jsonapi/framework-serializer.js'); -const { extractLocaleFromRequest } = require('../../infrastructure/utils/request-response-utils.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as frameworkAreasSerializer from '../../infrastructure/serializers/jsonapi/framework-areas-serializer.js'; +import * as frameworkSerializer from '../../infrastructure/serializers/jsonapi/framework-serializer.js'; +import { extractLocaleFromRequest } from '../../infrastructure/utils/request-response-utils.js'; -module.exports = { - async getFrameworks(request, h, dependencies = { frameworkSerializer }) { - const frameworks = await usecases.getFrameworks(); - return dependencies.frameworkSerializer.serialize(frameworks); - }, +const getFrameworks = async function (request, h, dependencies = { frameworkSerializer }) { + const frameworks = await usecases.getFrameworks(); + return dependencies.frameworkSerializer.serialize(frameworks); +}; + +const getFrameworkAreas = async function (request, h, dependencies = { frameworkAreasSerializer }) { + const frameworkId = request.params.id; + const framework = await usecases.getFrameworkAreas({ frameworkId }); + return dependencies.frameworkAreasSerializer.serialize(framework); +}; - async getFrameworkAreas(request, h, dependencies = { frameworkAreasSerializer }) { - const frameworkId = request.params.id; - const framework = await usecases.getFrameworkAreas({ frameworkId }); - return dependencies.frameworkAreasSerializer.serialize(framework); - }, +const getPixFrameworkAreasWithoutThematics = async function ( + request, + h, + dependencies = { extractLocaleFromRequest, frameworkAreasSerializer } +) { + const locale = dependencies.extractLocaleFromRequest(request); + const framework = await usecases.getFrameworkAreas({ frameworkName: 'Pix', locale }); + return dependencies.frameworkAreasSerializer.serialize(framework, { withoutThematics: true }); +}; - async getPixFrameworkAreasWithoutThematics( - request, - h, - dependencies = { extractLocaleFromRequest, frameworkAreasSerializer } - ) { - const locale = dependencies.extractLocaleFromRequest(request); - const framework = await usecases.getFrameworkAreas({ frameworkName: 'Pix', locale }); - return dependencies.frameworkAreasSerializer.serialize(framework, { withoutThematics: true }); - }, +const getFrameworksForTargetProfileSubmission = async function ( + request, + h, + dependencies = { extractLocaleFromRequest, frameworkSerializer } +) { + const locale = dependencies.extractLocaleFromRequest(request); + const learningContent = await usecases.getLearningContentForTargetProfileSubmission({ locale }); + return dependencies.frameworkSerializer.serializeDeepWithoutSkills(learningContent.frameworks); +}; - async getFrameworksForTargetProfileSubmission( - request, - h, - dependencies = { extractLocaleFromRequest, frameworkSerializer } - ) { - const locale = dependencies.extractLocaleFromRequest(request); - const learningContent = await usecases.getLearningContentForTargetProfileSubmission({ locale }); - return dependencies.frameworkSerializer.serializeDeepWithoutSkills(learningContent.frameworks); - }, +const frameworksController = { + getFrameworks, + getFrameworkAreas, + getPixFrameworkAreasWithoutThematics, + getFrameworksForTargetProfileSubmission, }; + +export { frameworksController }; diff --git a/api/lib/application/frameworks/index.js b/api/lib/application/frameworks/index.js index daddcffc580..782363810b0 100644 --- a/api/lib/application/frameworks/index.js +++ b/api/lib/application/frameworks/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); -const frameworkController = require('./frameworks-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import Joi from 'joi'; +import { frameworksController as frameworkController } from './frameworks-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { const adminRoutes = [ { method: 'GET', @@ -86,4 +86,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'frameworks-api'; +const name = 'frameworks-api'; +export { register, name }; diff --git a/api/lib/application/healthcheck/healthcheck-controller.js b/api/lib/application/healthcheck/healthcheck-controller.js index 7b3e443cb3d..97df680d963 100644 --- a/api/lib/application/healthcheck/healthcheck-controller.js +++ b/api/lib/application/healthcheck/healthcheck-controller.js @@ -1,39 +1,41 @@ -const Boom = require('@hapi/boom'); -const packageJSON = require('../../../package.json'); -const settings = require('../../config.js'); -const { redisMonitor } = require('../../infrastructure/utils/redis-monitor.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import Boom from '@hapi/boom'; +import packageJSON from '../../../package.json' assert { type: 'json' }; +import { config } from '../../config.js'; +import { redisMonitor } from '../../infrastructure/utils/redis-monitor.js'; +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - get(request) { - return { - name: packageJSON.name, - version: packageJSON.version, - description: packageJSON.description, - environment: settings.environment, - // eslint-disable-next-line node/no-process-env - 'container-version': process.env.CONTAINER_VERSION, - // eslint-disable-next-line node/no-process-env - 'container-app-name': process.env.APP, - 'current-lang': request.i18n.__('current-lang'), - }; - }, +const get = function (request) { + return { + name: packageJSON.name, + version: packageJSON.version, + description: packageJSON.description, + environment: config.environment, + // eslint-disable-next-line node/no-process-env + 'container-version': process.env.CONTAINER_VERSION, + // eslint-disable-next-line node/no-process-env + 'container-app-name': process.env.APP, + 'current-lang': request.i18n.__('current-lang'), + }; +}; - async checkDbStatus() { - try { - await knex.raw('SELECT 1 FROM knex_migrations_lock'); - return { message: 'Connection to database ok' }; - } catch (err) { - throw Boom.serverUnavailable('Connection to database failed'); - } - }, +const checkDbStatus = async function () { + try { + await knex.raw('SELECT 1 FROM knex_migrations_lock'); + return { message: 'Connection to database ok' }; + } catch (err) { + throw Boom.serverUnavailable('Connection to database failed'); + } +}; - async checkRedisStatus() { - try { - await redisMonitor.ping(); - return { message: 'Connection to Redis ok' }; - } catch (err) { - throw Boom.serverUnavailable('Connection to Redis failed'); - } - }, +const checkRedisStatus = async function () { + try { + await redisMonitor.ping(); + return { message: 'Connection to Redis ok' }; + } catch (err) { + throw Boom.serverUnavailable('Connection to Redis failed'); + } }; + +const healthcheckController = { get, checkDbStatus, checkRedisStatus }; + +export { healthcheckController }; diff --git a/api/lib/application/healthcheck/index.js b/api/lib/application/healthcheck/index.js index 4842ebcd442..a7e7375e7a7 100644 --- a/api/lib/application/healthcheck/index.js +++ b/api/lib/application/healthcheck/index.js @@ -1,6 +1,6 @@ -const healthcheckController = require('./healthcheck-controller.js'); +import { healthcheckController } from './healthcheck-controller.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -32,4 +32,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'healthcheck-api'; +const name = 'healthcheck-api'; +export { register, name }; diff --git a/api/lib/application/http-errors.js b/api/lib/application/http-errors.js index eb661a4f98e..8ff1cfafa4f 100644 --- a/api/lib/application/http-errors.js +++ b/api/lib/application/http-errors.js @@ -1,4 +1,6 @@ -const JSONAPIError = require('jsonapi-serializer').Error; +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Error: JSONAPIError } = jsonapiSerializer; class BaseHttpError extends Error { constructor(message) { @@ -176,7 +178,7 @@ const HttpErrors = { TooManyRequestsError, }; -module.exports = { +export { HttpErrors, BadRequestError, BaseHttpError, diff --git a/api/lib/application/lcms/index.js b/api/lib/application/lcms/index.js index ab206f41674..2b25d939e33 100644 --- a/api/lib/application/lcms/index.js +++ b/api/lib/application/lcms/index.js @@ -1,7 +1,7 @@ -const securityPreHandlers = require('../security-pre-handlers.js'); -const LcmsController = require('./lcms-controller.js'); +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { lcmsController } from './lcms-controller.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -13,7 +13,7 @@ exports.register = async function (server) { assign: 'hasRoleSuperAdmin', }, ], - handler: LcmsController.createRelease, + handler: lcmsController.createRelease, tags: ['api', 'lcms'], notes: [ 'Cette route est restreinte aux utilisateurs authentifiés avec le rôle Super Admin', @@ -24,4 +24,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'lcms-api'; +const name = 'lcms-api'; +export { register, name }; diff --git a/api/lib/application/lcms/lcms-controller.js b/api/lib/application/lcms/lcms-controller.js index ddafbb2e170..0128bad4b40 100644 --- a/api/lib/application/lcms/lcms-controller.js +++ b/api/lib/application/lcms/lcms-controller.js @@ -1,16 +1,18 @@ -const usecases = require('../../domain/usecases/index.js'); -const logger = require('../../infrastructure/logger.js'); +import { usecases } from '../../domain/usecases/index.js'; +import { logger } from '../../infrastructure/logger.js'; -module.exports = { - async createRelease(request, h) { - usecases - .createLcmsRelease() - .then(() => { - logger.info('Release created and cache reloaded'); - }) - .catch((e) => { - logger.error('Error while creating the release and reloading cache', e); - }); - return h.response({}).code(204); - }, +const createRelease = async function (request, h) { + usecases + .createLcmsRelease() + .then(() => { + logger.info('Release created and cache reloaded'); + }) + .catch((e) => { + logger.error('Error while creating the release and reloading cache', e); + }); + return h.response({}).code(204); }; + +const lcmsController = { createRelease }; + +export { lcmsController }; diff --git a/api/lib/application/memberships/index.js b/api/lib/application/memberships/index.js index df1d539076f..28d7670cae1 100644 --- a/api/lib/application/memberships/index.js +++ b/api/lib/application/memberships/index.js @@ -1,10 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const securityPreHandlers = require('../security-pre-handlers.js'); -const membershipController = require('./membership-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { membershipController } from './membership-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -152,4 +152,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'memberships-api'; +const name = 'memberships-api'; +export { register, name }; diff --git a/api/lib/application/memberships/membership-controller.js b/api/lib/application/memberships/membership-controller.js index f5c6a64af1d..018404fad31 100644 --- a/api/lib/application/memberships/membership-controller.js +++ b/api/lib/application/memberships/membership-controller.js @@ -1,41 +1,43 @@ -const membershipSerializer = require('../../infrastructure/serializers/jsonapi/membership-serializer.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); -const usecases = require('../../domain/usecases/index.js'); -const { BadRequestError } = require('../http-errors.js'); - -module.exports = { - async create(request, h, dependencies = { membershipSerializer }) { - const userId = request.payload.data.relationships.user.data.id; - const organizationId = request.payload.data.relationships.organization.data.id; - - const membership = await usecases.createMembership({ userId, organizationId }); - await usecases.createCertificationCenterMembershipForScoOrganizationMember({ membership }); - - return h.response(dependencies.membershipSerializer.serializeForAdmin(membership)).created(); - }, - - async update(request, h, dependencies = { requestResponseUtils, membershipSerializer }) { - const membershipId = request.params.id; - const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const membership = dependencies.membershipSerializer.deserialize(request.payload); - // eslint-disable-next-line no-restricted-syntax - const membershipIdFromPayload = parseInt(membership.id); - if (membershipId !== membershipIdFromPayload) { - throw new BadRequestError(); - } - membership.updatedByUserId = userId; - - const updatedMembership = await usecases.updateMembership({ membership }); - await usecases.createCertificationCenterMembershipForScoOrganizationMember({ membership }); - - return h.response(dependencies.membershipSerializer.serialize(updatedMembership)); - }, - - async disable(request, h) { - const membershipId = request.params.id; - const userId = requestResponseUtils.extractUserIdFromRequest(request); - - await usecases.disableMembership({ membershipId, userId }); - return h.response().code(204); - }, +import * as membershipSerializer from '../../infrastructure/serializers/jsonapi/membership-serializer.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; +import { usecases } from '../../domain/usecases/index.js'; +import { BadRequestError } from '../http-errors.js'; + +const create = async function (request, h, dependencies = { membershipSerializer }) { + const userId = request.payload.data.relationships.user.data.id; + const organizationId = request.payload.data.relationships.organization.data.id; + + const membership = await usecases.createMembership({ userId, organizationId }); + await usecases.createCertificationCenterMembershipForScoOrganizationMember({ membership }); + + return h.response(dependencies.membershipSerializer.serializeForAdmin(membership)).created(); +}; + +const update = async function (request, h, dependencies = { requestResponseUtils, membershipSerializer }) { + const membershipId = request.params.id; + const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const membership = dependencies.membershipSerializer.deserialize(request.payload); + // eslint-disable-next-line no-restricted-syntax + const membershipIdFromPayload = parseInt(membership.id); + if (membershipId !== membershipIdFromPayload) { + throw new BadRequestError(); + } + membership.updatedByUserId = userId; + + const updatedMembership = await usecases.updateMembership({ membership }); + await usecases.createCertificationCenterMembershipForScoOrganizationMember({ membership }); + + return h.response(dependencies.membershipSerializer.serialize(updatedMembership)); }; + +const disable = async function (request, h) { + const membershipId = request.params.id; + const userId = requestResponseUtils.extractUserIdFromRequest(request); + + await usecases.disableMembership({ membershipId, userId }); + return h.response().code(204); +}; + +const membershipController = { create, update, disable }; + +export { membershipController }; diff --git a/api/lib/application/organization-invitations/index.js b/api/lib/application/organization-invitations/index.js index 7949d0c1a71..c0c90fa22c9 100644 --- a/api/lib/application/organization-invitations/index.js +++ b/api/lib/application/organization-invitations/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const organizationInvitationController = require('./organization-invitation-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { organizationInvitationController } from './organization-invitation-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'POST', @@ -79,4 +79,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'organization-invitation-api'; +const name = 'organization-invitation-api'; +export { register, name }; diff --git a/api/lib/application/organization-invitations/organization-invitation-controller.js b/api/lib/application/organization-invitations/organization-invitation-controller.js index f3b129a22b1..768599c5e6a 100644 --- a/api/lib/application/organization-invitations/organization-invitation-controller.js +++ b/api/lib/application/organization-invitations/organization-invitation-controller.js @@ -1,50 +1,55 @@ -const _ = require('lodash'); - -const { MissingQueryParamError } = require('../http-errors.js'); -const usecases = require('../../domain/usecases/index.js'); -const organizationInvitationSerializer = require('../../infrastructure/serializers/jsonapi/organization-invitation-serializer.js'); -const scoOrganizationInvitationSerializer = require('../../infrastructure/serializers/jsonapi/sco-organization-invitation-serializer.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); - -module.exports = { - async acceptOrganizationInvitation(request) { - const organizationInvitationId = request.params.id; - const { code, email: rawEmail } = request.payload.data.attributes; - const localeFromCookie = request.state?.locale; - const email = rawEmail?.trim().toLowerCase(); - - const membership = await usecases.acceptOrganizationInvitation({ - organizationInvitationId, - code, - email, - localeFromCookie, - }); - await usecases.createCertificationCenterMembershipForScoOrganizationMember({ membership }); - return null; - }, - - async sendScoInvitation(request, h, dependencies = { requestResponseUtils, scoOrganizationInvitationSerializer }) { - const { uai, 'first-name': firstName, 'last-name': lastName } = request.payload.data.attributes; - - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - - const organizationScoInvitation = await usecases.sendScoInvitation({ uai, firstName, lastName, locale }); - - return h.response(dependencies.scoOrganizationInvitationSerializer.serialize(organizationScoInvitation)).created(); - }, - - async getOrganizationInvitation(request, h, dependencies = { organizationInvitationSerializer }) { - const organizationInvitationId = request.params.id; - const organizationInvitationCode = request.query.code; - - if (_.isEmpty(organizationInvitationCode)) { - throw new MissingQueryParamError('code'); - } - - const organizationInvitation = await usecases.getOrganizationInvitation({ - organizationInvitationId, - organizationInvitationCode, - }); - return dependencies.organizationInvitationSerializer.serialize(organizationInvitation); - }, +import _ from 'lodash'; + +import { MissingQueryParamError } from '../http-errors.js'; +import { usecases } from '../../domain/usecases/index.js'; +import * as organizationInvitationSerializer from '../../infrastructure/serializers/jsonapi/organization-invitation-serializer.js'; +import { serializer as scoOrganizationInvitationSerializer } from '../../infrastructure/serializers/jsonapi/sco-organization-invitation-serializer.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; + +const acceptOrganizationInvitation = async function (request) { + const organizationInvitationId = request.params.id; + const { code, email: rawEmail } = request.payload.data.attributes; + const localeFromCookie = request.state?.locale; + const email = rawEmail?.trim().toLowerCase(); + + const membership = await usecases.acceptOrganizationInvitation({ + organizationInvitationId, + code, + email, + localeFromCookie, + }); + await usecases.createCertificationCenterMembershipForScoOrganizationMember({ membership }); + return null; }; + +const sendScoInvitation = async function ( + request, + h, + dependencies = { requestResponseUtils, scoOrganizationInvitationSerializer } +) { + const { uai, 'first-name': firstName, 'last-name': lastName } = request.payload.data.attributes; + + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + + const organizationScoInvitation = await usecases.sendScoInvitation({ uai, firstName, lastName, locale }); + + return h.response(dependencies.scoOrganizationInvitationSerializer.serialize(organizationScoInvitation)).created(); +}; + +const getOrganizationInvitation = async function (request, h, dependencies = { organizationInvitationSerializer }) { + const organizationInvitationId = request.params.id; + const organizationInvitationCode = request.query.code; + + if (_.isEmpty(organizationInvitationCode)) { + throw new MissingQueryParamError('code'); + } + + const organizationInvitation = await usecases.getOrganizationInvitation({ + organizationInvitationId, + organizationInvitationCode, + }); + return dependencies.organizationInvitationSerializer.serialize(organizationInvitation); +}; + +const organizationInvitationController = { acceptOrganizationInvitation, sendScoInvitation, getOrganizationInvitation }; +export { organizationInvitationController }; diff --git a/api/lib/application/organization-learners/index.js b/api/lib/application/organization-learners/index.js index 5ccdfaebcc4..5233bb3bb73 100644 --- a/api/lib/application/organization-learners/index.js +++ b/api/lib/application/organization-learners/index.js @@ -1,12 +1,12 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const securityPreHandlers = require('../security-pre-handlers.js'); -const organizationLearnerController = require('./organization-learner-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { organizationLearnerController } from './organization-learner-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { const adminRoutes = [ { method: 'DELETE', @@ -101,4 +101,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'organization-learners-api'; +const name = 'organization-learners-api'; +export { register, name }; diff --git a/api/lib/application/organization-learners/organization-learner-controller.js b/api/lib/application/organization-learners/organization-learner-controller.js index 3510a699a5c..82133c8826c 100644 --- a/api/lib/application/organization-learners/organization-learner-controller.js +++ b/api/lib/application/organization-learners/organization-learner-controller.js @@ -1,39 +1,41 @@ -const usecases = require('../../domain/usecases/index.js'); -const organizationLearnerIdentitySerializer = require('../../infrastructure/serializers/jsonapi/organization-learner-identity-serializer.js'); -const organizationLearnerActivitySerializer = require('../../infrastructure/serializers/jsonapi/organization-learner-activity-serializer.js'); -const organizationLearnerSerializer = require('../../infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer.js'); - -module.exports = { - async dissociate(request, h) { - const organizationLearnerId = request.params.id; - await usecases.dissociateUserFromOrganizationLearner({ organizationLearnerId }); - return h.response().code(204); - }, - - async findAssociation(request, h, dependencies = { organizationLearnerIdentitySerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - // eslint-disable-next-line no-restricted-syntax - const requestedUserId = parseInt(request.query.userId); - const campaignCode = request.query.campaignCode; - - const organizationLearner = await usecases.findAssociationBetweenUserAndOrganizationLearner({ - authenticatedUserId, - requestedUserId, - campaignCode, - }); - - return h.response(dependencies.organizationLearnerIdentitySerializer.serialize(organizationLearner)).code(200); - }, - - async getActivity(request, h, dependencies = { organizationLearnerActivitySerializer }) { - const organizationLearnerId = request.params.id; - const activity = await usecases.getOrganizationLearnerActivity({ organizationLearnerId }); - return h.response(dependencies.organizationLearnerActivitySerializer.serialize(activity)).code(200); - }, - - async getLearner(request, h, dependencies = { organizationLearnerSerializer }) { - const organizationLearnerId = request.params.id; - const learner = await usecases.getOrganizationLearner({ organizationLearnerId }); - return h.response(dependencies.organizationLearnerSerializer.serialize(learner)).code(200); - }, +import { usecases } from '../../domain/usecases/index.js'; +import * as organizationLearnerIdentitySerializer from '../../infrastructure/serializers/jsonapi/organization-learner-identity-serializer.js'; +import * as organizationLearnerActivitySerializer from '../../infrastructure/serializers/jsonapi/organization-learner-activity-serializer.js'; +import * as organizationLearnerSerializer from '../../infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer.js'; + +const dissociate = async function (request, h) { + const organizationLearnerId = request.params.id; + await usecases.dissociateUserFromOrganizationLearner({ organizationLearnerId }); + return h.response().code(204); +}; + +const findAssociation = async function (request, h, dependencies = { organizationLearnerIdentitySerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + // eslint-disable-next-line no-restricted-syntax + const requestedUserId = parseInt(request.query.userId); + const campaignCode = request.query.campaignCode; + + const organizationLearner = await usecases.findAssociationBetweenUserAndOrganizationLearner({ + authenticatedUserId, + requestedUserId, + campaignCode, + }); + + return h.response(dependencies.organizationLearnerIdentitySerializer.serialize(organizationLearner)).code(200); }; + +const getActivity = async function (request, h, dependencies = { organizationLearnerActivitySerializer }) { + const organizationLearnerId = request.params.id; + const activity = await usecases.getOrganizationLearnerActivity({ organizationLearnerId }); + return h.response(dependencies.organizationLearnerActivitySerializer.serialize(activity)).code(200); +}; + +const getLearner = async function (request, h, dependencies = { organizationLearnerSerializer }) { + const organizationLearnerId = request.params.id; + const learner = await usecases.getOrganizationLearner({ organizationLearnerId }); + return h.response(dependencies.organizationLearnerSerializer.serialize(learner)).code(200); +}; + +const organizationLearnerController = { dissociate, findAssociation, getActivity, getLearner }; + +export { organizationLearnerController }; diff --git a/api/lib/application/organizations-administration/index.js b/api/lib/application/organizations-administration/index.js index bb54c92ea7a..3409aa8a1f3 100644 --- a/api/lib/application/organizations-administration/index.js +++ b/api/lib/application/organizations-administration/index.js @@ -1,16 +1,16 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const { sendJsonApiError, PayloadTooLargeError } = require('../http-errors.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const organizationController = require('./organization-administration-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { sendJsonApiError, PayloadTooLargeError } from '../http-errors.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { organizationAdministrationController as organizationController } from './organization-administration-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; const ERRORS = { PAYLOAD_TOO_LARGE: 'PAYLOAD_TOO_LARGE', }; const TWO_AND_HALF_MEGABYTES = 1048576 * 2.5; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'GET', @@ -83,4 +83,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'organizations-administration-api'; +const name = 'organizations-administration-api'; +export { register, name }; diff --git a/api/lib/application/organizations-administration/organization-administration-controller.js b/api/lib/application/organizations-administration/organization-administration-controller.js index 00f4c50ca31..f524afd0b16 100644 --- a/api/lib/application/organizations-administration/organization-administration-controller.js +++ b/api/lib/application/organizations-administration/organization-administration-controller.js @@ -1,26 +1,27 @@ -const usecases = require('../../domain/usecases/index.js'); -const organizationForAdminSerializer = require('../../infrastructure/serializers/jsonapi/organizations-administration/organization-for-admin-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as organizationForAdminSerializer from '../../infrastructure/serializers/jsonapi/organizations-administration/organization-for-admin-serializer.js'; -module.exports = { - async getOrganizationDetails(request, h, dependencies = { organizationForAdminSerializer }) { - const organizationId = request.params.id; +const getOrganizationDetails = async function (request, h, dependencies = { organizationForAdminSerializer }) { + const organizationId = request.params.id; - const organizationDetails = await usecases.getOrganizationDetails({ organizationId }); - return dependencies.organizationForAdminSerializer.serialize(organizationDetails); - }, + const organizationDetails = await usecases.getOrganizationDetails({ organizationId }); + return dependencies.organizationForAdminSerializer.serialize(organizationDetails); +}; - async updateOrganizationInformation( - request, - h, - dependencies = { - organizationForAdminSerializer, - } - ) { - const organizationDeserialized = dependencies.organizationForAdminSerializer.deserialize(request.payload); +const updateOrganizationInformation = async function ( + request, + h, + dependencies = { + organizationForAdminSerializer, + } +) { + const organizationDeserialized = dependencies.organizationForAdminSerializer.deserialize(request.payload); - const organizationUpdated = await usecases.updateOrganizationInformation({ - organization: organizationDeserialized, - }); - return h.response(dependencies.organizationForAdminSerializer.serialize(organizationUpdated)); - }, + const organizationUpdated = await usecases.updateOrganizationInformation({ + organization: organizationDeserialized, + }); + return h.response(dependencies.organizationForAdminSerializer.serialize(organizationUpdated)); }; + +const organizationAdministrationController = { getOrganizationDetails, updateOrganizationInformation }; +export { organizationAdministrationController, getOrganizationDetails, updateOrganizationInformation }; diff --git a/api/lib/application/organizations/helpers.js b/api/lib/application/organizations/helpers.js index 4e49043564e..b2794f5b9e7 100644 --- a/api/lib/application/organizations/helpers.js +++ b/api/lib/application/organizations/helpers.js @@ -12,6 +12,4 @@ function mapCertificabilityByLabel(certificabilityFilter) { return result.map((value) => certificabilityByLabel[value]); } -module.exports = { - mapCertificabilityByLabel, -}; +export { mapCertificabilityByLabel }; diff --git a/api/lib/application/organizations/index.js b/api/lib/application/organizations/index.js index cf821446b26..19b5d89a738 100644 --- a/api/lib/application/organizations/index.js +++ b/api/lib/application/organizations/index.js @@ -1,18 +1,18 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { sendJsonApiError, PayloadTooLargeError, NotFoundError, BadRequestError } = require('../http-errors.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const organizationController = require('./organization-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { sendJsonApiError, PayloadTooLargeError, NotFoundError, BadRequestError } from '../http-errors.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { organizationController } from './organization-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; const ERRORS = { PAYLOAD_TOO_LARGE: 'PAYLOAD_TOO_LARGE', }; const TWENTY_MEGABYTES = 1048576 * 20; -exports.register = async (server) => { +const register = async function (server) { const adminRoutes = [ { method: 'POST', @@ -994,4 +994,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'organization-api'; +const name = 'organization-api'; +export { register, name }; diff --git a/api/lib/application/organizations/organization-controller.js b/api/lib/application/organizations/organization-controller.js index 4d78e24cdaf..f1e50c05af0 100644 --- a/api/lib/application/organizations/organization-controller.js +++ b/api/lib/application/organizations/organization-controller.js @@ -1,460 +1,505 @@ -const tokenService = require('../../domain/services/token-service.js'); -const usecases = require('../../domain/usecases/index.js'); - -const campaignManagementSerializer = require('../../infrastructure/serializers/jsonapi/campaign-management-serializer.js'); -const campaignReportSerializer = require('../../infrastructure/serializers/jsonapi/campaign-report-serializer.js'); -const divisionSerializer = require('../../infrastructure/serializers/jsonapi/division-serializer.js'); -const groupSerializer = require('../../infrastructure/serializers/jsonapi/group-serializer.js'); -const membershipSerializer = require('../../infrastructure/serializers/jsonapi/membership-serializer.js'); -const organizationSerializer = require('../../infrastructure/serializers/jsonapi/organization-serializer.js'); -const organizationInvitationSerializer = require('../../infrastructure/serializers/jsonapi/organization-invitation-serializer.js'); -const supOrganizationLearnerWarningSerializer = require('../../infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer.js'); -const targetProfileForSpecifierSerializer = require('../../infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer.js'); -const organizationMemberIdentitySerializer = require('../../infrastructure/serializers/jsonapi/organization-member-identity-serializer.js'); -const organizationPlacesLotManagementSerializer = require('../../infrastructure/serializers/jsonapi/organization/organization-places-lot-management-serializer.js'); -const organizationPlacesLotSerializer = require('../../infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer.js'); -const organizationPlacesCapacitySerializer = require('../../infrastructure/serializers/jsonapi/organization-places-capacity-serializer.js'); -const organizationParticipantsSerializer = require('../../infrastructure/serializers/jsonapi/organization/organization-participants-serializer.js'); -const scoOrganizationParticipantsSerializer = require('../../infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer.js'); -const supOrganizationParticipantsSerializer = require('../../infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer.js'); -const targetProfileSummaryForAdminSerializer = require('../../infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js'); - -const SupOrganizationLearnerParser = require('../../infrastructure/serializers/csv/sup-organization-learner-parser.js'); -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const { - extractLocaleFromRequest, +import { tokenService } from '../../domain/services/token-service.js'; +import { usecases } from '../../domain/usecases/index.js'; + +import * as campaignManagementSerializer from '../../infrastructure/serializers/jsonapi/campaign-management-serializer.js'; +import * as campaignReportSerializer from '../../infrastructure/serializers/jsonapi/campaign-report-serializer.js'; +import * as divisionSerializer from '../../infrastructure/serializers/jsonapi/division-serializer.js'; +import * as groupSerializer from '../../infrastructure/serializers/jsonapi/group-serializer.js'; +import * as membershipSerializer from '../../infrastructure/serializers/jsonapi/membership-serializer.js'; +import * as organizationSerializer from '../../infrastructure/serializers/jsonapi/organization-serializer.js'; +import * as organizationInvitationSerializer from '../../infrastructure/serializers/jsonapi/organization-invitation-serializer.js'; +import * as supOrganizationLearnerWarningSerializer from '../../infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer.js'; +import * as targetProfileForSpecifierSerializer from '../../infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer.js'; +import * as organizationMemberIdentitySerializer from '../../infrastructure/serializers/jsonapi/organization-member-identity-serializer.js'; +import * as organizationPlacesLotManagementSerializer from '../../infrastructure/serializers/jsonapi/organization/organization-places-lot-management-serializer.js'; +import * as organizationPlacesLotSerializer from '../../infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer.js'; +import * as organizationPlacesCapacitySerializer from '../../infrastructure/serializers/jsonapi/organization-places-capacity-serializer.js'; +import * as organizationParticipantsSerializer from '../../infrastructure/serializers/jsonapi/organization/organization-participants-serializer.js'; +import * as scoOrganizationParticipantsSerializer from '../../infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer.js'; +import * as supOrganizationParticipantsSerializer from '../../infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer.js'; +import * as targetProfileSummaryForAdminSerializer from '../../infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js'; + +import { SupOrganizationLearnerParser } from '../../infrastructure/serializers/csv/sup-organization-learner-parser.js'; +import * as queryParamsUtils from '../../infrastructure/utils/query-params-utils.js'; +import { extractUserIdFromRequest, -} = require('../../infrastructure/utils/request-response-utils.js'); -const dayjs = require('dayjs'); -const customParseFormat = require('dayjs/plugin/customParseFormat'); + extractLocaleFromRequest, +} from '../../infrastructure/utils/request-response-utils.js'; +import dayjs from 'dayjs'; +import customParseFormat from 'dayjs/plugin/customParseFormat.js'; dayjs.extend(customParseFormat); -const certificationResultUtils = require('../../infrastructure/utils/csv/certification-results.js'); -const certificationAttestationPdf = require('../../infrastructure/utils/pdf/certification-attestation-pdf.js'); -const organizationForAdminSerializer = require('../../infrastructure/serializers/jsonapi/organization-for-admin-serializer.js'); - -const { mapCertificabilityByLabel } = require('./helpers.js'); -const csvSerializer = require('../../infrastructure/serializers/csv/csv-serializer.js'); - -module.exports = { - async create(request) { - const superAdminUserId = extractUserIdFromRequest(request); - const organization = organizationForAdminSerializer.deserialize(request.payload); - - organization.createdBy = +superAdminUserId; - - const createdOrganization = await usecases.createOrganization({ organization }); - const serializedOrganization = organizationForAdminSerializer.serialize(createdOrganization); - - return serializedOrganization; - }, - - async createInBatch(request, h) { - const organizations = await csvSerializer.deserializeForOrganizationsImport(request.payload.path); - - const createdOrganizations = await usecases.createOrganizationsWithTagsAndTargetProfiles({ organizations }); - - return h.response(organizationForAdminSerializer.serialize(createdOrganizations)).code(204); - }, - - async findPaginatedFilteredOrganizations( - request, - h, - dependencies = { - organizationSerializer, - queryParamsUtils, - } - ) { - const options = dependencies.queryParamsUtils.extractParameters(request.query); - - const { models: organizations, pagination } = await usecases.findPaginatedFilteredOrganizations({ - filter: options.filter, - page: options.page, - }); - return dependencies.organizationSerializer.serialize(organizations, pagination); - }, - - async findPaginatedFilteredCampaigns( - request, - h, - dependencies = { - queryParamsUtils, - campaignReportSerializer, - } - ) { - const organizationId = request.params.id; - const options = dependencies.queryParamsUtils.extractParameters(request.query); - const userId = request.auth.credentials.userId; - - if (options.filter.status === 'archived') { - options.filter.ongoing = false; - delete options.filter.status; - } - const { models: campaigns, meta } = await usecases.findPaginatedFilteredOrganizationCampaigns({ - organizationId, - filter: options.filter, - page: options.page, - userId, - }); - return dependencies.campaignReportSerializer.serialize(campaigns, meta); - }, - - async findPaginatedCampaignManagements( - request, - h, - dependencies = { - queryParamsUtils, - campaignManagementSerializer, - } - ) { - const organizationId = request.params.id; - const { filter, page } = dependencies.queryParamsUtils.extractParameters(request.query); - - const { models: campaigns, meta } = await usecases.findPaginatedCampaignManagements({ - organizationId, - filter, - page, - }); - return dependencies.campaignManagementSerializer.serialize(campaigns, meta); - }, - - async findPaginatedFilteredMembershipsForAdmin(request) { - const organizationId = request.params.id; - const options = queryParamsUtils.extractParameters(request.query); - - const { models: memberships, pagination } = await usecases.findPaginatedFilteredOrganizationMemberships({ - organizationId, - filter: options.filter, - page: options.page, - }); - return membershipSerializer.serializeForAdmin(memberships, pagination); - }, - - async findPaginatedFilteredMemberships(request) { - const organizationId = request.params.id; - const options = queryParamsUtils.extractParameters(request.query); - - const { models: memberships, pagination } = await usecases.findPaginatedFilteredOrganizationMemberships({ - organizationId, - filter: options.filter, - page: options.page, - }); - return membershipSerializer.serialize(memberships, pagination); - }, - - async getOrganizationMemberIdentities(request, h, dependencies = { organizationMemberIdentitySerializer }) { - const organizationId = request.params.id; - const members = await usecases.getOrganizationMemberIdentities({ organizationId }); - return dependencies.organizationMemberIdentitySerializer.serialize(members); - }, - - async getOrganizationPlacesCapacity(request) { - const organizationId = request.params.id; - const organizationPlacesCapacity = await usecases.getOrganizationPlacesCapacity({ organizationId }); - return organizationPlacesCapacitySerializer.serialize(organizationPlacesCapacity); - }, - - async findOrganizationPlacesLot(request, h, dependencies = { organizationPlacesLotManagementSerializer }) { - const organizationId = request.params.id; - const places = await usecases.findOrganizationPlacesLot({ organizationId }); - return dependencies.organizationPlacesLotManagementSerializer.serialize(places); - }, - - async deleteOrganizationPlacesLot(request, h) { - const organizationPlaceId = request.params.placeId; - const userId = request.auth.credentials.userId; - - await usecases.deleteOrganizationPlaceLot({ organizationPlaceId, userId }); - - return h.response(null).code(204); - }, - - async createOrganizationPlacesLot( - request, - h, - dependencies = { - organizationPlacesLotSerializer, - organizationPlacesLotManagementSerializer, - } - ) { - const organizationId = request.params.id; - const createdBy = request.auth.credentials.userId; - const organizationPlacesLotData = await dependencies.organizationPlacesLotSerializer.deserialize(request.payload); - const organizationPlacesLot = await usecases.createOrganizationPlacesLot({ - organizationPlacesLotData, - organizationId, - createdBy, - }); - return h - .response(dependencies.organizationPlacesLotManagementSerializer.serialize(organizationPlacesLot)) - .code(201); - }, - - async downloadCertificationAttestationsForDivision(request, h, dependencies = { certificationAttestationPdf }) { - const organizationId = request.params.id; - const { division, isFrenchDomainExtension } = request.query; - - const attestations = await usecases.findCertificationAttestationsForDivision({ - organizationId, - division, - }); - - const { buffer } = await dependencies.certificationAttestationPdf.getCertificationAttestationsPdfBuffer({ - certificates: attestations, - isFrenchDomainExtension, - }); - - const now = dayjs(); - const fileName = `${now.format('YYYYMMDD')}_attestations_${division}.pdf`; - - return h - .response(buffer) - .header('Content-Disposition', `attachment; filename=${fileName}`) - .header('Content-Type', 'application/pdf'); - }, - - async downloadCertificationResults(request, h, dependencies = { certificationResultUtils }) { - const organizationId = request.params.id; - const { division } = request.query; - - const certificationResults = await usecases.getScoCertificationResultsByDivision({ organizationId, division }); - - const csvResult = await dependencies.certificationResultUtils.getDivisionCertificationResultsCsv({ - certificationResults, - }); - - const now = dayjs(); - const fileName = `${now.format('YYYYMMDD')}_resultats_${division}.csv`; - - return h - .response(csvResult) - .header('Content-Type', 'text/csv;charset=utf-8') - .header('Content-Disposition', `attachment; filename="${fileName}"`); - }, - - async findTargetProfiles(request, h, dependencies = { targetProfileForSpecifierSerializer }) { - const organizationId = request.params.id; - const targetProfiles = await usecases.getAvailableTargetProfilesForOrganization({ organizationId }); - return dependencies.targetProfileForSpecifierSerializer.serialize(targetProfiles); - }, - - async attachTargetProfiles(request, h) { - const targetProfileIds = request.payload['target-profile-ids']; - const organizationId = request.params.id; - await usecases.attachTargetProfilesToOrganization({ organizationId, targetProfileIds }); - - return h.response({}).code(204); - }, - - async getDivisions(request) { - const organizationId = request.params.id; - const divisions = await usecases.findDivisionsByOrganization({ organizationId }); - return divisionSerializer.serialize(divisions); - }, - - async getGroups(request) { - const organizationId = request.params.id; - const groups = await usecases.findGroupsByOrganization({ organizationId }); - return groupSerializer.serialize(groups); - }, - - async findPaginatedFilteredScoParticipants( - request, - h, - dependencies = { - queryParamsUtils, - scoOrganizationParticipantsSerializer, - } - ) { - const organizationId = request.params.id; - const { filter, page, sort } = dependencies.queryParamsUtils.extractParameters(request.query); - if (filter.divisions && !Array.isArray(filter.divisions)) { - filter.divisions = [filter.divisions]; - } - if (filter.connectionTypes && !Array.isArray(filter.connectionTypes)) { - filter.connectionTypes = [filter.connectionTypes]; - } - if (filter.certificability) { - filter.certificability = mapCertificabilityByLabel(filter.certificability); - } - const { data: scoOrganizationParticipants, meta } = await usecases.findPaginatedFilteredScoParticipants({ - organizationId, - filter, - page, - sort, - }); - return dependencies.scoOrganizationParticipantsSerializer.serialize({ - scoOrganizationParticipants, - meta, - }); - }, - - async findPaginatedFilteredSupParticipants( - request, - h, - dependencies = { - queryParamsUtils, - supOrganizationParticipantsSerializer, - } - ) { - const organizationId = request.params.id; - const { filter, page, sort } = dependencies.queryParamsUtils.extractParameters(request.query); - if (filter.groups && !Array.isArray(filter.groups)) { - filter.groups = [filter.groups]; - } - - if (filter.certificability) { - filter.certificability = mapCertificabilityByLabel(filter.certificability); - } - - const { data: supOrganizationParticipants, meta } = await usecases.findPaginatedFilteredSupParticipants({ - organizationId, - filter, - page, - sort, - }); - return dependencies.supOrganizationParticipantsSerializer.serialize({ supOrganizationParticipants, meta }); - }, - - async importOrganizationLearnersFromSIECLE(request, h) { - const organizationId = request.params.id; - const { format } = request.query; - - await usecases.importOrganizationLearnersFromSIECLEFormat({ - organizationId, - payload: request.payload, - format, - i18n: request.i18n, - }); - - return h.response(null).code(204); - }, - - async importSupOrganizationLearners(request, h) { - const organizationId = request.params.id; - const buffer = request.payload; - const supOrganizationLearnerParser = new SupOrganizationLearnerParser(buffer, organizationId, request.i18n); - const warnings = await usecases.importSupOrganizationLearners({ supOrganizationLearnerParser }); - - return h.response(supOrganizationLearnerWarningSerializer.serialize({ id: organizationId, warnings })).code(200); - }, - - async replaceSupOrganizationLearners(request, h) { - const organizationId = request.params.id; - const buffer = request.payload; - const supOrganizationLearnerParser = new SupOrganizationLearnerParser(buffer, organizationId, request.i18n); - const warnings = await usecases.replaceSupOrganizationLearners({ - organizationId, - supOrganizationLearnerParser, - }); - - return h.response(supOrganizationLearnerWarningSerializer.serialize({ id: organizationId, warnings })).code(200); - }, - - async sendInvitations(request, h) { - const organizationId = request.params.id; - const emails = request.payload.data.attributes.email.split(','); - const locale = extractLocaleFromRequest(request); - - const organizationInvitations = await usecases.createOrganizationInvitations({ organizationId, emails, locale }); - return h.response(organizationInvitationSerializer.serialize(organizationInvitations)).created(); - }, - - async resendInvitation(request, h) { - const organizationId = request.params.id; - const email = request.payload.data.attributes.email; - const locale = extractLocaleFromRequest(request); - - const organizationInvitation = await usecases.resendOrganizationInvitation({ - organizationId, - email, - locale, - }); - return h.response(organizationInvitationSerializer.serialize(organizationInvitation)); - }, - - async cancelOrganizationInvitation(request, h) { - const organizationInvitationId = request.params.organizationInvitationId; - await usecases.cancelOrganizationInvitation({ organizationInvitationId }); - return h.response().code(204); - }, - - async sendInvitationByLangAndRole(request, h, dependencies = { organizationInvitationSerializer }) { - const organizationId = request.params.id; - const invitationInformation = - await dependencies.organizationInvitationSerializer.deserializeForCreateOrganizationInvitationAndSendEmail( - request.payload - ); - - const organizationInvitation = await usecases.createOrganizationInvitationByAdmin({ - organizationId, - email: invitationInformation.email, - locale: invitationInformation.lang, - role: invitationInformation.role, - }); - return h.response(dependencies.organizationInvitationSerializer.serialize(organizationInvitation)).created(); - }, - - findPendingInvitations(request, h, dependencies = { organizationInvitationSerializer }) { - const organizationId = request.params.id; - - return usecases - .findPendingOrganizationInvitations({ organizationId }) - .then((invitations) => dependencies.organizationInvitationSerializer.serialize(invitations)); - }, - - async getOrganizationLearnersCsvTemplate(request, h, dependencies = { tokenService }) { - const organizationId = request.params.id; - const token = request.query.accessToken; - const userId = dependencies.tokenService.extractUserId(token); - const template = await usecases.getOrganizationLearnersCsvTemplate({ - userId, - organizationId, - i18n: request.i18n, - }); - - return h - .response(template) - .header('Content-Type', 'text/csv;charset=utf-8') - .header('Content-Disposition', `attachment; filename=${request.i18n.__('csv-template.template-name')}.csv`); - }, - - async archiveOrganization(request, h, dependencies = { organizationForAdminSerializer }) { - const organizationId = request.params.id; - const userId = extractUserIdFromRequest(request); - const archivedOrganization = await usecases.archiveOrganization({ organizationId, userId }); - return dependencies.organizationForAdminSerializer.serialize(archivedOrganization); - }, - - async getPaginatedParticipantsForAnOrganization( - request, - h, - dependencies = { - queryParamsUtils, - organizationParticipantsSerializer, - } - ) { - const organizationId = request.params.id; - const { page, filter: filters, sort } = dependencies.queryParamsUtils.extractParameters(request.query); - - if (filters.certificability) { - filters.certificability = mapCertificabilityByLabel(filters.certificability); - } - - const results = await usecases.getPaginatedParticipantsForAnOrganization({ - organizationId, - page, - filters, - sort, - }); - - return dependencies.organizationParticipantsSerializer.serialize(results); - }, - - async findTargetProfileSummariesForAdmin(request) { - const organizationId = request.params.id; - const targetProfileSummaries = await usecases.findOrganizationTargetProfileSummariesForAdmin({ - organizationId, - }); - return targetProfileSummaryForAdminSerializer.serialize(targetProfileSummaries); - }, +import * as certificationResultUtils from '../../infrastructure/utils/csv/certification-results.js'; +import { getCertificationAttestationsPdf as certificationAttestationPdf } from '../../infrastructure/utils/pdf/certification-attestation-pdf.js'; +import * as organizationForAdminSerializer from '../../infrastructure/serializers/jsonapi/organization-for-admin-serializer.js'; + +import { mapCertificabilityByLabel } from './helpers.js'; +import * as csvSerializer from '../../infrastructure/serializers/csv/csv-serializer.js'; + +const create = async function (request) { + const superAdminUserId = extractUserIdFromRequest(request); + const organization = organizationForAdminSerializer.deserialize(request.payload); + + organization.createdBy = +superAdminUserId; + + const createdOrganization = await usecases.createOrganization({ organization }); + const serializedOrganization = organizationForAdminSerializer.serialize(createdOrganization); + + return serializedOrganization; +}; + +const createInBatch = async function (request, h) { + const organizations = await csvSerializer.deserializeForOrganizationsImport(request.payload.path); + + const createdOrganizations = await usecases.createOrganizationsWithTagsAndTargetProfiles({ organizations }); + + return h.response(organizationForAdminSerializer.serialize(createdOrganizations)).code(204); +}; + +const findPaginatedFilteredOrganizations = async function ( + request, + h, + dependencies = { + organizationSerializer, + queryParamsUtils, + } +) { + const options = dependencies.queryParamsUtils.extractParameters(request.query); + + const { models: organizations, pagination } = await usecases.findPaginatedFilteredOrganizations({ + filter: options.filter, + page: options.page, + }); + return dependencies.organizationSerializer.serialize(organizations, pagination); +}; + +const findPaginatedFilteredCampaigns = async function ( + request, + h, + dependencies = { + queryParamsUtils, + campaignReportSerializer, + } +) { + const organizationId = request.params.id; + const options = dependencies.queryParamsUtils.extractParameters(request.query); + const userId = request.auth.credentials.userId; + + if (options.filter.status === 'archived') { + options.filter.ongoing = false; + delete options.filter.status; + } + const { models: campaigns, meta } = await usecases.findPaginatedFilteredOrganizationCampaigns({ + organizationId, + filter: options.filter, + page: options.page, + userId, + }); + return dependencies.campaignReportSerializer.serialize(campaigns, meta); +}; + +const findPaginatedCampaignManagements = async function ( + request, + h, + dependencies = { + queryParamsUtils, + campaignManagementSerializer, + } +) { + const organizationId = request.params.id; + const { filter, page } = dependencies.queryParamsUtils.extractParameters(request.query); + + const { models: campaigns, meta } = await usecases.findPaginatedCampaignManagements({ + organizationId, + filter, + page, + }); + return dependencies.campaignManagementSerializer.serialize(campaigns, meta); +}; + +const findPaginatedFilteredMembershipsForAdmin = async function (request) { + const organizationId = request.params.id; + const options = queryParamsUtils.extractParameters(request.query); + + const { models: memberships, pagination } = await usecases.findPaginatedFilteredOrganizationMemberships({ + organizationId, + filter: options.filter, + page: options.page, + }); + return membershipSerializer.serializeForAdmin(memberships, pagination); +}; + +const findPaginatedFilteredMemberships = async function (request) { + const organizationId = request.params.id; + const options = queryParamsUtils.extractParameters(request.query); + + const { models: memberships, pagination } = await usecases.findPaginatedFilteredOrganizationMemberships({ + organizationId, + filter: options.filter, + page: options.page, + }); + return membershipSerializer.serialize(memberships, pagination); +}; + +const getOrganizationMemberIdentities = async function ( + request, + h, + dependencies = { organizationMemberIdentitySerializer } +) { + const organizationId = request.params.id; + const members = await usecases.getOrganizationMemberIdentities({ organizationId }); + return dependencies.organizationMemberIdentitySerializer.serialize(members); +}; + +const getOrganizationPlacesCapacity = async function (request) { + const organizationId = request.params.id; + const organizationPlacesCapacity = await usecases.getOrganizationPlacesCapacity({ organizationId }); + return organizationPlacesCapacitySerializer.serialize(organizationPlacesCapacity); +}; + +const findOrganizationPlacesLot = async function ( + request, + h, + dependencies = { organizationPlacesLotManagementSerializer } +) { + const organizationId = request.params.id; + const places = await usecases.findOrganizationPlacesLot({ organizationId }); + return dependencies.organizationPlacesLotManagementSerializer.serialize(places); +}; + +const deleteOrganizationPlacesLot = async function (request, h) { + const organizationPlaceId = request.params.placeId; + const userId = request.auth.credentials.userId; + + await usecases.deleteOrganizationPlaceLot({ organizationPlaceId, userId }); + + return h.response(null).code(204); +}; + +const createOrganizationPlacesLot = async function ( + request, + h, + dependencies = { + organizationPlacesLotSerializer, + organizationPlacesLotManagementSerializer, + } +) { + const organizationId = request.params.id; + const createdBy = request.auth.credentials.userId; + const organizationPlacesLotData = await dependencies.organizationPlacesLotSerializer.deserialize(request.payload); + const organizationPlacesLot = await usecases.createOrganizationPlacesLot({ + organizationPlacesLotData, + organizationId, + createdBy, + }); + return h.response(dependencies.organizationPlacesLotManagementSerializer.serialize(organizationPlacesLot)).code(201); +}; + +const downloadCertificationAttestationsForDivision = async function ( + request, + h, + dependencies = { certificationAttestationPdf } +) { + const organizationId = request.params.id; + const { division, isFrenchDomainExtension } = request.query; + + const attestations = await usecases.findCertificationAttestationsForDivision({ + organizationId, + division, + }); + + const { buffer } = await dependencies.certificationAttestationPdf.getCertificationAttestationsPdfBuffer({ + certificates: attestations, + isFrenchDomainExtension, + }); + + const now = dayjs(); + const fileName = `${now.format('YYYYMMDD')}_attestations_${division}.pdf`; + + return h + .response(buffer) + .header('Content-Disposition', `attachment; filename=${fileName}`) + .header('Content-Type', 'application/pdf'); +}; + +const downloadCertificationResults = async function (request, h, dependencies = { certificationResultUtils }) { + const organizationId = request.params.id; + const { division } = request.query; + + const certificationResults = await usecases.getScoCertificationResultsByDivision({ organizationId, division }); + + const csvResult = await dependencies.certificationResultUtils.getDivisionCertificationResultsCsv({ + certificationResults, + }); + + const now = dayjs(); + const fileName = `${now.format('YYYYMMDD')}_resultats_${division}.csv`; + + return h + .response(csvResult) + .header('Content-Type', 'text/csv;charset=utf-8') + .header('Content-Disposition', `attachment; filename="${fileName}"`); +}; + +const findTargetProfiles = async function (request, h, dependencies = { targetProfileForSpecifierSerializer }) { + const organizationId = request.params.id; + const targetProfiles = await usecases.getAvailableTargetProfilesForOrganization({ organizationId }); + return dependencies.targetProfileForSpecifierSerializer.serialize(targetProfiles); }; + +const attachTargetProfiles = async function (request, h) { + const targetProfileIds = request.payload['target-profile-ids']; + const organizationId = request.params.id; + await usecases.attachTargetProfilesToOrganization({ organizationId, targetProfileIds }); + + return h.response({}).code(204); +}; + +const getDivisions = async function (request) { + const organizationId = request.params.id; + const divisions = await usecases.findDivisionsByOrganization({ organizationId }); + return divisionSerializer.serialize(divisions); +}; + +const getGroups = async function (request) { + const organizationId = request.params.id; + const groups = await usecases.findGroupsByOrganization({ organizationId }); + return groupSerializer.serialize(groups); +}; + +const findPaginatedFilteredScoParticipants = async function ( + request, + h, + dependencies = { + queryParamsUtils, + scoOrganizationParticipantsSerializer, + } +) { + const organizationId = request.params.id; + const { filter, page, sort } = dependencies.queryParamsUtils.extractParameters(request.query); + if (filter.divisions && !Array.isArray(filter.divisions)) { + filter.divisions = [filter.divisions]; + } + if (filter.connectionTypes && !Array.isArray(filter.connectionTypes)) { + filter.connectionTypes = [filter.connectionTypes]; + } + if (filter.certificability) { + filter.certificability = mapCertificabilityByLabel(filter.certificability); + } + const { data: scoOrganizationParticipants, meta } = await usecases.findPaginatedFilteredScoParticipants({ + organizationId, + filter, + page, + sort, + }); + return dependencies.scoOrganizationParticipantsSerializer.serialize({ + scoOrganizationParticipants, + meta, + }); +}; + +const findPaginatedFilteredSupParticipants = async function ( + request, + h, + dependencies = { + queryParamsUtils, + supOrganizationParticipantsSerializer, + } +) { + const organizationId = request.params.id; + const { filter, page, sort } = dependencies.queryParamsUtils.extractParameters(request.query); + if (filter.groups && !Array.isArray(filter.groups)) { + filter.groups = [filter.groups]; + } + + if (filter.certificability) { + filter.certificability = mapCertificabilityByLabel(filter.certificability); + } + + const { data: supOrganizationParticipants, meta } = await usecases.findPaginatedFilteredSupParticipants({ + organizationId, + filter, + page, + sort, + }); + return dependencies.supOrganizationParticipantsSerializer.serialize({ supOrganizationParticipants, meta }); +}; + +const importOrganizationLearnersFromSIECLE = async function (request, h) { + const organizationId = request.params.id; + const { format } = request.query; + + await usecases.importOrganizationLearnersFromSIECLEFormat({ + organizationId, + payload: request.payload, + format, + i18n: request.i18n, + }); + + return h.response(null).code(204); +}; + +const importSupOrganizationLearners = async function (request, h) { + const organizationId = request.params.id; + const buffer = request.payload; + const supOrganizationLearnerParser = new SupOrganizationLearnerParser(buffer, organizationId, request.i18n); + const warnings = await usecases.importSupOrganizationLearners({ supOrganizationLearnerParser }); + + return h.response(supOrganizationLearnerWarningSerializer.serialize({ id: organizationId, warnings })).code(200); +}; + +const replaceSupOrganizationLearners = async function (request, h) { + const organizationId = request.params.id; + const buffer = request.payload; + const supOrganizationLearnerParser = new SupOrganizationLearnerParser(buffer, organizationId, request.i18n); + const warnings = await usecases.replaceSupOrganizationLearners({ + organizationId, + supOrganizationLearnerParser, + }); + + return h.response(supOrganizationLearnerWarningSerializer.serialize({ id: organizationId, warnings })).code(200); +}; + +const sendInvitations = async function (request, h) { + const organizationId = request.params.id; + const emails = request.payload.data.attributes.email.split(','); + const locale = extractLocaleFromRequest(request); + + const organizationInvitations = await usecases.createOrganizationInvitations({ organizationId, emails, locale }); + return h.response(organizationInvitationSerializer.serialize(organizationInvitations)).created(); +}; + +const resendInvitation = async function (request, h) { + const organizationId = request.params.id; + const email = request.payload.data.attributes.email; + const locale = extractLocaleFromRequest(request); + + const organizationInvitation = await usecases.resendOrganizationInvitation({ + organizationId, + email, + locale, + }); + return h.response(organizationInvitationSerializer.serialize(organizationInvitation)); +}; + +const cancelOrganizationInvitation = async function (request, h) { + const organizationInvitationId = request.params.organizationInvitationId; + await usecases.cancelOrganizationInvitation({ organizationInvitationId }); + return h.response().code(204); +}; + +const sendInvitationByLangAndRole = async function (request, h, dependencies = { organizationInvitationSerializer }) { + const organizationId = request.params.id; + const invitationInformation = + await dependencies.organizationInvitationSerializer.deserializeForCreateOrganizationInvitationAndSendEmail( + request.payload + ); + + const organizationInvitation = await usecases.createOrganizationInvitationByAdmin({ + organizationId, + email: invitationInformation.email, + locale: invitationInformation.lang, + role: invitationInformation.role, + }); + return h.response(dependencies.organizationInvitationSerializer.serialize(organizationInvitation)).created(); +}; + +const findPendingInvitations = function (request, h, dependencies = { organizationInvitationSerializer }) { + const organizationId = request.params.id; + + return usecases + .findPendingOrganizationInvitations({ organizationId }) + .then((invitations) => dependencies.organizationInvitationSerializer.serialize(invitations)); +}; + +const getOrganizationLearnersCsvTemplate = async function (request, h, dependencies = { tokenService }) { + const organizationId = request.params.id; + const token = request.query.accessToken; + const userId = dependencies.tokenService.extractUserId(token); + const template = await usecases.getOrganizationLearnersCsvTemplate({ + userId, + organizationId, + i18n: request.i18n, + }); + + return h + .response(template) + .header('Content-Type', 'text/csv;charset=utf-8') + .header('Content-Disposition', `attachment; filename=${request.i18n.__('csv-template.template-name')}.csv`); +}; + +const archiveOrganization = async function (request, h, dependencies = { organizationForAdminSerializer }) { + const organizationId = request.params.id; + const userId = extractUserIdFromRequest(request); + const archivedOrganization = await usecases.archiveOrganization({ organizationId, userId }); + return dependencies.organizationForAdminSerializer.serialize(archivedOrganization); +}; + +const getPaginatedParticipantsForAnOrganization = async function ( + request, + h, + dependencies = { + queryParamsUtils, + organizationParticipantsSerializer, + } +) { + const organizationId = request.params.id; + const { page, filter: filters, sort } = dependencies.queryParamsUtils.extractParameters(request.query); + + if (filters.certificability) { + filters.certificability = mapCertificabilityByLabel(filters.certificability); + } + + const results = await usecases.getPaginatedParticipantsForAnOrganization({ + organizationId, + page, + filters, + sort, + }); + + return dependencies.organizationParticipantsSerializer.serialize(results); +}; + +const findTargetProfileSummariesForAdmin = async function (request) { + const organizationId = request.params.id; + const targetProfileSummaries = await usecases.findOrganizationTargetProfileSummariesForAdmin({ + organizationId, + }); + return targetProfileSummaryForAdminSerializer.serialize(targetProfileSummaries); +}; + +const organizationController = { + create, + createInBatch, + findPaginatedFilteredOrganizations, + findPaginatedFilteredCampaigns, + findPaginatedCampaignManagements, + findPaginatedFilteredMembershipsForAdmin, + findPaginatedFilteredMemberships, + getOrganizationMemberIdentities, + getOrganizationPlacesCapacity, + findOrganizationPlacesLot, + deleteOrganizationPlacesLot, + createOrganizationPlacesLot, + downloadCertificationAttestationsForDivision, + downloadCertificationResults, + findTargetProfiles, + attachTargetProfiles, + getDivisions, + getGroups, + findPaginatedFilteredScoParticipants, + findPaginatedFilteredSupParticipants, + importOrganizationLearnersFromSIECLE, + importSupOrganizationLearners, + replaceSupOrganizationLearners, + sendInvitations, + resendInvitation, + cancelOrganizationInvitation, + sendInvitationByLangAndRole, + findPendingInvitations, + getOrganizationLearnersCsvTemplate, + archiveOrganization, + getPaginatedParticipantsForAnOrganization, + findTargetProfileSummariesForAdmin, +}; + +export { organizationController }; diff --git a/api/lib/application/passwords/index.js b/api/lib/application/passwords/index.js index 37deeaa7209..5f33db2d604 100644 --- a/api/lib/application/passwords/index.js +++ b/api/lib/application/passwords/index.js @@ -1,10 +1,13 @@ -const Joi = require('joi'); -const XRegExp = require('xregexp'); +import Joi from 'joi'; +import XRegExp from 'xregexp'; -const { passwordValidationPattern } = require('../../config.js').account; -const passwordController = require('./password-controller.js'); +import { config } from '../../config.js'; -exports.register = async function (server) { +const { passwordValidationPattern } = config.account; + +import { passwordController } from './password-controller.js'; + +const register = async function (server) { server.route([ { method: 'POST', @@ -61,4 +64,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'passwords-api'; +const name = 'passwords-api'; +export { register, name }; diff --git a/api/lib/application/passwords/password-controller.js b/api/lib/application/passwords/password-controller.js index 36b5ccfa863..5d3d5eb0612 100644 --- a/api/lib/application/passwords/password-controller.js +++ b/api/lib/application/passwords/password-controller.js @@ -1,50 +1,52 @@ -const usecases = require('../../domain/usecases/index.js'); - -const passwordResetSerializer = require('../../infrastructure/serializers/jsonapi/password-reset-serializer.js'); -const userSerializer = require('../../infrastructure/serializers/jsonapi/user-serializer.js'); - -const { extractLocaleFromRequest } = require('../../infrastructure/utils/request-response-utils.js'); - -module.exports = { - async createResetDemand( - request, - h, - dependencies = { - passwordResetSerializer, - } - ) { - const { email } = request.payload.data.attributes; - const locale = extractLocaleFromRequest(request); - - const passwordResetDemand = await usecases.createPasswordResetDemand({ - email, - locale, - }); - const serializedPayload = dependencies.passwordResetSerializer.serialize(passwordResetDemand.attributes); - - return h.response(serializedPayload).created(); - }, - - async checkResetDemand(request, h, dependencies = { userSerializer }) { - const temporaryKey = request.params.temporaryKey; - const user = await usecases.getUserByResetPasswordDemand({ temporaryKey }); - return dependencies.userSerializer.serialize(user); - }, - - async updateExpiredPassword(request, h) { - const passwordResetToken = request.payload.data.attributes['password-reset-token']; - const newPassword = request.payload.data.attributes['new-password']; - const login = await usecases.updateExpiredPassword({ passwordResetToken, newPassword }); - - return h - .response({ - data: { - type: 'reset-expired-password-demands', - attributes: { - login, - }, +import { usecases } from '../../domain/usecases/index.js'; + +import * as passwordResetSerializer from '../../infrastructure/serializers/jsonapi/password-reset-serializer.js'; +import * as userSerializer from '../../infrastructure/serializers/jsonapi/user-serializer.js'; + +import { extractLocaleFromRequest } from '../../infrastructure/utils/request-response-utils.js'; + +const createResetDemand = async function ( + request, + h, + dependencies = { + passwordResetSerializer, + } +) { + const { email } = request.payload.data.attributes; + const locale = extractLocaleFromRequest(request); + + const passwordResetDemand = await usecases.createPasswordResetDemand({ + email, + locale, + }); + const serializedPayload = dependencies.passwordResetSerializer.serialize(passwordResetDemand.attributes); + + return h.response(serializedPayload).created(); +}; + +const checkResetDemand = async function (request, h, dependencies = { userSerializer }) { + const temporaryKey = request.params.temporaryKey; + const user = await usecases.getUserByResetPasswordDemand({ temporaryKey }); + return dependencies.userSerializer.serialize(user); +}; + +const updateExpiredPassword = async function (request, h) { + const passwordResetToken = request.payload.data.attributes['password-reset-token']; + const newPassword = request.payload.data.attributes['new-password']; + const login = await usecases.updateExpiredPassword({ passwordResetToken, newPassword }); + + return h + .response({ + data: { + type: 'reset-expired-password-demands', + attributes: { + login, }, - }) - .created(); - }, + }, + }) + .created(); }; + +const passwordController = { createResetDemand, checkResetDemand, updateExpiredPassword }; + +export { passwordController }; diff --git a/api/lib/application/pole-emploi/index.js b/api/lib/application/pole-emploi/index.js index 34013cb4062..2186cefb21e 100644 --- a/api/lib/application/pole-emploi/index.js +++ b/api/lib/application/pole-emploi/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); -const poleEmploiController = require('./pole-emploi-controller.js'); -const poleEmploiErreurDoc = require('../../infrastructure/open-api-doc/pole-emploi/erreur-doc.js'); -const { poleEmploiEnvoisDoc } = require('../../infrastructure/open-api-doc/pole-emploi/envois-doc.js'); +import Joi from 'joi'; +import { poleEmploiController } from './pole-emploi-controller.js'; +import { erreurDoc } from '../../infrastructure/open-api-doc/pole-emploi/erreur-doc.js'; +import { poleEmploiEnvoisDoc } from '../../infrastructure/open-api-doc/pole-emploi/envois-doc.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -20,9 +20,9 @@ exports.register = async function (server) { status: { 200: poleEmploiEnvoisDoc, 204: poleEmploiEnvoisDoc, - 400: poleEmploiErreurDoc, - 401: poleEmploiErreurDoc, - 403: poleEmploiErreurDoc, + 400: erreurDoc, + 401: erreurDoc, + 403: erreurDoc, }, }, plugins: { @@ -55,4 +55,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'pole-emploi-api'; +const name = 'pole-emploi-api'; +export { register, name }; diff --git a/api/lib/application/pole-emploi/pole-emploi-controller.js b/api/lib/application/pole-emploi/pole-emploi-controller.js index 0e2560fb8ed..1d93ad77871 100644 --- a/api/lib/application/pole-emploi/pole-emploi-controller.js +++ b/api/lib/application/pole-emploi/pole-emploi-controller.js @@ -1,14 +1,16 @@ -const usecases = require('../../domain/usecases/index.js'); +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async getSendings(request, h) { - const cursor = request.query.curseur; - const filters = _extractFilters(request); - const { sendings, link } = await usecases.getPoleEmploiSendings({ cursor, filters }); - return h.response(sendings).header('link', link).code(200); - }, +const getSendings = async function (request, h) { + const cursor = request.query.curseur; + const filters = _extractFilters(request); + const { sendings, link } = await usecases.getPoleEmploiSendings({ cursor, filters }); + return h.response(sendings).header('link', link).code(200); }; +const poleEmploiController = { getSendings }; + +export { poleEmploiController }; + function _extractFilters(request) { const filters = {}; if (Object.keys(request.query).includes('enErreur')) { diff --git a/api/lib/application/pre-response-utils.js b/api/lib/application/pre-response-utils.js index 577bafa6a47..df0a40710a1 100644 --- a/api/lib/application/pre-response-utils.js +++ b/api/lib/application/pre-response-utils.js @@ -1,6 +1,6 @@ -const errorManager = require('./error-manager.js'); -const { BaseHttpError } = require('./http-errors.js'); -const { DomainError } = require('../domain/errors.js'); +import * as errorManager from './error-manager.js'; +import { BaseHttpError } from './http-errors.js'; +import { DomainError } from '../domain/errors.js'; function handleDomainAndHttpErrors( request, @@ -18,6 +18,4 @@ function handleDomainAndHttpErrors( return h.continue; } -module.exports = { - handleDomainAndHttpErrors, -}; +export { handleDomainAndHttpErrors }; diff --git a/api/lib/application/preHandlers/assessment-authorization.js b/api/lib/application/preHandlers/assessment-authorization.js index 057ba94d3b4..3665b64b04d 100644 --- a/api/lib/application/preHandlers/assessment-authorization.js +++ b/api/lib/application/preHandlers/assessment-authorization.js @@ -1,20 +1,26 @@ -const assessmentRepository = require('../../infrastructure/repositories/assessment-repository.js'); -const validationErrorSerializer = require('../../infrastructure/serializers/jsonapi/validation-error-serializer.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); +import * as assessmentRepository from '../../infrastructure/repositories/assessment-repository.js'; +import * as validationErrorSerializer from '../../infrastructure/serializers/jsonapi/validation-error-serializer.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; -module.exports = { - verify(request, h, dependencies = { requestResponseUtils, assessmentRepository, validationErrorSerializer }) { - const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - // eslint-disable-next-line no-restricted-syntax - const assessmentId = parseInt(request.params.id); +const verify = function ( + request, + h, + dependencies = { requestResponseUtils, assessmentRepository, validationErrorSerializer } +) { + const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + // eslint-disable-next-line no-restricted-syntax + const assessmentId = parseInt(request.params.id); - return dependencies.assessmentRepository.getByAssessmentIdAndUserId(assessmentId, userId).catch(() => { - const buildError = _handleWhenInvalidAuthorization('Vous n’êtes pas autorisé à accéder à cette évaluation'); - return h.response(dependencies.validationErrorSerializer.serialize(buildError)).code(401).takeover(); - }); - }, + return dependencies.assessmentRepository.getByAssessmentIdAndUserId(assessmentId, userId).catch(() => { + const buildError = _handleWhenInvalidAuthorization('Vous n’êtes pas autorisé à accéder à cette évaluation'); + return h.response(dependencies.validationErrorSerializer.serialize(buildError)).code(401).takeover(); + }); }; +const assessmentAuthorization = { verify }; + +export { assessmentAuthorization }; + function _handleWhenInvalidAuthorization(errorMessage) { return { data: { diff --git a/api/lib/application/preHandlers/authorization.js b/api/lib/application/preHandlers/authorization.js index de42b2bc03d..e2afcb10606 100644 --- a/api/lib/application/preHandlers/authorization.js +++ b/api/lib/application/preHandlers/authorization.js @@ -1,15 +1,15 @@ -const { NotFoundError } = require('../http-errors.js'); -const certificationCourseRepository = require('../../infrastructure/repositories/certification-course-repository.js'); -const sessionRepository = require('../../infrastructure/repositories/sessions/session-repository.js'); +import { NotFoundError } from '../http-errors.js'; +import * as certificationCourseRepository from '../../infrastructure/repositories/certification-course-repository.js'; +import * as sessionRepository from '../../infrastructure/repositories/sessions/session-repository.js'; -module.exports.verifySessionAuthorization = async (request, h, dependencies = { sessionRepository }) => { +const verifySessionAuthorization = async (request, h, dependencies = { sessionRepository }) => { const userId = request.auth.credentials.userId; const sessionId = request.params.id; return await _isAuthorizedToAccessSession({ userId, sessionId, sessionRepository: dependencies.sessionRepository }); }; -module.exports.verifyCertificationSessionAuthorization = async ( +const verifyCertificationSessionAuthorization = async ( request, h, dependencies = { sessionRepository, certificationCourseRepository } @@ -26,6 +26,10 @@ module.exports.verifyCertificationSessionAuthorization = async ( }); }; +const authorization = { verifySessionAuthorization, verifyCertificationSessionAuthorization }; + +export { authorization, verifySessionAuthorization, verifyCertificationSessionAuthorization }; + async function _isAuthorizedToAccessSession({ userId, sessionId, sessionRepository }) { const hasMembershipAccess = await sessionRepository.doesUserHaveCertificationCenterMembershipForSession( userId, diff --git a/api/lib/application/preHandlers/feature-toggles.js b/api/lib/application/preHandlers/feature-toggles.js index f053ebf7976..cb0ff5c3b54 100644 --- a/api/lib/application/preHandlers/feature-toggles.js +++ b/api/lib/application/preHandlers/feature-toggles.js @@ -1 +1 @@ -module.exports = {}; +export {}; diff --git a/api/lib/application/preHandlers/models/CampaignAuthorization.js b/api/lib/application/preHandlers/models/CampaignAuthorization.js index d609568afe7..650d9e08fe3 100644 --- a/api/lib/application/preHandlers/models/CampaignAuthorization.js +++ b/api/lib/application/preHandlers/models/CampaignAuthorization.js @@ -10,5 +10,4 @@ class CampaignAuthorization { } } -module.exports = CampaignAuthorization; -module.exports.prescriberRoles = prescriberRoles; +export { CampaignAuthorization, prescriberRoles }; diff --git a/api/lib/application/preHandlers/session-supervisor-authorization.js b/api/lib/application/preHandlers/session-supervisor-authorization.js index 28f4cf99f51..4b7fdc338ae 100644 --- a/api/lib/application/preHandlers/session-supervisor-authorization.js +++ b/api/lib/application/preHandlers/session-supervisor-authorization.js @@ -1,38 +1,44 @@ -const supervisorAccessRepository = require('../../infrastructure/repositories/supervisor-access-repository.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); - -module.exports = { - async verifyByCertificationCandidateId( - request, - h, - dependencies = { requestResponseUtils, supervisorAccessRepository } - ) { - const supervisorUserId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const candidateId = request.params.id; - const isSupervisorForSession = await dependencies.supervisorAccessRepository.isUserSupervisorForSessionCandidate({ - supervisorId: supervisorUserId, - certificationCandidateId: candidateId, - }); - - if (!isSupervisorForSession) { - return h.response().code(401).takeover(); - } - - return true; - }, - - async verifyBySessionId(request, h, dependencies = { requestResponseUtils, supervisorAccessRepository }) { - const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const sessionId = request.params.id; - - const isSupervisorForSession = await dependencies.supervisorAccessRepository.isUserSupervisorForSession({ - sessionId, - userId, - }); - - if (!isSupervisorForSession) { - return h.response().code(401).takeover(); - } - return true; - }, +import * as supervisorAccessRepository from '../../infrastructure/repositories/supervisor-access-repository.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; + +const verifyByCertificationCandidateId = async function ( + request, + h, + dependencies = { requestResponseUtils, supervisorAccessRepository } +) { + const supervisorUserId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const candidateId = request.params.id; + const isSupervisorForSession = await dependencies.supervisorAccessRepository.isUserSupervisorForSessionCandidate({ + supervisorId: supervisorUserId, + certificationCandidateId: candidateId, + }); + + if (!isSupervisorForSession) { + return h.response().code(401).takeover(); + } + + return true; }; + +const verifyBySessionId = async function ( + request, + h, + dependencies = { requestResponseUtils, supervisorAccessRepository } +) { + const userId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const sessionId = request.params.id; + + const isSupervisorForSession = await dependencies.supervisorAccessRepository.isUserSupervisorForSession({ + sessionId, + userId, + }); + + if (!isSupervisorForSession) { + return h.response().code(401).takeover(); + } + return true; +}; + +const assessmentSupervisorAuthorization = { verifyByCertificationCandidateId, verifyBySessionId }; + +export { assessmentSupervisorAuthorization }; diff --git a/api/lib/application/preHandlers/user-existence-verification.js b/api/lib/application/preHandlers/user-existence-verification.js index d0c3afeda7a..36b1c1018e9 100644 --- a/api/lib/application/preHandlers/user-existence-verification.js +++ b/api/lib/application/preHandlers/user-existence-verification.js @@ -1,14 +1,16 @@ -const userRepository = require('../../../lib/infrastructure/repositories/user-repository.js'); -const errorSerializer = require('../../../lib/infrastructure/serializers/jsonapi/validation-error-serializer.js'); -const { UserNotFoundError } = require('../../domain/errors.js'); +import * as userRepository from '../../../lib/infrastructure/repositories/user-repository.js'; +import * as errorSerializer from '../../../lib/infrastructure/serializers/jsonapi/validation-error-serializer.js'; +import { UserNotFoundError } from '../../domain/errors.js'; -module.exports = { - verifyById(request, h, dependencies = { userRepository, errorSerializer }) { - return dependencies.userRepository.get(request.params.id).catch((err) => { - if (err instanceof UserNotFoundError) { - const serializedError = dependencies.errorSerializer.serialize(new UserNotFoundError().getErrorMessage()); - return h.response(serializedError).code(404).takeover(); - } - }); - }, +const verifyById = function (request, h, dependencies = { userRepository, errorSerializer }) { + return dependencies.userRepository.get(request.params.id).catch((err) => { + if (err instanceof UserNotFoundError) { + const serializedError = dependencies.errorSerializer.serialize(new UserNotFoundError().getErrorMessage()); + return h.response(serializedError).code(404).takeover(); + } + }); }; + +const userVerification = { verifyById }; + +export { userVerification }; diff --git a/api/lib/application/prescribers/index.js b/api/lib/application/prescribers/index.js index 29a59592dee..f70a89fc4ec 100644 --- a/api/lib/application/prescribers/index.js +++ b/api/lib/application/prescribers/index.js @@ -1,10 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const securityPreHandlers = require('../security-pre-handlers.js'); -const prescriberController = require('./prescriber-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { prescriberController } from './prescriber-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -33,4 +33,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'prescribers-api'; +const name = 'prescribers-api'; +export { register, name }; diff --git a/api/lib/application/prescribers/prescriber-controller.js b/api/lib/application/prescribers/prescriber-controller.js index 18171439d8b..1230691ccca 100644 --- a/api/lib/application/prescribers/prescriber-controller.js +++ b/api/lib/application/prescribers/prescriber-controller.js @@ -1,13 +1,15 @@ -const prescriberSerializer = require('../../infrastructure/serializers/jsonapi/prescriber-serializer.js'); +import * as prescriberSerializer from '../../infrastructure/serializers/jsonapi/prescriber-serializer.js'; -const usecases = require('../../domain/usecases/index.js'); +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - get(request, h, dependencies = { prescriberSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; +const get = function (request, h, dependencies = { prescriberSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; - return usecases - .getPrescriber({ userId: authenticatedUserId }) - .then((prescriber) => dependencies.prescriberSerializer.serialize(prescriber)); - }, + return usecases + .getPrescriber({ userId: authenticatedUserId }) + .then((prescriber) => dependencies.prescriberSerializer.serialize(prescriber)); }; + +const prescriberController = { get }; + +export { prescriberController }; diff --git a/api/lib/application/progressions/index.js b/api/lib/application/progressions/index.js index af87c9159ea..c488d02d0ed 100644 --- a/api/lib/application/progressions/index.js +++ b/api/lib/application/progressions/index.js @@ -1,11 +1,12 @@ -const ProgressionController = require('./progression-controller.js'); -exports.register = async function (server) { +import { progressionController } from './progression-controller.js'; + +const register = async function (server) { server.route([ { method: 'GET', path: '/api/progressions/{id}', config: { - handler: ProgressionController.get, + handler: progressionController.get, tags: ['api'], notes: [ '- **Route nécessitant une authentification**\n' + @@ -16,4 +17,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'progressions-api'; +const name = 'progressions-api'; +export { register, name }; diff --git a/api/lib/application/progressions/progression-controller.js b/api/lib/application/progressions/progression-controller.js index 711607299e3..2aea6a15bc8 100644 --- a/api/lib/application/progressions/progression-controller.js +++ b/api/lib/application/progressions/progression-controller.js @@ -1,17 +1,19 @@ -const ProgressionSerializer = require('../../infrastructure/serializers/jsonapi/progression-serializer.js'); -const usecases = require('../../domain/usecases/index.js'); +import * as ProgressionSerializer from '../../infrastructure/serializers/jsonapi/progression-serializer.js'; +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - get(request) { - const userId = request.auth.credentials.userId; +const get = function (request) { + const userId = request.auth.credentials.userId; - const progressionId = request.params.id; + const progressionId = request.params.id; - return usecases - .getProgression({ - progressionId, - userId, - }) - .then(ProgressionSerializer.serialize); - }, + return usecases + .getProgression({ + progressionId, + userId, + }) + .then(ProgressionSerializer.serialize); }; + +const progressionController = { get }; + +export { progressionController }; diff --git a/api/lib/application/saml/index.js b/api/lib/application/saml/index.js index 56b4b80912c..f3676b2a10b 100644 --- a/api/lib/application/saml/index.js +++ b/api/lib/application/saml/index.js @@ -1,6 +1,6 @@ -const samlController = require('./saml-controller.js'); +import { samlController } from './saml-controller.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'GET', @@ -34,4 +34,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'saml-api'; +const name = 'saml-api'; +export { register, name }; diff --git a/api/lib/application/saml/saml-controller.js b/api/lib/application/saml/saml-controller.js index c2be05c8c0b..d4b9b4b5dac 100644 --- a/api/lib/application/saml/saml-controller.js +++ b/api/lib/application/saml/saml-controller.js @@ -1,38 +1,40 @@ -const saml = require('../../infrastructure/saml.js'); -const usecases = require('../../domain/usecases/index.js'); -const logger = require('../../infrastructure/logger.js'); -const tokenService = require('../../domain/services/token-service.js'); -const settings = require('../../config.js'); +import * as saml from '../../infrastructure/saml.js'; +import { usecases } from '../../domain/usecases/index.js'; +import { logger } from '../../infrastructure/logger.js'; +import { tokenService } from '../../domain/services/token-service.js'; +import { config } from '../../config.js'; -module.exports = { - metadata(request, h) { - return h.response(saml.getServiceProviderMetadata()).type('application/xml'); - }, +const metadata = function (request, h) { + return h.response(saml.getServiceProviderMetadata()).type('application/xml'); +}; - login(request, h) { - return h.redirect(saml.createLoginRequest()); - }, +const login = function (request, h) { + return h.redirect(saml.createLoginRequest()); +}; - assert: async function (request, h) { - let userAttributes; - try { - userAttributes = await saml.parsePostResponse(request.payload); - } catch (e) { - logger.error({ e }, 'SAML: Error while parsing post response'); - return h.response(e.toString()).code(400); - } +const assert = async function (request, h) { + let userAttributes; + try { + userAttributes = await saml.parsePostResponse(request.payload); + } catch (e) { + logger.error({ e }, 'SAML: Error while parsing post response'); + return h.response(e.toString()).code(400); + } - try { - const redirectionUrl = await usecases.getExternalAuthenticationRedirectionUrl({ - userAttributes, - tokenService, - settings, - }); + try { + const redirectionUrl = await usecases.getExternalAuthenticationRedirectionUrl({ + userAttributes, + tokenService, + config, + }); - return h.redirect(redirectionUrl); - } catch (e) { - logger.error({ e }, 'SAML: Error while get external authentication redirection url'); - return h.response(e.toString()).code(500); - } - }, + return h.redirect(redirectionUrl); + } catch (e) { + logger.error({ e }, 'SAML: Error while get external authentication redirection url'); + return h.response(e.toString()).code(500); + } }; + +const samlController = { metadata, login, assert }; + +export { samlController }; diff --git a/api/lib/application/sco-organization-learners/index.js b/api/lib/application/sco-organization-learners/index.js index ca341c15663..7ed94e63876 100644 --- a/api/lib/application/sco-organization-learners/index.js +++ b/api/lib/application/sco-organization-learners/index.js @@ -1,18 +1,20 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { sendJsonApiError, UnprocessableEntityError, BadRequestError } = require('../http-errors.js'); -const scoOrganizationLearnerController = require('./sco-organization-learner-controller.js'); -const XRegExp = require('xregexp'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const { passwordValidationPattern } = require('../../config.js').account; +import { sendJsonApiError, UnprocessableEntityError, BadRequestError } from '../http-errors.js'; +import { scoOrganizationLearnerController } from './sco-organization-learner-controller.js'; +import XRegExp from 'xregexp'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { config } from '../../config.js'; + +const { passwordValidationPattern } = config.account; const inePattern = new RegExp('^[0-9]{9}[a-zA-Z]{2}$'); const inaPattern = new RegExp('^[0-9]{10}[a-zA-Z]{1}$'); -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -264,4 +266,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'sco-organization-learners-api'; +const name = 'sco-organization-learners-api'; +export { register, name }; diff --git a/api/lib/application/sco-organization-learners/sco-organization-learner-controller.js b/api/lib/application/sco-organization-learners/sco-organization-learner-controller.js index c6c31d92866..1f2708953e7 100644 --- a/api/lib/application/sco-organization-learners/sco-organization-learner-controller.js +++ b/api/lib/application/sco-organization-learners/sco-organization-learner-controller.js @@ -1,169 +1,194 @@ -const usecases = require('../../domain/usecases/index.js'); -const scoOrganizationLearnerSerializer = require('../../infrastructure/serializers/jsonapi/sco-organization-learner-serializer.js'); -const requestReponseUtils = require('../../infrastructure/utils/request-response-utils.js'); -const studentInformationForAccountRecoverySerializer = require('../../infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js'); - -module.exports = { - async reconcileScoOrganizationLearnerManually(request, h, dependencies = { scoOrganizationLearnerSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - const payload = request.payload.data.attributes; - const campaignCode = payload['campaign-code']; - const withReconciliation = request.query.withReconciliation === 'true'; - - const reconciliationInfo = { - id: authenticatedUserId, - firstName: payload['first-name'], - lastName: payload['last-name'], - birthdate: payload['birthdate'], - }; - - const organizationLearner = await usecases.reconcileScoOrganizationLearnerManually({ - campaignCode, - reconciliationInfo, - withReconciliation, - }); - - let response; - if (withReconciliation) { - const serializedData = dependencies.scoOrganizationLearnerSerializer.serializeIdentity(organizationLearner); - response = h.response(serializedData).code(200); - } else { - response = h.response().code(204); - } - return response; - }, - - async reconcileScoOrganizationLearnerAutomatically(request, h, dependencies = { scoOrganizationLearnerSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - const payload = request.payload.data.attributes; - const campaignCode = payload['campaign-code']; - const organizationLearner = await usecases.reconcileScoOrganizationLearnerAutomatically({ - userId: authenticatedUserId, - campaignCode, - }); - - return h.response(dependencies.scoOrganizationLearnerSerializer.serializeIdentity(organizationLearner)); - }, - - async generateUsername(request, h, dependencies = { scoOrganizationLearnerSerializer }) { - const payload = request.payload.data.attributes; - const { 'campaign-code': campaignCode } = payload; - - const studentInformation = { - firstName: payload['first-name'], - lastName: payload['last-name'], - birthdate: payload['birthdate'], - }; - - const username = await usecases.generateUsername({ campaignCode, studentInformation }); - - const scoOrganizationLearner = { - ...studentInformation, - username, - campaignCode, - }; - - return h - .response(dependencies.scoOrganizationLearnerSerializer.serializeWithUsernameGeneration(scoOrganizationLearner)) - .code(200); - }, - - async createAndReconcileUserToOrganizationLearner( - request, - h, - dependencies = { - scoOrganizationLearnerSerializer, - requestReponseUtils, - } - ) { - const payload = request.payload.data.attributes; - const userAttributes = { - firstName: payload['first-name'], - lastName: payload['last-name'], - birthdate: payload['birthdate'], - email: payload.email, - username: payload.username, - withUsername: payload['with-username'], - }; - const locale = dependencies.requestReponseUtils.extractLocaleFromRequest(request); - - await usecases.createAndReconcileUserToOrganizationLearner({ - userAttributes, - password: payload.password, - campaignCode: payload['campaign-code'], - locale, - }); - - return h.response().code(204); - }, - - async createUserAndReconcileToOrganizationLearnerFromExternalUser( - request, - h, - dependencies = { scoOrganizationLearnerSerializer } - ) { - const { birthdate, 'campaign-code': campaignCode, 'external-user-token': token } = request.payload.data.attributes; - - const accessToken = await usecases.createUserAndReconcileToOrganizationLearnerFromExternalUser({ - birthdate, - campaignCode, - token, - }); - - const scoOrganizationLearner = { - accessToken, - }; - - return h - .response(dependencies.scoOrganizationLearnerSerializer.serializeExternal(scoOrganizationLearner)) - .code(200); - }, - - async updatePassword(request, h, dependencies = { scoOrganizationLearnerSerializer }) { - const payload = request.payload.data.attributes; - const userId = request.auth.credentials.userId; - const organizationId = payload['organization-id']; - const organizationLearnerId = payload['organization-learner-id']; - - const generatedPassword = await usecases.updateOrganizationLearnerDependentUserPassword({ - userId, - organizationId, - organizationLearnerId, - }); - - const scoOrganizationLearner = { - generatedPassword, - }; - - return h - .response(dependencies.scoOrganizationLearnerSerializer.serializeCredentialsForDependent(scoOrganizationLearner)) - .code(200); - }, - - async generateUsernameWithTemporaryPassword(request, h, dependencies = { scoOrganizationLearnerSerializer }) { - const payload = request.payload.data.attributes; - const organizationId = payload['organization-id']; - const organizationLearnerId = payload['organization-learner-id']; - - const result = await usecases.generateUsernameWithTemporaryPassword({ - organizationLearnerId, - organizationId, - }); - - return h.response(dependencies.scoOrganizationLearnerSerializer.serializeCredentialsForDependent(result)).code(200); - }, - - async checkScoAccountRecovery(request, h, dependencies = { studentInformationForAccountRecoverySerializer }) { - const studentInformation = await dependencies.studentInformationForAccountRecoverySerializer.deserialize( - request.payload - ); - - const studentInformationForAccountRecovery = await usecases.checkScoAccountRecovery({ - studentInformation, - }); - - return h.response( - dependencies.studentInformationForAccountRecoverySerializer.serialize(studentInformationForAccountRecovery) - ); - }, +import { usecases } from '../../domain/usecases/index.js'; +import * as scoOrganizationLearnerSerializer from '../../infrastructure/serializers/jsonapi/sco-organization-learner-serializer.js'; +import * as requestReponseUtils from '../../infrastructure/utils/request-response-utils.js'; +import * as studentInformationForAccountRecoverySerializer from '../../infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js'; + +const reconcileScoOrganizationLearnerManually = async function ( + request, + h, + dependencies = { scoOrganizationLearnerSerializer } +) { + const authenticatedUserId = request.auth.credentials.userId; + const payload = request.payload.data.attributes; + const campaignCode = payload['campaign-code']; + const withReconciliation = request.query.withReconciliation === 'true'; + + const reconciliationInfo = { + id: authenticatedUserId, + firstName: payload['first-name'], + lastName: payload['last-name'], + birthdate: payload['birthdate'], + }; + + const organizationLearner = await usecases.reconcileScoOrganizationLearnerManually({ + campaignCode, + reconciliationInfo, + withReconciliation, + }); + + let response; + if (withReconciliation) { + const serializedData = dependencies.scoOrganizationLearnerSerializer.serializeIdentity(organizationLearner); + response = h.response(serializedData).code(200); + } else { + response = h.response().code(204); + } + return response; }; + +const reconcileScoOrganizationLearnerAutomatically = async function ( + request, + h, + dependencies = { scoOrganizationLearnerSerializer } +) { + const authenticatedUserId = request.auth.credentials.userId; + const payload = request.payload.data.attributes; + const campaignCode = payload['campaign-code']; + const organizationLearner = await usecases.reconcileScoOrganizationLearnerAutomatically({ + userId: authenticatedUserId, + campaignCode, + }); + + return h.response(dependencies.scoOrganizationLearnerSerializer.serializeIdentity(organizationLearner)); +}; + +const generateUsername = async function (request, h, dependencies = { scoOrganizationLearnerSerializer }) { + const payload = request.payload.data.attributes; + const { 'campaign-code': campaignCode } = payload; + + const studentInformation = { + firstName: payload['first-name'], + lastName: payload['last-name'], + birthdate: payload['birthdate'], + }; + + const username = await usecases.generateUsername({ campaignCode, studentInformation }); + + const scoOrganizationLearner = { + ...studentInformation, + username, + campaignCode, + }; + + return h + .response(dependencies.scoOrganizationLearnerSerializer.serializeWithUsernameGeneration(scoOrganizationLearner)) + .code(200); +}; + +const createAndReconcileUserToOrganizationLearner = async function ( + request, + h, + dependencies = { + scoOrganizationLearnerSerializer, + requestReponseUtils, + } +) { + const payload = request.payload.data.attributes; + const userAttributes = { + firstName: payload['first-name'], + lastName: payload['last-name'], + birthdate: payload['birthdate'], + email: payload.email, + username: payload.username, + withUsername: payload['with-username'], + }; + const locale = dependencies.requestReponseUtils.extractLocaleFromRequest(request); + + await usecases.createAndReconcileUserToOrganizationLearner({ + userAttributes, + password: payload.password, + campaignCode: payload['campaign-code'], + locale, + }); + + return h.response().code(204); +}; + +const createUserAndReconcileToOrganizationLearnerFromExternalUser = async function ( + request, + h, + dependencies = { scoOrganizationLearnerSerializer } +) { + const { birthdate, 'campaign-code': campaignCode, 'external-user-token': token } = request.payload.data.attributes; + + const accessToken = await usecases.createUserAndReconcileToOrganizationLearnerFromExternalUser({ + birthdate, + campaignCode, + token, + }); + + const scoOrganizationLearner = { + accessToken, + }; + + return h.response(dependencies.scoOrganizationLearnerSerializer.serializeExternal(scoOrganizationLearner)).code(200); +}; + +const updatePassword = async function (request, h, dependencies = { scoOrganizationLearnerSerializer }) { + const payload = request.payload.data.attributes; + const userId = request.auth.credentials.userId; + const organizationId = payload['organization-id']; + const organizationLearnerId = payload['organization-learner-id']; + + const generatedPassword = await usecases.updateOrganizationLearnerDependentUserPassword({ + userId, + organizationId, + organizationLearnerId, + }); + + const scoOrganizationLearner = { + generatedPassword, + }; + + return h + .response(dependencies.scoOrganizationLearnerSerializer.serializeCredentialsForDependent(scoOrganizationLearner)) + .code(200); +}; + +const generateUsernameWithTemporaryPassword = async function ( + request, + h, + dependencies = { scoOrganizationLearnerSerializer } +) { + const payload = request.payload.data.attributes; + const organizationId = payload['organization-id']; + const organizationLearnerId = payload['organization-learner-id']; + + const result = await usecases.generateUsernameWithTemporaryPassword({ + organizationLearnerId, + organizationId, + }); + + return h.response(dependencies.scoOrganizationLearnerSerializer.serializeCredentialsForDependent(result)).code(200); +}; + +const checkScoAccountRecovery = async function ( + request, + h, + dependencies = { studentInformationForAccountRecoverySerializer } +) { + const studentInformation = await dependencies.studentInformationForAccountRecoverySerializer.deserialize( + request.payload + ); + + const studentInformationForAccountRecovery = await usecases.checkScoAccountRecovery({ + studentInformation, + }); + + return h.response( + dependencies.studentInformationForAccountRecoverySerializer.serialize(studentInformationForAccountRecovery) + ); +}; + +const scoOrganizationLearnerController = { + reconcileScoOrganizationLearnerManually, + reconcileScoOrganizationLearnerAutomatically, + generateUsername, + createAndReconcileUserToOrganizationLearner, + createUserAndReconcileToOrganizationLearnerFromExternalUser, + updatePassword, + generateUsernameWithTemporaryPassword, + checkScoAccountRecovery, +}; + +export { scoOrganizationLearnerController }; diff --git a/api/lib/application/scorecards/index.js b/api/lib/application/scorecards/index.js index 06fefaed2c4..8a0e27d1d41 100644 --- a/api/lib/application/scorecards/index.js +++ b/api/lib/application/scorecards/index.js @@ -1,6 +1,6 @@ -const scorecardController = require('./scorecard-controller.js'); +import { scorecardController } from './scorecard-controller.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'GET', @@ -31,4 +31,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'scorecards-api'; +const name = 'scorecards-api'; +export { register, name }; diff --git a/api/lib/application/scorecards/scorecard-controller.js b/api/lib/application/scorecards/scorecard-controller.js index 9b2af650682..8e37c93527c 100644 --- a/api/lib/application/scorecards/scorecard-controller.js +++ b/api/lib/application/scorecards/scorecard-controller.js @@ -1,34 +1,35 @@ -const scorecardSerializer = require('../../infrastructure/serializers/jsonapi/scorecard-serializer.js'); -const tutorialSerializer = require('../../infrastructure/serializers/jsonapi/tutorial-serializer.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); -const usecases = require('../../domain/usecases/index.js'); +import * as scorecardSerializer from '../../infrastructure/serializers/jsonapi/scorecard-serializer.js'; +import * as tutorialSerializer from '../../infrastructure/serializers/jsonapi/tutorial-serializer.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - getScorecard(request, h, dependencies = { requestResponseUtils, scorecardSerializer }) { - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - const authenticatedUserId = request.auth.credentials.userId; - const scorecardId = request.params.id; +const getScorecard = function (request, h, dependencies = { requestResponseUtils, scorecardSerializer }) { + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const authenticatedUserId = request.auth.credentials.userId; + const scorecardId = request.params.id; - return usecases - .getScorecard({ - authenticatedUserId, - scorecardId, - locale, - }) - .then(dependencies.scorecardSerializer.serialize); - }, + return usecases + .getScorecard({ + authenticatedUserId, + scorecardId, + locale, + }) + .then(dependencies.scorecardSerializer.serialize); +}; - findTutorials(request, h, dependencies = { requestResponseUtils, tutorialSerializer }) { - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - const authenticatedUserId = request.auth.credentials.userId; - const scorecardId = request.params.id; +const findTutorials = function (request, h, dependencies = { requestResponseUtils, tutorialSerializer }) { + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const authenticatedUserId = request.auth.credentials.userId; + const scorecardId = request.params.id; - return usecases - .findTutorials({ - authenticatedUserId, - scorecardId, - locale, - }) - .then(dependencies.tutorialSerializer.serialize); - }, + return usecases + .findTutorials({ + authenticatedUserId, + scorecardId, + locale, + }) + .then(dependencies.tutorialSerializer.serialize); }; + +const scorecardController = { getScorecard, findTutorials }; +export { scorecardController }; diff --git a/api/lib/application/scoring-simulator/index.js b/api/lib/application/scoring-simulator/index.js index 9a46695f9f6..56b82dcdf27 100644 --- a/api/lib/application/scoring-simulator/index.js +++ b/api/lib/application/scoring-simulator/index.js @@ -1,8 +1,8 @@ -const Joi = require('joi'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const scoringSimulatorController = require('./scoring-simulator-controller.js'); +import Joi from 'joi'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { scoringSimulatorController } from './scoring-simulator-controller.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'POST', @@ -105,4 +105,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'scoring-simulator-api'; +const name = 'scoring-simulator-api'; +export { register, name }; diff --git a/api/lib/application/scoring-simulator/scoring-simulator-controller.js b/api/lib/application/scoring-simulator/scoring-simulator-controller.js index 87d78f51311..4860ff344c6 100644 --- a/api/lib/application/scoring-simulator/scoring-simulator-controller.js +++ b/api/lib/application/scoring-simulator/scoring-simulator-controller.js @@ -1,37 +1,39 @@ -const usecases = require('../../domain/usecases/index.js'); -const { extractLocaleFromRequest } = require('../../infrastructure/utils/request-response-utils.js'); -const scoringSimulationContextSerializer = require('../../infrastructure/serializers/json/scoring-simulator/scoring-simulation-context-serializer.js'); -const scoringSimulationDatasetSerializer = require('../../infrastructure/serializers/json/scoring-simulator/scoring-simulation-dataset-serializer.js'); - -module.exports = { - async calculateOldScores(request, h) { - const dataset = scoringSimulationDatasetSerializer.deserialize(request); - - const results = await usecases.simulateOldScoring({ simulations: dataset.simulations }); - - return h.response({ - datasetId: dataset.id, - results, - date: new Date().toISOString(), - }); - }, - - async calculateFlashScores(request, h) { - const context = scoringSimulationContextSerializer.deserialize(request); - const dataset = scoringSimulationDatasetSerializer.deserialize(request); - const locale = extractLocaleFromRequest(request); - - const results = await usecases.simulateFlashScoring({ - context, - simulations: dataset.simulations, - locale, - }); - - return h.response({ - contextId: context.id, - datasetId: dataset.id, - results, - date: new Date().toISOString(), - }); - }, +import { usecases } from '../../domain/usecases/index.js'; +import { extractLocaleFromRequest } from '../../infrastructure/utils/request-response-utils.js'; +import * as scoringSimulationContextSerializer from '../../infrastructure/serializers/json/scoring-simulator/scoring-simulation-context-serializer.js'; +import * as scoringSimulationDatasetSerializer from '../../infrastructure/serializers/json/scoring-simulator/scoring-simulation-dataset-serializer.js'; + +const calculateOldScores = async function (request, h) { + const dataset = scoringSimulationDatasetSerializer.deserialize(request); + + const results = await usecases.simulateOldScoring({ simulations: dataset.simulations }); + + return h.response({ + datasetId: dataset.id, + results, + date: new Date().toISOString(), + }); }; + +const calculateFlashScores = async function (request, h) { + const context = scoringSimulationContextSerializer.deserialize(request); + const dataset = scoringSimulationDatasetSerializer.deserialize(request); + const locale = extractLocaleFromRequest(request); + + const results = await usecases.simulateFlashScoring({ + context, + simulations: dataset.simulations, + locale, + }); + + return h.response({ + contextId: context.id, + datasetId: dataset.id, + results, + date: new Date().toISOString(), + }); +}; + +const scoringSimulatorController = { calculateOldScores, calculateFlashScores }; + +export { scoringSimulatorController }; diff --git a/api/lib/application/security-pre-handlers.js b/api/lib/application/security-pre-handlers.js index a204ba6e008..3f90e1c4439 100644 --- a/api/lib/application/security-pre-handlers.js +++ b/api/lib/application/security-pre-handlers.js @@ -1,32 +1,36 @@ -/* eslint-disable no-restricted-syntax */ -const bluebird = require('bluebird'); -const checkIfUserIsBlockedUseCase = require('./usecases/checkIfUserIsBlocked.js'); -const checkAdminMemberHasRoleSuperAdminUseCase = require('./usecases/checkAdminMemberHasRoleSuperAdmin.js'); -const checkAdminMemberHasRoleCertifUseCase = require('./usecases/checkAdminMemberHasRoleCertif.js'); -const checkAdminMemberHasRoleSupportUseCase = require('./usecases/checkAdminMemberHasRoleSupport.js'); -const checkAdminMemberHasRoleMetierUseCase = require('./usecases/checkAdminMemberHasRoleMetier.js'); -const checkUserIsAdminInOrganizationUseCase = require('./usecases/checkUserIsAdminInOrganization.js'); -const checkUserBelongsToOrganizationManagingStudentsUseCase = require('./usecases/checkUserBelongsToOrganizationManagingStudents.js'); -const checkUserBelongsToLearnersOrganizationUseCase = require('./usecases/checkUserBelongsToLearnersOrganization.js'); -const checkUserBelongsToScoOrganizationAndManagesStudentsUseCase = require('./usecases/checkUserBelongsToScoOrganizationAndManagesStudents.js'); -const checkUserBelongsToSupOrganizationAndManagesStudentsUseCase = require('./usecases/checkUserBelongsToSupOrganizationAndManagesStudents.js'); -const checkUserOwnsCertificationCourseUseCase = require('./usecases/checkUserOwnsCertificationCourse.js'); -const checkUserBelongsToOrganizationUseCase = require('./usecases/checkUserBelongsToOrganization.js'); -const checkUserIsAdminAndManagingStudentsForOrganization = require('./usecases/checkUserIsAdminAndManagingStudentsForOrganization.js'); -const checkUserIsMemberOfAnOrganizationUseCase = require('./usecases/checkUserIsMemberOfAnOrganization.js'); -const checkUserIsMemberOfCertificationCenterUsecase = require('./usecases/checkUserIsMemberOfCertificationCenter.js'); -const checkUserIsMemberOfCertificationCenterSessionUsecase = require('./usecases/checkUserIsMemberOfCertificationCenterSession.js'); -const checkAuthorizationToManageCampaignUsecase = require('./usecases/checkAuthorizationToManageCampaign.js'); -const checkOrganizationIsScoAndManagingStudentUsecase = require('./usecases/checkOrganizationIsScoAndManagingStudent'); -const checkPix1dEnabled = require('./usecases/checkPix1dEnabled.js'); -const certificationIssueReportRepository = require('../infrastructure/repositories/certification-issue-report-repository.js'); -const organizationRepository = require('../infrastructure/repositories/organization-repository'); -const Organization = require('../../lib/domain/models/Organization.js'); -const { ForbiddenAccess, NotFoundError } = require('../..//lib/domain/errors.js'); -const apps = require('../..//lib/domain/constants.js'); - -const JSONAPIError = require('jsonapi-serializer').Error; -const has = require('lodash/has'); +import bluebird from 'bluebird'; +import * as checkIfUserIsBlockedUseCase from './usecases/checkIfUserIsBlocked.js'; +import * as checkAdminMemberHasRoleSuperAdminUseCase from './usecases/checkAdminMemberHasRoleSuperAdmin.js'; +import * as checkAdminMemberHasRoleCertifUseCase from './usecases/checkAdminMemberHasRoleCertif.js'; +import * as checkAdminMemberHasRoleSupportUseCase from './usecases/checkAdminMemberHasRoleSupport.js'; +import * as checkAdminMemberHasRoleMetierUseCase from './usecases/checkAdminMemberHasRoleMetier.js'; +import * as checkUserIsAdminInOrganizationUseCase from './usecases/checkUserIsAdminInOrganization.js'; +import * as checkUserBelongsToOrganizationManagingStudentsUseCase from './usecases/checkUserBelongsToOrganizationManagingStudents.js'; +import * as checkUserBelongsToLearnersOrganizationUseCase from './usecases/checkUserBelongsToLearnersOrganization.js'; +import * as checkUserBelongsToScoOrganizationAndManagesStudentsUseCase from './usecases/checkUserBelongsToScoOrganizationAndManagesStudents.js'; +import * as checkUserBelongsToSupOrganizationAndManagesStudentsUseCase from './usecases/checkUserBelongsToSupOrganizationAndManagesStudents.js'; +import * as checkUserOwnsCertificationCourseUseCase from './usecases/checkUserOwnsCertificationCourse.js'; +import * as checkUserBelongsToOrganizationUseCase from './usecases/checkUserBelongsToOrganization.js'; +import * as checkUserIsAdminAndManagingStudentsForOrganization from './usecases/checkUserIsAdminAndManagingStudentsForOrganization.js'; +import * as checkUserIsMemberOfAnOrganizationUseCase from './usecases/checkUserIsMemberOfAnOrganization.js'; +import * as checkUserIsMemberOfCertificationCenterUsecase from './usecases/checkUserIsMemberOfCertificationCenter.js'; +import * as checkUserIsMemberOfCertificationCenterSessionUsecase from './usecases/checkUserIsMemberOfCertificationCenterSession.js'; +import * as checkAuthorizationToManageCampaignUsecase from './usecases/checkAuthorizationToManageCampaign.js'; +import * as checkOrganizationIsScoAndManagingStudentUsecase from './usecases/checkOrganizationIsScoAndManagingStudent.js'; +import * as checkPix1dEnabled from './usecases/checkPix1dEnabled.js'; +import * as certificationIssueReportRepository from '../infrastructure/repositories/certification-issue-report-repository.js'; +import * as organizationRepository from '../infrastructure/repositories/organization-repository.js'; +import { Organization } from '../../lib/domain/models/Organization.js'; +import { ForbiddenAccess, NotFoundError } from '../..//lib/domain/errors.js'; +import { PIX_ADMIN } from '../..//lib/domain/constants.js'; + +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Error: JSONAPIError } = jsonapiSerializer; + +const { has } = lodash; + +import lodash from 'lodash'; function _replyForbiddenError(h) { const errorHttpStatusCode = 403; @@ -72,7 +76,7 @@ async function checkAdminMemberHasRoleSuperAdmin( try { const hasRoleSuperAdmin = await dependencies.checkAdminMemberHasRoleSuperAdminUseCase.execute(userId); if (!hasRoleSuperAdmin) { - throw new ForbiddenAccess(apps.PIX_ADMIN.NOT_ALLOWED_MSG); + throw new ForbiddenAccess(PIX_ADMIN.NOT_ALLOWED_MSG); } return h.response(true); } catch (e) { @@ -90,7 +94,7 @@ async function checkAdminMemberHasRoleCertif(request, h, dependencies = { checkA try { const hasRoleCertif = await dependencies.checkAdminMemberHasRoleCertifUseCase.execute(userId); if (!hasRoleCertif) { - throw new ForbiddenAccess(apps.PIX_ADMIN.NOT_ALLOWED_MSG); + throw new ForbiddenAccess(PIX_ADMIN.NOT_ALLOWED_MSG); } return h.response(true); } catch (e) { @@ -108,7 +112,7 @@ async function checkAdminMemberHasRoleSupport(request, h, dependencies = { check try { const hasRoleSupport = await dependencies.checkAdminMemberHasRoleSupportUseCase.execute(userId); if (!hasRoleSupport) { - throw new ForbiddenAccess(apps.PIX_ADMIN.NOT_ALLOWED_MSG); + throw new ForbiddenAccess(PIX_ADMIN.NOT_ALLOWED_MSG); } return h.response(true); } catch (e) { @@ -126,7 +130,7 @@ async function checkAdminMemberHasRoleMetier(request, h, dependencies = { checkA try { const hasRoleMetier = await dependencies.checkAdminMemberHasRoleMetierUseCase.execute(userId); if (!hasRoleMetier) { - throw new ForbiddenAccess(apps.PIX_ADMIN.NOT_ALLOWED_MSG); + throw new ForbiddenAccess(PIX_ADMIN.NOT_ALLOWED_MSG); } return h.response(true); } catch (e) { @@ -140,7 +144,10 @@ function checkRequestedUserIsAuthenticatedUser(request, h) { } const authenticatedUserId = request.auth.credentials.userId; - const requestedUserId = parseInt(request.params.userId) || parseInt(request.params.id); + + // We cannot guarantee that callers will enforce the type to be an integer upstream + // eslint-disable-next-line no-restricted-syntax + const requestedUserId = request.params.userId || parseInt(request.params.id); return authenticatedUserId === requestedUserId ? h.response(true) : _replyForbiddenError(h); } @@ -156,7 +163,7 @@ function checkUserIsAdminInOrganization(request, h, dependencies = { checkUserIs const organizationId = request.path && request.path.includes('memberships') ? request.payload.data.relationships.organization.data.id - : parseInt(request.params.id); + : request.params.id; return dependencies.checkUserIsAdminInOrganizationUseCase .execute(userId, organizationId) @@ -179,7 +186,7 @@ function checkUserIsMemberOfCertificationCenter( } const userId = request.auth.credentials.userId; - const certificationCenterId = parseInt(request.params.certificationCenterId); + const certificationCenterId = request.params.certificationCenterId; return dependencies.checkUserIsMemberOfCertificationCenterUsecase .execute(userId, certificationCenterId) @@ -202,7 +209,7 @@ async function checkUserIsMemberOfCertificationCenterSessionFromCertificationIss } const userId = request.auth.credentials.userId; - const certificationIssueReportId = parseInt(request.params.id); + const certificationIssueReportId = request.params.id; try { const certificationIssueReport = await dependencies.certificationIssueReportRepository.get( @@ -230,7 +237,7 @@ async function checkUserIsMemberOfCertificationCenterSessionFromCertificationCou } const userId = request.auth.credentials.userId; - const certificationCourseId = parseInt(request.params.id); + const certificationCourseId = request.params.id; try { const isMemberOfSession = await dependencies.checkUserIsMemberOfCertificationCenterSessionUsecase.execute({ @@ -253,7 +260,7 @@ async function checkUserBelongsToOrganizationManagingStudents( } const userId = request.auth.credentials.userId; - const organizationId = parseInt(request.params.id); + const organizationId = request.params.id; try { if (await dependencies.checkUserBelongsToOrganizationManagingStudentsUseCase.execute(userId, organizationId)) { @@ -275,7 +282,7 @@ async function checkUserBelongsToScoOrganizationAndManagesStudents( } const userId = request.auth.credentials.userId; - const organizationId = parseInt(request.params.id) || parseInt(request.payload.data.attributes['organization-id']); + const organizationId = request.params.id || request.payload.data.attributes['organization-id']; let belongsToScoOrganizationAndManageStudents; try { @@ -306,8 +313,7 @@ async function checkCertificationCenterIsNotScoManagingStudents( } const certificationCenterId = - parseInt(request?.params?.certificationCenterId) || - parseInt(request?.payload?.data?.attributes?.certificationCenterId); + request?.params?.certificationCenterId || request?.payload?.data?.attributes?.certificationCenterId; let organizationId; @@ -344,7 +350,7 @@ async function checkUserBelongsToSupOrganizationAndManagesStudents( } const userId = request.auth.credentials.userId; - const organizationId = parseInt(request.params.id) || parseInt(request.payload.data.attributes['organization-id']); + const organizationId = request.params.id || request.payload.data.attributes['organization-id']; let belongsToSupOrganizationAndManageStudents; try { @@ -367,7 +373,7 @@ async function checkUserIsAdminInSCOOrganizationManagingStudents( dependencies = { checkUserIsAdminAndManagingStudentsForOrganization } ) { const userId = request.auth.credentials.userId; - const organizationId = parseInt(request.params.id); + const organizationId = request.params.id; if ( await dependencies.checkUserIsAdminAndManagingStudentsForOrganization.execute( @@ -387,7 +393,7 @@ async function checkUserIsAdminInSUPOrganizationManagingStudents( dependencies = { checkUserIsAdminAndManagingStudentsForOrganization } ) { const userId = request.auth.credentials.userId; - const organizationId = parseInt(request.params.id); + const organizationId = request.params.id; if ( await dependencies.checkUserIsAdminAndManagingStudentsForOrganization.execute( @@ -412,7 +418,7 @@ async function checkUserBelongsToLearnersOrganization( } const userId = request.auth.credentials.userId; - const organizationLearnerId = parseInt(request.params.id); + const organizationLearnerId = request.params.id; let belongsToLearnersOrganization; @@ -436,7 +442,7 @@ async function checkUserBelongsToOrganization(request, h, dependencies = { check } const userId = request.auth.credentials.userId; - const organizationId = parseInt(request.params.id); + const organizationId = request.params.id; const belongsToOrganization = await dependencies.checkUserBelongsToOrganizationUseCase.execute( userId, @@ -495,6 +501,7 @@ function adminMemberHasAtLeastOneAccessOf(securityChecks) { return hasAccess ? hasAccess : _replyForbiddenError(h); }; } + async function checkPix1dActivated(request, h, dependencies = { checkPix1dEnabled }) { const isPix1dEnabled = await dependencies.checkPix1dEnabled.execute(); @@ -512,7 +519,7 @@ async function checkUserOwnsCertificationCourse( } const userId = request.auth.credentials.userId; - const certificationCourseId = parseInt(request.params.id); + const certificationCourseId = request.params.id; try { const ownsCertificationCourse = await dependencies.checkUserOwnsCertificationCourseUseCase.execute({ @@ -529,9 +536,7 @@ function _noOrganizationFound(error) { return error instanceof NotFoundError; } -/* eslint-enable no-restricted-syntax */ - -module.exports = { +const securityPreHandlers = { checkIfUserIsBlocked, checkPix1dActivated, checkRequestedUserIsAuthenticatedUser, @@ -547,7 +552,7 @@ module.exports = { checkAuthorizationToManageCampaign, checkUserIsAdminInSCOOrganizationManagingStudents, checkUserIsAdminInSUPOrganizationManagingStudents, - checkUserBelongsToLearnersOrganization: checkUserBelongsToLearnersOrganization, + checkUserBelongsToLearnersOrganization, checkUserBelongsToOrganization, checkUserIsMemberOfAnOrganization, checkUserIsMemberOfCertificationCenter, @@ -556,3 +561,5 @@ module.exports = { checkUserIsMemberOfCertificationCenterSessionFromCertificationIssueReportId, adminMemberHasAtLeastOneAccessOf, }; + +export { securityPreHandlers }; diff --git a/api/lib/application/sessions/finalized-session-controller.js b/api/lib/application/sessions/finalized-session-controller.js index b5b60a4859a..93f2dc61fdf 100644 --- a/api/lib/application/sessions/finalized-session-controller.js +++ b/api/lib/application/sessions/finalized-session-controller.js @@ -1,15 +1,20 @@ -const usecases = require('../../domain/usecases/index.js'); -const toBePublishedSessionSerializer = require('../../infrastructure/serializers/jsonapi/to-be-published-session-serializer.js'); -const withRequiredActionSessionSerializer = require('../../infrastructure/serializers/jsonapi/with-required-action-session-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as toBePublishedSessionSerializer from '../../infrastructure/serializers/jsonapi/to-be-published-session-serializer.js'; +import * as withRequiredActionSessionSerializer from '../../infrastructure/serializers/jsonapi/with-required-action-session-serializer.js'; -module.exports = { - async findFinalizedSessionsToPublish(request, h, dependencies = { toBePublishedSessionSerializer }) { - const finalizedSessionsToPublish = await usecases.findFinalizedSessionsToPublish(); - return dependencies.toBePublishedSessionSerializer.serialize(finalizedSessionsToPublish); - }, +const findFinalizedSessionsToPublish = async function (request, h, dependencies = { toBePublishedSessionSerializer }) { + const finalizedSessionsToPublish = await usecases.findFinalizedSessionsToPublish(); + return dependencies.toBePublishedSessionSerializer.serialize(finalizedSessionsToPublish); +}; - async findFinalizedSessionsWithRequiredAction(request, h, dependencies = { withRequiredActionSessionSerializer }) { - const finalizedSessionsWithRequiredAction = await usecases.findFinalizedSessionsWithRequiredAction(); - return dependencies.withRequiredActionSessionSerializer.serialize(finalizedSessionsWithRequiredAction); - }, +const findFinalizedSessionsWithRequiredAction = async function ( + request, + h, + dependencies = { withRequiredActionSessionSerializer } +) { + const finalizedSessionsWithRequiredAction = await usecases.findFinalizedSessionsWithRequiredAction(); + return dependencies.withRequiredActionSessionSerializer.serialize(finalizedSessionsWithRequiredAction); }; + +const finalizedSessionController = { findFinalizedSessionsToPublish, findFinalizedSessionsWithRequiredAction }; +export { finalizedSessionController }; diff --git a/api/lib/application/sessions/index.js b/api/lib/application/sessions/index.js index a4face2b73d..0d919523eb9 100644 --- a/api/lib/application/sessions/index.js +++ b/api/lib/application/sessions/index.js @@ -1,15 +1,15 @@ -const Joi = require('joi'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const sessionController = require('./session-controller.js'); -const sessionForSupervisingController = require('./session-for-supervising-controller.js'); -const sessionWithCleaCertifiedCandidateController = require('./session-with-clea-certified-candidate-controller.js'); -const finalizedSessionController = require('./finalized-session-controller.js'); -const authorization = require('../preHandlers/authorization.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const { sendJsonApiError, UnprocessableEntityError } = require('../http-errors.js'); -const assessmentSupervisorAuthorization = require('../preHandlers/session-supervisor-authorization.js'); +import Joi from 'joi'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { sessionController } from './session-controller.js'; +import { sessionForSupervisingController } from './session-for-supervising-controller.js'; +import { sessionWithCleaCertifiedCandidateController } from './session-with-clea-certified-candidate-controller.js'; +import { finalizedSessionController } from './finalized-session-controller.js'; +import { authorization } from '../preHandlers/authorization.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { sendJsonApiError, UnprocessableEntityError } from '../http-errors.js'; +import { assessmentSupervisorAuthorization } from '../preHandlers/session-supervisor-authorization.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'GET', @@ -720,7 +720,7 @@ exports.register = async (server) => { assign: 'authorizationCheck', }, ], - handler: sessionController.delete, + handler: sessionController.remove, notes: [ "- **Cette route est restreinte aux utilisateurs authentifiés ayant les droits d'accès au centre de certification**\n" + "- Supprime la session et les candidats si la session n'a pas démarrée", @@ -777,4 +777,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'sessions-api'; +const name = 'sessions-api'; +export { register, name }; diff --git a/api/lib/application/sessions/session-controller.js b/api/lib/application/sessions/session-controller.js index 7d630e10fcb..9090467ddca 100644 --- a/api/lib/application/sessions/session-controller.js +++ b/api/lib/application/sessions/session-controller.js @@ -1,368 +1,416 @@ -const moment = require('moment'); -const { BadRequestError, SessionPublicationBatchError } = require('../http-errors.js'); -const usecases = require('../../domain/usecases/index.js'); -const tokenService = require('../../domain/services/token-service.js'); -const sessionResultsLinkService = require('../../domain/services/session-results-link-service.js'); -const sessionValidator = require('../../domain/validators/session-validator.js'); -const events = require('../../domain/events/index.js'); -const { CertificationCandidateAlreadyLinkedToUserError } = require('../../domain/errors.js'); -const sessionSerializer = require('../../infrastructure/serializers/jsonapi/session-serializer.js'); -const jurySessionSerializer = require('../../infrastructure/serializers/jsonapi/jury-session-serializer.js'); -const certificationCandidateSerializer = require('../../infrastructure/serializers/jsonapi/certification-candidate-serializer.js'); -const certificationReportSerializer = require('../../infrastructure/serializers/jsonapi/certification-report-serializer.js'); -const juryCertificationSummarySerializer = require('../../infrastructure/serializers/jsonapi/jury-certification-summary-serializer.js'); -const juryCertificationSummaryRepository = require('../../infrastructure/repositories/jury-certification-summary-repository.js'); -const jurySessionRepository = require('../../infrastructure/repositories/sessions/jury-session-repository.js'); -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); -const certificationResultUtils = require('../../infrastructure/utils/csv/certification-results.js'); -const fillCandidatesImportSheet = require('../../infrastructure/files/candidates-import/fill-candidates-import-sheet.js'); -const supervisorKitPdf = require('../../infrastructure/utils/pdf/supervisor-kit-pdf.js'); -const trim = require('lodash/trim'); -const UserLinkedToCertificationCandidate = require('../../domain/events/UserLinkedToCertificationCandidate.js'); -const logger = require('../../infrastructure/logger.js'); - -module.exports = { - async findPaginatedFilteredJurySessions( - request, - h, - dependencies = { - queryParamsUtils, - jurySessionRepository, - jurySessionSerializer, - sessionValidator, - } - ) { - const { filter, page } = dependencies.queryParamsUtils.extractParameters(request.query); - const normalizedFilters = dependencies.sessionValidator.validateAndNormalizeFilters(filter); - const jurySessionsForPaginatedList = await dependencies.jurySessionRepository.findPaginatedFiltered({ - filters: normalizedFilters, - page, - }); +import moment from 'moment'; +import { BadRequestError, SessionPublicationBatchError } from '../http-errors.js'; +import { usecases } from '../../domain/usecases/index.js'; +import { tokenService } from '../../domain/services/token-service.js'; +import * as sessionResultsLinkService from '../../domain/services/session-results-link-service.js'; +import * as sessionValidator from '../../domain/validators/session-validator.js'; +import * as events from '../../domain/events/index.js'; +import { CertificationCandidateAlreadyLinkedToUserError } from '../../domain/errors.js'; +import * as sessionSerializer from '../../infrastructure/serializers/jsonapi/session-serializer.js'; +import * as jurySessionSerializer from '../../infrastructure/serializers/jsonapi/jury-session-serializer.js'; +import * as certificationCandidateSerializer from '../../infrastructure/serializers/jsonapi/certification-candidate-serializer.js'; +import * as certificationReportSerializer from '../../infrastructure/serializers/jsonapi/certification-report-serializer.js'; +import * as juryCertificationSummarySerializer from '../../infrastructure/serializers/jsonapi/jury-certification-summary-serializer.js'; +import * as juryCertificationSummaryRepository from '../../infrastructure/repositories/jury-certification-summary-repository.js'; +import * as jurySessionRepository from '../../infrastructure/repositories/sessions/jury-session-repository.js'; +import * as queryParamsUtils from '../../infrastructure/utils/query-params-utils.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; +import * as certificationResultUtils from '../../infrastructure/utils/csv/certification-results.js'; +import { fillCandidatesImportSheet } from '../../infrastructure/files/candidates-import/fill-candidates-import-sheet.js'; +import * as supervisorKitPdf from '../../infrastructure/utils/pdf/supervisor-kit-pdf.js'; +import lodash from 'lodash'; + +const { trim } = lodash; + +import { UserLinkedToCertificationCandidate } from '../../domain/events/UserLinkedToCertificationCandidate.js'; +import { logger } from '../../infrastructure/logger.js'; + +const findPaginatedFilteredJurySessions = async function ( + request, + h, + dependencies = { + queryParamsUtils, + jurySessionRepository, + jurySessionSerializer, + sessionValidator, + } +) { + const { filter, page } = dependencies.queryParamsUtils.extractParameters(request.query); + const normalizedFilters = dependencies.sessionValidator.validateAndNormalizeFilters(filter); + const jurySessionsForPaginatedList = await dependencies.jurySessionRepository.findPaginatedFiltered({ + filters: normalizedFilters, + page, + }); + + return dependencies.jurySessionSerializer.serializeForPaginatedList(jurySessionsForPaginatedList); +}; - return dependencies.jurySessionSerializer.serializeForPaginatedList(jurySessionsForPaginatedList); - }, - - async getJurySession(request, h, dependencies = { jurySessionSerializer }) { - const sessionId = request.params.id; - const { jurySession, hasSupervisorAccess } = await usecases.getJurySession({ sessionId }); - - return dependencies.jurySessionSerializer.serialize(jurySession, hasSupervisorAccess); - }, - - async get(request, h, dependencies = { sessionSerializer }) { - const sessionId = request.params.id; - const { session, hasSupervisorAccess, hasSomeCleaAcquired } = await usecases.getSession({ sessionId }); - return dependencies.sessionSerializer.serialize({ session, hasSupervisorAccess, hasSomeCleaAcquired }); - }, - - async update(request, h, dependencies = { sessionSerializer }) { - const userId = request.auth.credentials.userId; - const session = dependencies.sessionSerializer.deserialize(request.payload); - session.id = request.params.id; - - const updatedSession = await usecases.updateSession({ userId, session }); - - return dependencies.sessionSerializer.serialize({ session: updatedSession }); - }, - - async getAttendanceSheet(request, h, dependencies = { tokenService }) { - const sessionId = request.params.id; - const token = request.query.accessToken; - const userId = dependencies.tokenService.extractUserId(token); - const attendanceSheet = await usecases.getAttendanceSheet({ sessionId, userId }); - - const fileName = `feuille-emargement-session-${sessionId}.ods`; - return h - .response(attendanceSheet) - .header('Content-Type', 'application/vnd.oasis.opendocument.spreadsheet') - .header('Content-Disposition', `attachment; filename=${fileName}`); - }, - - async getSupervisorKitPdf(request, h, dependencies = { tokenService, supervisorKitPdf }) { - const sessionId = request.params.id; - const token = request.query.accessToken; - const userId = dependencies.tokenService.extractUserId(token); - const sessionForSupervisorKit = await usecases.getSupervisorKitSessionInfo({ sessionId, userId }); - - const { buffer, fileName } = await dependencies.supervisorKitPdf.getSupervisorKitPdfBuffer({ - sessionForSupervisorKit, - }); +const getJurySession = async function (request, h, dependencies = { jurySessionSerializer }) { + const sessionId = request.params.id; + const { jurySession, hasSupervisorAccess } = await usecases.getJurySession({ sessionId }); - return h - .response(buffer) - .header('Content-Disposition', `attachment; filename=${fileName}`) - .header('Content-Type', 'application/pdf'); - }, - - async getCandidatesImportSheet(request, h, dependencies = { tokenService, fillCandidatesImportSheet }) { - const translate = request.i18n.__; - const sessionId = request.params.id; - const token = request.query.accessToken; - const userId = dependencies.tokenService.extractUserId(token); - const filename = translate('candidate-list-template.filename'); - - const { session, certificationCenterHabilitations, isScoCertificationCenter } = - await usecases.getCandidateImportSheetData({ - sessionId, - userId, - }); - const candidateImportSheet = await dependencies.fillCandidatesImportSheet({ - session, - certificationCenterHabilitations, - isScoCertificationCenter, - i18n: request.i18n, - }); + return dependencies.jurySessionSerializer.serialize(jurySession, hasSupervisorAccess); +}; + +const get = async function (request, h, dependencies = { sessionSerializer }) { + const sessionId = request.params.id; + const { session, hasSupervisorAccess, hasSomeCleaAcquired } = await usecases.getSession({ sessionId }); + return dependencies.sessionSerializer.serialize({ session, hasSupervisorAccess, hasSomeCleaAcquired }); +}; + +const update = async function (request, h, dependencies = { sessionSerializer }) { + const userId = request.auth.credentials.userId; + const session = dependencies.sessionSerializer.deserialize(request.payload); + session.id = request.params.id; + + const updatedSession = await usecases.updateSession({ userId, session }); + + return dependencies.sessionSerializer.serialize({ session: updatedSession }); +}; + +const getAttendanceSheet = async function (request, h, dependencies = { tokenService }) { + const sessionId = request.params.id; + const token = request.query.accessToken; + const userId = dependencies.tokenService.extractUserId(token); + const attendanceSheet = await usecases.getAttendanceSheet({ sessionId, userId }); + + const fileName = `feuille-emargement-session-${sessionId}.ods`; + return h + .response(attendanceSheet) + .header('Content-Type', 'application/vnd.oasis.opendocument.spreadsheet') + .header('Content-Disposition', `attachment; filename=${fileName}`); +}; - return h - .response(candidateImportSheet) - .header('Content-Type', 'application/vnd.oasis.opendocument.spreadsheet') - .header('Content-Disposition', `attachment; filename=${filename + sessionId}.ods`); - }, +const getSupervisorKitPdf = async function (request, h, dependencies = { tokenService, supervisorKitPdf }) { + const sessionId = request.params.id; + const token = request.query.accessToken; + const userId = dependencies.tokenService.extractUserId(token); + const sessionForSupervisorKit = await usecases.getSupervisorKitSessionInfo({ sessionId, userId }); - async getCertificationCandidates(request, h, dependencies = { certificationCandidateSerializer }) { - const sessionId = request.params.id; + const { buffer, fileName } = await dependencies.supervisorKitPdf.getSupervisorKitPdfBuffer({ + sessionForSupervisorKit, + }); - const certificationCandidates = await usecases.getSessionCertificationCandidates({ sessionId }); - return dependencies.certificationCandidateSerializer.serialize(certificationCandidates); - }, + return h + .response(buffer) + .header('Content-Disposition', `attachment; filename=${fileName}`) + .header('Content-Type', 'application/pdf'); +}; - async addCertificationCandidate(request, h, dependencies = { certificationCandidateSerializer }) { - const sessionId = request.params.id; - const certificationCandidate = await dependencies.certificationCandidateSerializer.deserialize(request.payload); - const complementaryCertifications = request.payload.data.attributes['complementary-certifications'] ?? []; - const addedCertificationCandidate = await usecases.addCertificationCandidateToSession({ +const getCandidatesImportSheet = async function ( + request, + h, + dependencies = { tokenService, fillCandidatesImportSheet } +) { + const translate = request.i18n.__; + const sessionId = request.params.id; + const token = request.query.accessToken; + const userId = dependencies.tokenService.extractUserId(token); + const filename = translate('candidate-list-template.filename'); + + const { session, certificationCenterHabilitations, isScoCertificationCenter } = + await usecases.getCandidateImportSheetData({ sessionId, - certificationCandidate, - complementaryCertifications, + userId, }); + const candidateImportSheet = await dependencies.fillCandidatesImportSheet({ + session, + certificationCenterHabilitations, + isScoCertificationCenter, + i18n: request.i18n, + }); + + return h + .response(candidateImportSheet) + .header('Content-Type', 'application/vnd.oasis.opendocument.spreadsheet') + .header('Content-Disposition', `attachment; filename=${filename + sessionId}.ods`); +}; - return h.response(dependencies.certificationCandidateSerializer.serialize(addedCertificationCandidate)).created(); - }, - - async deleteCertificationCandidate(request) { - const certificationCandidateId = request.params.certificationCandidateId; +const getCertificationCandidates = async function (request, h, dependencies = { certificationCandidateSerializer }) { + const sessionId = request.params.id; - await usecases.deleteUnlinkedCertificationCandidate({ certificationCandidateId }); + const certificationCandidates = await usecases.getSessionCertificationCandidates({ sessionId }); + return dependencies.certificationCandidateSerializer.serialize(certificationCandidates); +}; - return null; - }, +const addCertificationCandidate = async function (request, h, dependencies = { certificationCandidateSerializer }) { + const sessionId = request.params.id; + const certificationCandidate = await dependencies.certificationCandidateSerializer.deserialize(request.payload); + const complementaryCertifications = request.payload.data.attributes['complementary-certifications'] ?? []; + const addedCertificationCandidate = await usecases.addCertificationCandidateToSession({ + sessionId, + certificationCandidate, + complementaryCertifications, + }); + + return h.response(dependencies.certificationCandidateSerializer.serialize(addedCertificationCandidate)).created(); +}; - async getJuryCertificationSummaries( - request, - h, - dependencies = { - queryParamsUtils, - juryCertificationSummaryRepository, - juryCertificationSummarySerializer, - } - ) { - const sessionId = request.params.id; - const { page } = dependencies.queryParamsUtils.extractParameters(request.query); +const deleteCertificationCandidate = async function (request) { + const certificationCandidateId = request.params.certificationCandidateId; - const { juryCertificationSummaries, pagination } = - await dependencies.juryCertificationSummaryRepository.findBySessionIdPaginated({ - sessionId, - page, - }); - return dependencies.juryCertificationSummarySerializer.serialize(juryCertificationSummaries, pagination); - }, - - async generateSessionResultsDownloadLink(request, h, dependencies = { sessionResultsLinkService }) { - const sessionId = request.params.id; - const sessionResultsLink = dependencies.sessionResultsLinkService.generateResultsLink(sessionId); - - return h.response({ sessionResultsLink }); - }, - - async getSessionResultsToDownload(request, h, dependencies = { tokenService, certificationResultUtils }) { - const token = request.params.token; - const { sessionId } = dependencies.tokenService.extractSessionId(token); - const { session, certificationResults } = await usecases.getSessionResults({ sessionId }); - - const csvResult = await dependencies.certificationResultUtils.getSessionCertificationResultsCsv({ - session, - certificationResults, - }); + await usecases.deleteUnlinkedCertificationCandidate({ certificationCandidateId }); - const dateWithTime = moment(session.date + ' ' + session.time, 'YYYY-MM-DD HH:mm'); - const fileName = `${dateWithTime.format('YYYYMMDD_HHmm')}_resultats_session_${sessionId}.csv`; + return null; +}; - return h - .response(csvResult) - .header('Content-Type', 'text/csv;charset=utf-8') - .header('Content-Disposition', `attachment; filename=${fileName}`); - }, +const getJuryCertificationSummaries = async function ( + request, + h, + dependencies = { + queryParamsUtils, + juryCertificationSummaryRepository, + juryCertificationSummarySerializer, + } +) { + const sessionId = request.params.id; + const { page } = dependencies.queryParamsUtils.extractParameters(request.query); - async getSessionResultsByRecipientEmail(request, h, dependencies = { tokenService, certificationResultUtils }) { - const token = request.params.token; - const { resultRecipientEmail, sessionId } = - dependencies.tokenService.extractResultRecipientEmailAndSessionId(token); - const { session, certificationResults } = await usecases.getSessionResultsByResultRecipientEmail({ + const { juryCertificationSummaries, pagination } = + await dependencies.juryCertificationSummaryRepository.findBySessionIdPaginated({ sessionId, - resultRecipientEmail, - }); - const csvResult = await dependencies.certificationResultUtils.getSessionCertificationResultsCsv({ - session, - certificationResults, + page, }); + return dependencies.juryCertificationSummarySerializer.serialize(juryCertificationSummaries, pagination); +}; - const dateWithTime = moment(session.date + ' ' + session.time, 'YYYY-MM-DD HH:mm'); - const fileName = `${dateWithTime.format('YYYYMMDD_HHmm')}_resultats_session_${sessionId}.csv`; - - return h - .response(csvResult) - .header('Content-Type', 'text/csv;charset=utf-8') - .header('Content-Disposition', `attachment; filename=${fileName}`); - }, - - async getCertificationReports(request, h, dependencies = { certificationReportSerializer }) { - const sessionId = request.params.id; - - return usecases - .getSessionCertificationReports({ sessionId }) - .then((certificationReports) => dependencies.certificationReportSerializer.serialize(certificationReports)); - }, - - async importCertificationCandidatesFromCandidatesImportSheet(request) { - const sessionId = request.params.id; - const odsBuffer = request.payload; - const i18n = request.i18n; - - try { - await usecases.importCertificationCandidatesFromCandidatesImportSheet({ sessionId, odsBuffer, i18n }); - } catch (err) { - if (err instanceof CertificationCandidateAlreadyLinkedToUserError) { - throw new BadRequestError(err.message); - } - throw err; - } +const generateSessionResultsDownloadLink = async function (request, h, dependencies = { sessionResultsLinkService }) { + const sessionId = request.params.id; + const sessionResultsLink = dependencies.sessionResultsLinkService.generateResultsLink(sessionId); - return null; - }, - - async enrolStudentsToSession(request, h, dependencies = { certificationCandidateSerializer, requestResponseUtils }) { - const referentId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); - const sessionId = request.params.id; - const studentIds = request.deserializedPayload.organizationLearnerIds; - - await usecases.enrolStudentsToSession({ sessionId, referentId, studentIds }); - const certificationCandidates = await usecases.getSessionCertificationCandidates({ sessionId }); - const certificationCandidatesSerialized = - dependencies.certificationCandidateSerializer.serialize(certificationCandidates); - return h.response(certificationCandidatesSerialized).created(); - }, - - async createCandidateParticipation(request, h, dependencies = { certificationCandidateSerializer }) { - const userId = request.auth.credentials.userId; - const sessionId = request.params.id; - const firstName = trim(request.payload.data.attributes['first-name']); - const lastName = trim(request.payload.data.attributes['last-name']); - const birthdate = request.payload.data.attributes['birthdate']; - - const event = await usecases.linkUserToSessionCertificationCandidate({ - userId, - sessionId, - firstName, - lastName, - birthdate, - }); + return h.response({ sessionResultsLink }); +}; - const certificationCandidate = await usecases.getCertificationCandidate({ userId, sessionId }); - const serialized = await dependencies.certificationCandidateSerializer.serialize(certificationCandidate); - return event instanceof UserLinkedToCertificationCandidate ? h.response(serialized).created() : serialized; - }, - - async finalize(request, h, dependencies = { certificationReportSerializer, events }) { - const sessionId = request.params.id; - const examinerGlobalComment = request.payload.data.attributes['examiner-global-comment']; - const hasIncident = request.payload.data.attributes['has-incident']; - const hasJoiningIssue = request.payload.data.attributes['has-joining-issue']; - const certificationReports = await Promise.all( - (request.payload.data.included || []) - .filter((data) => data.type === 'certification-reports') - .map((data) => dependencies.certificationReportSerializer.deserialize({ data })) - ); +const getSessionResultsToDownload = async function ( + request, + h, + dependencies = { tokenService, certificationResultUtils } +) { + const token = request.params.token; + const { sessionId } = dependencies.tokenService.extractSessionId(token); + const { session, certificationResults } = await usecases.getSessionResults({ sessionId }); + + const csvResult = await dependencies.certificationResultUtils.getSessionCertificationResultsCsv({ + session, + certificationResults, + }); + + const dateWithTime = moment(session.date + ' ' + session.time, 'YYYY-MM-DD HH:mm'); + const fileName = `${dateWithTime.format('YYYYMMDD_HHmm')}_resultats_session_${sessionId}.csv`; + + return h + .response(csvResult) + .header('Content-Type', 'text/csv;charset=utf-8') + .header('Content-Disposition', `attachment; filename=${fileName}`); +}; - const event = await usecases.finalizeSession({ - sessionId, - examinerGlobalComment, - hasIncident, - hasJoiningIssue, - certificationReports, - }); - await dependencies.events.eventDispatcher.dispatch(event); - return h.response().code(200); - }, +const getSessionResultsByRecipientEmail = async function ( + request, + h, + dependencies = { tokenService, certificationResultUtils } +) { + const token = request.params.token; + const { resultRecipientEmail, sessionId } = dependencies.tokenService.extractResultRecipientEmailAndSessionId(token); + const { session, certificationResults } = await usecases.getSessionResultsByResultRecipientEmail({ + sessionId, + resultRecipientEmail, + }); + const csvResult = await dependencies.certificationResultUtils.getSessionCertificationResultsCsv({ + session, + certificationResults, + }); + + const dateWithTime = moment(session.date + ' ' + session.time, 'YYYY-MM-DD HH:mm'); + const fileName = `${dateWithTime.format('YYYYMMDD_HHmm')}_resultats_session_${sessionId}.csv`; + + return h + .response(csvResult) + .header('Content-Type', 'text/csv;charset=utf-8') + .header('Content-Disposition', `attachment; filename=${fileName}`); +}; - async publish(request, h, dependencies = { sessionSerializer }) { - const sessionId = request.params.id; - const i18n = request.i18n; +const getCertificationReports = async function (request, h, dependencies = { certificationReportSerializer }) { + const sessionId = request.params.id; - const session = await usecases.publishSession({ sessionId, i18n }); + return usecases + .getSessionCertificationReports({ sessionId }) + .then((certificationReports) => dependencies.certificationReportSerializer.serialize(certificationReports)); +}; - return dependencies.sessionSerializer.serialize({ session }); - }, +const importCertificationCandidatesFromCandidatesImportSheet = async function (request) { + const sessionId = request.params.id; + const odsBuffer = request.payload; + const i18n = request.i18n; - async publishInBatch(request, h) { - const sessionIds = request.payload.data.attributes.ids; - const result = await usecases.publishSessionsInBatch({ - sessionIds, - }); - if (result.hasPublicationErrors()) { - _logSessionBatchPublicationErrors(result); - throw new SessionPublicationBatchError(result.batchId); + try { + await usecases.importCertificationCandidatesFromCandidatesImportSheet({ sessionId, odsBuffer, i18n }); + } catch (err) { + if (err instanceof CertificationCandidateAlreadyLinkedToUserError) { + throw new BadRequestError(err.message); } - return h.response().code(204); - }, + throw err; + } - async unpublish(request, h, dependencies = { sessionSerializer }) { - const sessionId = request.params.id; + return null; +}; - const session = await usecases.unpublishSession({ sessionId }); +const enrolStudentsToSession = async function ( + request, + h, + dependencies = { certificationCandidateSerializer, requestResponseUtils } +) { + const referentId = dependencies.requestResponseUtils.extractUserIdFromRequest(request); + const sessionId = request.params.id; + const studentIds = request.deserializedPayload.organizationLearnerIds; + + await usecases.enrolStudentsToSession({ sessionId, referentId, studentIds }); + const certificationCandidates = await usecases.getSessionCertificationCandidates({ sessionId }); + const certificationCandidatesSerialized = + dependencies.certificationCandidateSerializer.serialize(certificationCandidates); + return h.response(certificationCandidatesSerialized).created(); +}; - return dependencies.sessionSerializer.serialize({ session }); - }, +const createCandidateParticipation = async function (request, h, dependencies = { certificationCandidateSerializer }) { + const userId = request.auth.credentials.userId; + const sessionId = request.params.id; + const firstName = trim(request.payload.data.attributes['first-name']); + const lastName = trim(request.payload.data.attributes['last-name']); + const birthdate = request.payload.data.attributes['birthdate']; + + const event = await usecases.linkUserToSessionCertificationCandidate({ + userId, + sessionId, + firstName, + lastName, + birthdate, + }); + + const certificationCandidate = await usecases.getCertificationCandidate({ userId, sessionId }); + const serialized = await dependencies.certificationCandidateSerializer.serialize(certificationCandidate); + return event instanceof UserLinkedToCertificationCandidate ? h.response(serialized).created() : serialized; +}; - async flagResultsAsSentToPrescriber(request, h, dependencies = { sessionSerializer }) { - const sessionId = request.params.id; - const { resultsFlaggedAsSent, session } = await usecases.flagSessionResultsAsSentToPrescriber({ sessionId }); - const serializedSession = await dependencies.sessionSerializer.serialize({ session }); - return resultsFlaggedAsSent ? h.response(serializedSession).created() : serializedSession; - }, +const finalize = async function (request, h, dependencies = { certificationReportSerializer, events }) { + const sessionId = request.params.id; + const examinerGlobalComment = request.payload.data.attributes['examiner-global-comment']; + const hasIncident = request.payload.data.attributes['has-incident']; + const hasJoiningIssue = request.payload.data.attributes['has-joining-issue']; + const certificationReports = await Promise.all( + (request.payload.data.included || []) + .filter((data) => data.type === 'certification-reports') + .map((data) => dependencies.certificationReportSerializer.deserialize({ data })) + ); + + const event = await usecases.finalizeSession({ + sessionId, + examinerGlobalComment, + hasIncident, + hasJoiningIssue, + certificationReports, + }); + await dependencies.events.eventDispatcher.dispatch(event); + return h.response().code(200); +}; - async assignCertificationOfficer(request, h, dependencies = { jurySessionSerializer }) { - const sessionId = request.params.id; - const certificationOfficerId = request.auth.credentials.userId; - const jurySession = await usecases.assignCertificationOfficerToJurySession({ sessionId, certificationOfficerId }); - return dependencies.jurySessionSerializer.serialize(jurySession); - }, +const publish = async function (request, h, dependencies = { sessionSerializer }) { + const sessionId = request.params.id; + const i18n = request.i18n; - async commentAsJury(request, h) { - const sessionId = request.params.id; - const juryCommentAuthorId = request.auth.credentials.userId; - const juryComment = request.payload['jury-comment']; - await usecases.commentSessionAsJury({ sessionId, juryCommentAuthorId, juryComment }); + const session = await usecases.publishSession({ sessionId, i18n }); - return h.response().code(204); - }, + return dependencies.sessionSerializer.serialize({ session }); +}; - async delete(request, h) { - const sessionId = request.params.id; +const publishInBatch = async function (request, h) { + const sessionIds = request.payload.data.attributes.ids; + const result = await usecases.publishSessionsInBatch({ + sessionIds, + }); + if (result.hasPublicationErrors()) { + _logSessionBatchPublicationErrors(result); + throw new SessionPublicationBatchError(result.batchId); + } + return h.response().code(204); +}; - await usecases.deleteSession({ sessionId }); +const unpublish = async function (request, h, dependencies = { sessionSerializer }) { + const sessionId = request.params.id; - return h.response().code(204); - }, + const session = await usecases.unpublishSession({ sessionId }); - async deleteJuryComment(request, h) { - const sessionId = request.params.id; - await usecases.deleteSessionJuryComment({ sessionId }); + return dependencies.sessionSerializer.serialize({ session }); +}; + +const flagResultsAsSentToPrescriber = async function (request, h, dependencies = { sessionSerializer }) { + const sessionId = request.params.id; + const { resultsFlaggedAsSent, session } = await usecases.flagSessionResultsAsSentToPrescriber({ sessionId }); + const serializedSession = await dependencies.sessionSerializer.serialize({ session }); + return resultsFlaggedAsSent ? h.response(serializedSession).created() : serializedSession; +}; + +const assignCertificationOfficer = async function (request, h, dependencies = { jurySessionSerializer }) { + const sessionId = request.params.id; + const certificationOfficerId = request.auth.credentials.userId; + const jurySession = await usecases.assignCertificationOfficerToJurySession({ sessionId, certificationOfficerId }); + return dependencies.jurySessionSerializer.serialize(jurySession); +}; + +const commentAsJury = async function (request, h) { + const sessionId = request.params.id; + const juryCommentAuthorId = request.auth.credentials.userId; + const juryComment = request.payload['jury-comment']; + await usecases.commentSessionAsJury({ sessionId, juryCommentAuthorId, juryComment }); + + return h.response().code(204); +}; - return h.response().code(204); - }, +const remove = async function (request, h) { + const sessionId = request.params.id; + + await usecases.deleteSession({ sessionId }); + + return h.response().code(204); +}; + +const deleteJuryComment = async function (request, h) { + const sessionId = request.params.id; + await usecases.deleteSessionJuryComment({ sessionId }); + + return h.response().code(204); +}; + +const sessionController = { + findPaginatedFilteredJurySessions, + getJurySession, + get, + update, + getAttendanceSheet, + getSupervisorKitPdf, + getCandidatesImportSheet, + getCertificationCandidates, + addCertificationCandidate, + deleteCertificationCandidate, + getJuryCertificationSummaries, + generateSessionResultsDownloadLink, + getSessionResultsToDownload, + getSessionResultsByRecipientEmail, + getCertificationReports, + importCertificationCandidatesFromCandidatesImportSheet, + enrolStudentsToSession, + createCandidateParticipation, + finalize, + publish, + publishInBatch, + unpublish, + flagResultsAsSentToPrescriber, + assignCertificationOfficer, + commentAsJury, + remove, + deleteJuryComment, }; +export { sessionController }; + function _logSessionBatchPublicationErrors(result) { logger.warn(`One or more error occurred when publishing session in batch ${result.batchId}`); diff --git a/api/lib/application/sessions/session-for-supervising-controller.js b/api/lib/application/sessions/session-for-supervising-controller.js index bf321e3aad7..e528ced3c8f 100644 --- a/api/lib/application/sessions/session-for-supervising-controller.js +++ b/api/lib/application/sessions/session-for-supervising-controller.js @@ -1,17 +1,19 @@ -const usecases = require('../../domain/usecases/index.js'); -const sessionForSupervisingSerializer = require('../../infrastructure/serializers/jsonapi/session-for-supervising-serializer.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as sessionForSupervisingSerializer from '../../infrastructure/serializers/jsonapi/session-for-supervising-serializer.js'; -module.exports = { - async get(request) { - const sessionId = request.params.id; - const session = await usecases.getSessionForSupervising({ sessionId }); - return sessionForSupervisingSerializer.serialize(session); - }, +const get = async function (request) { + const sessionId = request.params.id; + const session = await usecases.getSessionForSupervising({ sessionId }); + return sessionForSupervisingSerializer.serialize(session); +}; - async supervise(request, h) { - const { 'supervisor-password': supervisorPassword, 'session-id': sessionId } = request.payload.data.attributes; - const { userId } = request.auth.credentials; - await usecases.superviseSession({ sessionId, userId, supervisorPassword }); - return h.response().code(204); - }, +const supervise = async function (request, h) { + const { 'supervisor-password': supervisorPassword, 'session-id': sessionId } = request.payload.data.attributes; + const { userId } = request.auth.credentials; + await usecases.superviseSession({ sessionId, userId, supervisorPassword }); + return h.response().code(204); }; + +const sessionForSupervisingController = { get, supervise }; + +export { sessionForSupervisingController }; diff --git a/api/lib/application/sessions/session-with-clea-certified-candidate-controller.js b/api/lib/application/sessions/session-with-clea-certified-candidate-controller.js index bac7e9399be..f97d2461c43 100644 --- a/api/lib/application/sessions/session-with-clea-certified-candidate-controller.js +++ b/api/lib/application/sessions/session-with-clea-certified-candidate-controller.js @@ -1,23 +1,25 @@ -const usecases = require('../../domain/usecases/index.js'); -const certificationResultUtils = require('../../infrastructure/utils/csv/certification-results.js'); -const dayjs = require('dayjs'); +import { usecases } from '../../domain/usecases/index.js'; +import * as certificationResultUtils from '../../infrastructure/utils/csv/certification-results.js'; +import dayjs from 'dayjs'; -module.exports = { - async getCleaCertifiedCandidateDataCsv(request, h, dependencies = { certificationResultUtils }) { - const sessionId = request.params.id; - const { session, cleaCertifiedCandidateData } = await usecases.getCleaCertifiedCandidateBySession({ sessionId }); - const csvResult = await dependencies.certificationResultUtils.getCleaCertifiedCandidateCsv( - cleaCertifiedCandidateData - ); +const getCleaCertifiedCandidateDataCsv = async function (request, h, dependencies = { certificationResultUtils }) { + const sessionId = request.params.id; + const { session, cleaCertifiedCandidateData } = await usecases.getCleaCertifiedCandidateBySession({ sessionId }); + const csvResult = await dependencies.certificationResultUtils.getCleaCertifiedCandidateCsv( + cleaCertifiedCandidateData + ); - const dateWithTime = dayjs(session.date + ' ' + session.time) - .locale('fr') - .format('YYYYMMDD_HHmm'); - const fileName = `${dateWithTime}_candidats_certifies_clea_${sessionId}.csv`; + const dateWithTime = dayjs(session.date + ' ' + session.time) + .locale('fr') + .format('YYYYMMDD_HHmm'); + const fileName = `${dateWithTime}_candidats_certifies_clea_${sessionId}.csv`; - return h - .response(csvResult) - .header('Content-Type', 'text/csv;charset=utf-8') - .header('Content-Disposition', `attachment; filename=${fileName}`); - }, + return h + .response(csvResult) + .header('Content-Type', 'text/csv;charset=utf-8') + .header('Content-Disposition', `attachment; filename=${fileName}`); }; + +const sessionWithCleaCertifiedCandidateController = { getCleaCertifiedCandidateDataCsv }; + +export { sessionWithCleaCertifiedCandidateController }; diff --git a/api/lib/application/stage-collections/index.js b/api/lib/application/stage-collections/index.js index b7b467344e6..61e3ab6c5c4 100644 --- a/api/lib/application/stage-collections/index.js +++ b/api/lib/application/stage-collections/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const stageCollectionController = require('./stage-collection-controller'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import Joi from 'joi'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { stageCollectionController } from './stage-collection-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'PATCH', @@ -36,4 +36,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'stage-collections-api'; +const name = 'stage-collections-api'; +export { register, name }; diff --git a/api/lib/application/stage-collections/stage-collection-controller.js b/api/lib/application/stage-collections/stage-collection-controller.js index 03ec24f1374..371507818a1 100644 --- a/api/lib/application/stage-collections/stage-collection-controller.js +++ b/api/lib/application/stage-collections/stage-collection-controller.js @@ -1,13 +1,15 @@ -const stageCollectionRepository = require('../../infrastructure/repositories/target-profile-management/stage-collection-repository'); -const StageCollectionUpdate = require('../../domain/models/target-profile-management/StageCollectionUpdate'); +import * as stageCollectionRepository from '../../infrastructure/repositories/target-profile-management/stage-collection-repository.js'; +import { StageCollectionUpdate } from '../../domain/models/target-profile-management/StageCollectionUpdate.js'; -module.exports = { - async update(request, h) { - const targetProfileId = request.params.id; - const stagesDTO = request.payload.data.attributes.stages; - const stageCollection = await stageCollectionRepository.getByTargetProfileId(targetProfileId); - const stageCollectionUpdate = new StageCollectionUpdate({ stagesDTO, stageCollection }); - await stageCollectionRepository.update(stageCollectionUpdate); - return h.response({}).code(204); - }, +const update = async function (request, h) { + const targetProfileId = request.params.id; + const stagesDTO = request.payload.data.attributes.stages; + const stageCollection = await stageCollectionRepository.getByTargetProfileId(targetProfileId); + const stageCollectionUpdate = new StageCollectionUpdate({ stagesDTO, stageCollection }); + await stageCollectionRepository.update(stageCollectionUpdate); + return h.response({}).code(204); }; + +const stageCollectionController = { update }; + +export { stageCollectionController }; diff --git a/api/lib/application/sup-organization-learners/index.js b/api/lib/application/sup-organization-learners/index.js index 5e8e74795ae..0ce66b7b943 100644 --- a/api/lib/application/sup-organization-learners/index.js +++ b/api/lib/application/sup-organization-learners/index.js @@ -1,13 +1,13 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { sendJsonApiError, UnprocessableEntityError, NotFoundError } = require('../http-errors.js'); -const supOrganizationLearnerController = require('./sup-organization-learner-controller.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { sendJsonApiError, UnprocessableEntityError, NotFoundError } from '../http-errors.js'; +import { supOrganizationLearnerController } from './sup-organization-learner-controller.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'POST', @@ -84,4 +84,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'sup-organization-learners-api'; +const name = 'sup-organization-learners-api'; +export { register, name }; diff --git a/api/lib/application/sup-organization-learners/sup-organization-learner-controller.js b/api/lib/application/sup-organization-learners/sup-organization-learner-controller.js index af68fa80f70..bf84ee98b6c 100644 --- a/api/lib/application/sup-organization-learners/sup-organization-learner-controller.js +++ b/api/lib/application/sup-organization-learners/sup-organization-learner-controller.js @@ -1,33 +1,35 @@ -const usecases = require('../../domain/usecases/index.js'); +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async reconcileSupOrganizationLearner(request, h) { - const userId = request.auth.credentials.userId; - const payload = request.payload.data.attributes; +const reconcileSupOrganizationLearner = async function (request, h) { + const userId = request.auth.credentials.userId; + const payload = request.payload.data.attributes; - const campaignCode = payload['campaign-code']; + const campaignCode = payload['campaign-code']; - const reconciliationInfo = { - userId, - studentNumber: payload['student-number'], - firstName: payload['first-name'], - lastName: payload['last-name'], - birthdate: payload['birthdate'], - }; + const reconciliationInfo = { + userId, + studentNumber: payload['student-number'], + firstName: payload['first-name'], + lastName: payload['last-name'], + birthdate: payload['birthdate'], + }; - await usecases.reconcileSupOrganizationLearner({ campaignCode, reconciliationInfo }); + await usecases.reconcileSupOrganizationLearner({ campaignCode, reconciliationInfo }); - return h.response(null).code(204); - }, + return h.response(null).code(204); +}; - async updateStudentNumber(request, h) { - const payload = request.payload.data.attributes; - const organizationId = request.params.id; - const studentNumber = payload['student-number']; - const organizationLearnerId = request.params.organizationLearnerId; +const updateStudentNumber = async function (request, h) { + const payload = request.payload.data.attributes; + const organizationId = request.params.id; + const studentNumber = payload['student-number']; + const organizationLearnerId = request.params.organizationLearnerId; - await usecases.updateStudentNumber({ organizationLearnerId, studentNumber, organizationId }); + await usecases.updateStudentNumber({ organizationLearnerId, studentNumber, organizationId }); - return h.response().code(204); - }, + return h.response().code(204); }; + +const supOrganizationLearnerController = { reconcileSupOrganizationLearner, updateStudentNumber }; + +export { supOrganizationLearnerController }; diff --git a/api/lib/application/tags/index.js b/api/lib/application/tags/index.js index b99d766bc96..f44dd3890b8 100644 --- a/api/lib/application/tags/index.js +++ b/api/lib/application/tags/index.js @@ -1,9 +1,9 @@ -const securityPreHandlers = require('../security-pre-handlers.js'); -const tagController = require('./tag-controller.js'); -const Joi = require('joi'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { tagController } from './tag-controller.js'; +import Joi from 'joi'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'POST', @@ -91,4 +91,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'tags-api'; +const name = 'tags-api'; +export { register, name }; diff --git a/api/lib/application/tags/tag-controller.js b/api/lib/application/tags/tag-controller.js index cf2a740f70c..78eb18ba18b 100644 --- a/api/lib/application/tags/tag-controller.js +++ b/api/lib/application/tags/tag-controller.js @@ -1,21 +1,23 @@ -const tagSerializer = require('../../infrastructure/serializers/jsonapi/tag-serializer.js'); -const usecases = require('../../domain/usecases/index.js'); +import * as tagSerializer from '../../infrastructure/serializers/jsonapi/tag-serializer.js'; +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async create(request, h, dependencies = { tagSerializer }) { - const tagName = request.payload.data.attributes['name'].toUpperCase(); - const createdTag = await usecases.createTag({ tagName }); - return h.response(dependencies.tagSerializer.serialize(createdTag)).created(); - }, +const create = async function (request, h, dependencies = { tagSerializer }) { + const tagName = request.payload.data.attributes['name'].toUpperCase(); + const createdTag = await usecases.createTag({ tagName }); + return h.response(dependencies.tagSerializer.serialize(createdTag)).created(); +}; - async findAllTags(request, h, dependencies = { tagSerializer }) { - const organizationsTags = await usecases.findAllTags(); - return dependencies.tagSerializer.serialize(organizationsTags); - }, +const findAllTags = async function (request, h, dependencies = { tagSerializer }) { + const organizationsTags = await usecases.findAllTags(); + return dependencies.tagSerializer.serialize(organizationsTags); +}; - async getRecentlyUsedTags(request, h, dependencies = { tagSerializer }) { - const tagId = request.params.id; - const recentlyUsedTags = await usecases.getRecentlyUsedTags({ tagId }); - return dependencies.tagSerializer.serialize(recentlyUsedTags); - }, +const getRecentlyUsedTags = async function (request, h, dependencies = { tagSerializer }) { + const tagId = request.params.id; + const recentlyUsedTags = await usecases.getRecentlyUsedTags({ tagId }); + return dependencies.tagSerializer.serialize(recentlyUsedTags); }; + +const tagController = { create, findAllTags, getRecentlyUsedTags }; + +export { tagController }; diff --git a/api/lib/application/target-profiles/index.js b/api/lib/application/target-profiles/index.js index 9a59e4cfafb..e82e952b523 100644 --- a/api/lib/application/target-profiles/index.js +++ b/api/lib/application/target-profiles/index.js @@ -1,11 +1,11 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const { sendJsonApiError, BadRequestError } = require('../http-errors.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const targetProfileController = require('./target-profile-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { sendJsonApiError, BadRequestError } from '../http-errors.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { targetProfileController } from './target-profile-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'GET', @@ -446,4 +446,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'target-profiles-api'; +const name = 'target-profiles-api'; +export { register, name }; diff --git a/api/lib/application/target-profiles/presenter/pdf/builder/area-builder.js b/api/lib/application/target-profiles/presenter/pdf/builder/area-builder.js index c7051f5e843..5cb9927dd00 100644 --- a/api/lib/application/target-profiles/presenter/pdf/builder/area-builder.js +++ b/api/lib/application/target-profiles/presenter/pdf/builder/area-builder.js @@ -1,31 +1,29 @@ -const sortBy = require('lodash/sortBy'); -const competenceBuilder = require('./competence-builder.js'); -const AreaText = require('../drawer/AreaText.js'); -const LegalMentionText = require('../drawer/LegalMentionText.js'); +import lodash from 'lodash'; + +const { sortBy } = lodash; + +import * as competenceBuilder from './competence-builder.js'; +import { AreaText } from '../drawer/AreaText.js'; +import { LegalMentionText } from '../drawer/LegalMentionText.js'; const MARGIN_TOP_WITHOUT_AREA = 15; const MARGIN_BOTTOM_LIMIT = 5; -module.exports = { - /** - * @param pdfDocument{PDFDocument} - * @param area{Area} - * @param frameworkName{string} - * @param language{string} - */ - build(pdfDocument, area, frameworkName, language) { - const page = _addPage(pdfDocument, language); - const areaTitle = frameworkName + ' : ' + area.title; - let pageContext = { - page, - positionY: _drawAreaTitle(page, areaTitle, area.color), - }; - for (const competence of sortBy(area.competences, 'index')) { - pageContext = _nextPage(pageContext.page, pageContext.positionY, competence, area.color, language); - pageContext.positionY = competenceBuilder.build(pageContext.positionY, pageContext.page, competence, area.color); - } - }, +const build = function (pdfDocument, area, frameworkName, language) { + const page = _addPage(pdfDocument, language); + const areaTitle = frameworkName + ' : ' + area.title; + let pageContext = { + page, + positionY: _drawAreaTitle(page, areaTitle, area.color), + }; + for (const competence of sortBy(area.competences, 'index')) { + pageContext = _nextPage(pageContext.page, pageContext.positionY, competence, area.color, language); + pageContext.positionY = competenceBuilder.build(pageContext.positionY, pageContext.page, competence, area.color); + } }; + +export { build }; + /** * @param page{PDFPage} * @param positionY{number} diff --git a/api/lib/application/target-profiles/presenter/pdf/builder/competence-builder.js b/api/lib/application/target-profiles/presenter/pdf/builder/competence-builder.js index cd02fe3a9e0..5a6df9c1dce 100644 --- a/api/lib/application/target-profiles/presenter/pdf/builder/competence-builder.js +++ b/api/lib/application/target-profiles/presenter/pdf/builder/competence-builder.js @@ -1,38 +1,33 @@ -const sortBy = require('lodash/sortBy'); -const thematicBuilder = require('./thematic-builder.js'); -const CompetenceText = require('../drawer/CompetenceText.js'); -const PositionManager = require('../manager/position-manager.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); +import lodash from 'lodash'; -module.exports = { - /** - * @param positionY{number} - * @param page {PDFPage} - * @param competence {Competence} - * @param areaColor {string} - * @param dryRun {boolean} - * @returns {number} next y position - */ - build(positionY, page, competence, areaColor, dryRun = false) { - positionY = positionY - FontManager.competenceFontHeight; - const competenceText = new CompetenceText({ - text: competence.fullName, - areaColor, - positionY: positionY, - }); - if (!dryRun) { - _drawCompetenceBackground(positionY, page, competenceText); - } - positionY = competenceText.draw(page, dryRun); +const { sortBy } = lodash; - for (const thematic of sortBy(competence.thematics, 'index')) { - positionY = thematicBuilder.build(positionY, page, thematic, dryRun); - positionY = positionY - FontManager.thematicFontHeight / 2; - } - return positionY; - }, +import * as thematicBuilder from './thematic-builder.js'; +import { CompetenceText } from '../drawer/CompetenceText.js'; +import { PositionManager } from '../manager/position-manager.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; + +const build = function (positionY, page, competence, areaColor, dryRun = false) { + positionY = positionY - FontManager.competenceFontHeight; + const competenceText = new CompetenceText({ + text: competence.fullName, + areaColor, + positionY: positionY, + }); + if (!dryRun) { + _drawCompetenceBackground(positionY, page, competenceText); + } + positionY = competenceText.draw(page, dryRun); + + for (const thematic of sortBy(competence.thematics, 'index')) { + positionY = thematicBuilder.build(positionY, page, thematic, dryRun); + positionY = positionY - FontManager.thematicFontHeight / 2; + } + return positionY; }; + +export { build }; /** * @param positionY{number} * @param page {PDFPage} diff --git a/api/lib/application/target-profiles/presenter/pdf/builder/cover-page-builder.js b/api/lib/application/target-profiles/presenter/pdf/builder/cover-page-builder.js index f2f892bdaf8..13079d38206 100644 --- a/api/lib/application/target-profiles/presenter/pdf/builder/cover-page-builder.js +++ b/api/lib/application/target-profiles/presenter/pdf/builder/cover-page-builder.js @@ -1,27 +1,22 @@ -const TemplatePageManager = require('../manager/template-page-manager.js'); -const CoverPageVersionText = require('../drawer/CoverPageVersionText.js'); -const CoverPageLegalMentionText = require('../drawer/CoverPageLegalMentionText.js'); -const CoverPageTitleText = require('../drawer/CoverPageTitleText.js'); -const PositionManager = require('../manager/position-manager.js'); +import * as TemplatePageManager from '../manager/template-page-manager.js'; +import { CoverPageVersionText } from '../drawer/CoverPageVersionText.js'; +import { CoverPageLegaLMentionText } from '../drawer/CoverPageLegalMentionText.js'; +import { CoverPageTitleText } from '../drawer/CoverPageTitleText.js'; +import { PositionManager } from '../manager/position-manager.js'; -module.exports = { - /** - * @param pdfDocument{PDFDocument} - * @param title {string} - * @param language {string} - */ - build(pdfDocument, title, language) { - const page = pdfDocument.addPage(); - PositionManager.initialize(page); - page.drawPage(TemplatePageManager.getCoverPage()); - const coverPageTitleText = new CoverPageTitleText({ - title, - page, - }); - const coverPageVersionText = new CoverPageVersionText({ language, page }); - const coverPageLegalMentionText = new CoverPageLegalMentionText({ language }); - coverPageTitleText.drawAlignCenter(page); - coverPageVersionText.draw(page); - coverPageLegalMentionText.draw(page); - }, +const build = function (pdfDocument, title, language) { + const page = pdfDocument.addPage(); + PositionManager.initialize(page); + page.drawPage(TemplatePageManager.getCoverPage()); + const coverPageTitleText = new CoverPageTitleText({ + title, + page, + }); + const coverPageVersionText = new CoverPageVersionText({ language, page }); + const coverPageLegalMentionText = new CoverPageLegaLMentionText({ language }); + coverPageTitleText.drawAlignCenter(page); + coverPageVersionText.draw(page); + coverPageLegalMentionText.draw(page); }; + +export { build }; diff --git a/api/lib/application/target-profiles/presenter/pdf/builder/learning-content-builder.js b/api/lib/application/target-profiles/presenter/pdf/builder/learning-content-builder.js index ee979506bf2..1a44e5a441d 100644 --- a/api/lib/application/target-profiles/presenter/pdf/builder/learning-content-builder.js +++ b/api/lib/application/target-profiles/presenter/pdf/builder/learning-content-builder.js @@ -1,19 +1,15 @@ -const sortBy = require('lodash/sortBy'); -const areaBuilder = require('./area-builder.js'); +import lodash from 'lodash'; -module.exports = { - /** - * @param pdfDocument{PDFDocument} - * @param learningContent{LearningContent} - * @param language {string} - * - * @return {PDFDocument} - */ - build(pdfDocument, learningContent, language) { - for (const area of sortBy(learningContent.areas, ['frameworkId', 'code'])) { - const frameworkName = learningContent.findFrameworkNameOfArea(area.id); - areaBuilder.build(pdfDocument, area, frameworkName, language); - } - return pdfDocument; - }, +const { sortBy } = lodash; + +import * as areaBuilder from './area-builder.js'; + +const build = function (pdfDocument, learningContent, language) { + for (const area of sortBy(learningContent.areas, ['frameworkId', 'code'])) { + const frameworkName = learningContent.findFrameworkNameOfArea(area.id); + areaBuilder.build(pdfDocument, area, frameworkName, language); + } + return pdfDocument; }; + +export { build }; diff --git a/api/lib/application/target-profiles/presenter/pdf/builder/thematic-builder.js b/api/lib/application/target-profiles/presenter/pdf/builder/thematic-builder.js index 0d6ddee4515..93479a1442c 100644 --- a/api/lib/application/target-profiles/presenter/pdf/builder/thematic-builder.js +++ b/api/lib/application/target-profiles/presenter/pdf/builder/thematic-builder.js @@ -1,61 +1,44 @@ -const sortBy = require('lodash/sortBy'); -const tubeBuilder = require('./tube-builder.js'); -const ThematicText = require('../drawer/ThematicText.js'); -const PositionManager = require('../manager/position-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const ColorManager = require('../manager/color-manager.js'); +import lodash from 'lodash'; -module.exports = { - /** - * @param positionY{number} - * @param page {PDFPage} - * @param thematic {Thematic} - * @param dryRun {boolean} - * @returns {number} next y position - */ - build(positionY, page, thematic, dryRun) { - if (!dryRun) { - this._drawThematicBackground(positionY, page, thematic); - } - return this._drawContent(positionY, page, thematic, dryRun); - }, - /** - * @param positionY{number} - * @param page {PDFPage} - * @param thematic {Thematic} - * @param dryRun {boolean} - * @returns {number} next y position - * @private - */ - _drawContent(positionY, page, thematic, dryRun) { - let positionYAfterTubes = positionY; - let pair = false; - for (const tube of sortBy(thematic.tubes, 'practicalTitle')) { - positionYAfterTubes = tubeBuilder.build(positionYAfterTubes, page, tube, pair, dryRun); - pair = !pair; - } - const thematicText = new ThematicText({ text: thematic.name, positionY, positionYAfterTubes }); - const nextYThematic = thematicText.draw(page, dryRun); +const { sortBy } = lodash; - return Math.min(positionYAfterTubes, nextYThematic); - }, - /** - * @param positionY{number} - * @param page {PDFPage} - * @param thematic {Thematic} - * @returns {number} next y position - * @private - */ - _drawThematicBackground(positionY, page, thematic) { - const nextPositionY = this._drawContent(positionY, page, thematic, true); - page.drawRectangle({ - x: PositionManager.margin, - y: nextPositionY + FontManager.thematicFontHeight, - width: PositionManager.widthMaxWithoutMargin, - height: positionY - nextPositionY, - color: ColorManager.thematicBackground, - opacity: 0.5, - borderWidth: 0, - }); - }, +import * as tubeBuilder from './tube-builder.js'; +import { ThematicText } from '../drawer/ThematicText.js'; +import { PositionManager } from '../manager/position-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import * as ColorManager from '../manager/color-manager.js'; + +const build = function (positionY, page, thematic, dryRun) { + if (!dryRun) { + this._drawThematicBackground(positionY, page, thematic); + } + return this._drawContent(positionY, page, thematic, dryRun); +}; + +const _drawContent = function (positionY, page, thematic, dryRun) { + let positionYAfterTubes = positionY; + let pair = false; + for (const tube of sortBy(thematic.tubes, 'practicalTitle')) { + positionYAfterTubes = tubeBuilder.build(positionYAfterTubes, page, tube, pair, dryRun); + pair = !pair; + } + const thematicText = new ThematicText({ text: thematic.name, positionY, positionYAfterTubes }); + const nextYThematic = thematicText.draw(page, dryRun); + + return Math.min(positionYAfterTubes, nextYThematic); }; + +const _drawThematicBackground = function (positionY, page, thematic) { + const nextPositionY = this._drawContent(positionY, page, thematic, true); + page.drawRectangle({ + x: PositionManager.margin, + y: nextPositionY + FontManager.thematicFontHeight, + width: PositionManager.widthMaxWithoutMargin, + height: positionY - nextPositionY, + color: ColorManager.thematicBackground, + opacity: 0.5, + borderWidth: 0, + }); +}; + +export { build, _drawContent, _drawThematicBackground }; diff --git a/api/lib/application/target-profiles/presenter/pdf/builder/tube-builder.js b/api/lib/application/target-profiles/presenter/pdf/builder/tube-builder.js index 2fca36db4ae..10d77a2e4c8 100644 --- a/api/lib/application/target-profiles/presenter/pdf/builder/tube-builder.js +++ b/api/lib/application/target-profiles/presenter/pdf/builder/tube-builder.js @@ -1,33 +1,24 @@ -const TubeText = require('../drawer/TubeText.js'); -const PositionManager = require('../manager/position-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const ColorManager = require('../manager/color-manager.js'); +import { TubeText } from '../drawer/TubeText.js'; +import { PositionManager } from '../manager/position-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import * as ColorManager from '../manager/color-manager.js'; const START_BORDER = 2; -module.exports = { - /** - * - * @param positionY{number} - * @param page {PDFPage} - * @param tube {Tube} - * @param dryRun {boolean} - * @param withBackground {boolean} - * @returns {number} next y position - */ - build(positionY, page, tube, withBackground, dryRun) { - const tubeText = new TubeText({ - practicalTitle: tube.practicalTitle, - practicalDescription: tube.practicalDescription, - positionY, - }); - if (!dryRun && withBackground) { - _drawTubeBackground(positionY, page, tubeText); - } +const build = function (positionY, page, tube, withBackground, dryRun) { + const tubeText = new TubeText({ + practicalTitle: tube.practicalTitle, + practicalDescription: tube.practicalDescription, + positionY, + }); + if (!dryRun && withBackground) { + _drawTubeBackground(positionY, page, tubeText); + } - return tubeText.draw(page, dryRun); - }, + return tubeText.draw(page, dryRun); }; + +export { build }; /** * * @param positionY{number} diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/AreaText.js b/api/lib/application/target-profiles/presenter/pdf/drawer/AreaText.js index e9aa771da05..84c6eb717bd 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/AreaText.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/AreaText.js @@ -1,12 +1,12 @@ -const Text = require('./Text.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const TemplatePageManager = require('../manager/template-page-manager.js'); +import { Text } from './Text.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import * as TemplatePageManager from '../manager/template-page-manager.js'; const MARGIN_TOP_AREA = 5; const MARGIN_BOTTOM_AREA = 50; -module.exports = class AreaText extends Text { +class AreaText extends Text { /** * * @param text {string} @@ -48,4 +48,6 @@ module.exports = class AreaText extends Text { super.drawAlignCenter(page, dryRun); return this.positionYAfter; } -}; +} + +export { AreaText }; diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/CompetenceText.js b/api/lib/application/target-profiles/presenter/pdf/drawer/CompetenceText.js index 1c48238f3ac..966023a5860 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/CompetenceText.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/CompetenceText.js @@ -1,9 +1,9 @@ -const Text = require('./Text.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const PositionManager = require('../manager/position-manager.js'); +import { Text } from './Text.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import { PositionManager } from '../manager/position-manager.js'; -module.exports = class CompetenceText extends Text { +class CompetenceText extends Text { constructor({ text, positionY, areaColor }) { super({ text, @@ -14,4 +14,6 @@ module.exports = class CompetenceText extends Text { fontColor: ColorManager.findLighterShadeRGBColor(areaColor), }); } -}; +} + +export { CompetenceText }; diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageLegalMentionText.js b/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageLegalMentionText.js index 00afc46e8d0..28dd3320307 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageLegalMentionText.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageLegalMentionText.js @@ -1,14 +1,14 @@ -const Text = require('./Text.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const PositionManager = require('../manager/position-manager.js'); +import { Text } from './Text.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import { PositionManager } from '../manager/position-manager.js'; const textByLang = { en: 'This is a working document, updated regularly. Its distribution is restricted and its use limited to Pix Orga members in the context of the implementation of the support of their users.', fr: "Ceci est un document de travail. Il évolue régulièrement. Sa diffusion est restreinte et son usage limité aux utilisateurs de Pix Orga dans le cadre de la mise en oeuvre de l'accompagnement de leurs publics.", }; -module.exports = class CoverPageLegaLMentionText extends Text { +class CoverPageLegaLMentionText extends Text { constructor({ language }) { const text = textByLang[language]; super({ @@ -21,4 +21,6 @@ module.exports = class CoverPageLegaLMentionText extends Text { maxWidth: PositionManager.coverPageLegalMentionWidth, }); } -}; +} + +export { CoverPageLegaLMentionText }; diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageTitleText.js b/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageTitleText.js index 496d023f3a2..9f3114d0cd4 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageTitleText.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageTitleText.js @@ -1,9 +1,9 @@ -const Text = require('./Text.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const PositionManager = require('../manager/position-manager.js'); +import { Text } from './Text.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import { PositionManager } from '../manager/position-manager.js'; -module.exports = class CoverPageTitleText extends Text { +class CoverPageTitleText extends Text { constructor({ title, page }) { const text = title; const font = FontManager.coverPageTitleFont; @@ -19,4 +19,6 @@ module.exports = class CoverPageTitleText extends Text { maxWidth: PositionManager.coverPageTitleWidth, }); } -}; +} + +export { CoverPageTitleText }; diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageVersionText.js b/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageVersionText.js index 66a7f74150b..589528c2351 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageVersionText.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/CoverPageVersionText.js @@ -1,17 +1,17 @@ -const dayjs = require('dayjs'); -const localizedFormat = require('dayjs/plugin/localizedFormat'); +import dayjs from 'dayjs'; +import localizedFormat from 'dayjs/plugin/localizedFormat.js'; dayjs.extend(localizedFormat); -const Text = require('./Text.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const PositionManager = require('../manager/position-manager.js'); +import { Text } from './Text.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import { PositionManager } from '../manager/position-manager.js'; const textByLang = { en: 'Version {date}', fr: 'Version du {date}', }; -module.exports = class CoverPageVersionText extends Text { +class CoverPageVersionText extends Text { constructor({ language, page }) { let text = textByLang[language]; const todayDateString = dayjs().locale(language).format('LL'); @@ -28,4 +28,6 @@ module.exports = class CoverPageVersionText extends Text { fontColor: ColorManager.coverPageVersionColor, }); } -}; +} + +export { CoverPageVersionText }; diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/LegalMentionText.js b/api/lib/application/target-profiles/presenter/pdf/drawer/LegalMentionText.js index cb2e6f12f49..4f0542c4892 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/LegalMentionText.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/LegalMentionText.js @@ -1,15 +1,15 @@ -const dayjs = require('dayjs'); -const Text = require('./Text.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const PositionManager = require('../manager/position-manager.js'); +import dayjs from 'dayjs'; +import { Text } from './Text.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import { PositionManager } from '../manager/position-manager.js'; const textByLang = { en: 'This is a working document, updated regularly. Its distribution is restricted and its use limited to Pix Orga members in the context of the implementation of the support of their users. - Version {date}', fr: "Ceci est un document de travail. Il évolue régulièrement. Sa diffusion est restreinte et son usage limité aux utilisateurs de Pix Orga dans le cadre de la mise en oeuvre de l'accompagnement de leurs publics. - Version du {date}", }; -module.exports = class LegalMentionText extends Text { +class LegalMentionText extends Text { constructor({ language }) { let text = textByLang[language]; const todayDateString = dayjs().locale(language).format('DD MMMM YYYY'); @@ -25,4 +25,6 @@ module.exports = class LegalMentionText extends Text { fontColor: ColorManager.legalMentionColor, }); } -}; +} + +export { LegalMentionText }; diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/Text.js b/api/lib/application/target-profiles/presenter/pdf/drawer/Text.js index 1b0d688004d..e9606875ba3 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/Text.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/Text.js @@ -1,7 +1,7 @@ -const PositionManager = require('../manager/position-manager.js'); -const pdfLibUtils = require('pdf-lib/cjs/utils'); +import { PositionManager } from '../manager/position-manager.js'; +import pdfLibUtils from 'pdf-lib/cjs/utils/index.js'; -module.exports = class Text { +class Text { constructor({ text, positionX, positionY, fontSize, font, fontColor, maxWidth }) { this.text = text; this.position = { @@ -130,4 +130,6 @@ module.exports = class Text { const textWidth = font.widthOfTextAtSize(text, fontSize); return page.getWidth() / 2 - textWidth / 2; } -}; +} + +export { Text }; diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/ThematicText.js b/api/lib/application/target-profiles/presenter/pdf/drawer/ThematicText.js index 4aa1b75a081..86e230d5a83 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/ThematicText.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/ThematicText.js @@ -1,7 +1,7 @@ -const Text = require('./Text.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const PositionManager = require('../manager/position-manager.js'); +import { Text } from './Text.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import { PositionManager } from '../manager/position-manager.js'; class ThematicText extends Text { constructor({ text, positionY, positionYAfterTubes }) { @@ -56,4 +56,4 @@ function _thematicHeight(text) { return FontManager.thematicFontHeight * numberOfLine; } -module.exports = ThematicText; +export { ThematicText }; diff --git a/api/lib/application/target-profiles/presenter/pdf/drawer/TubeText.js b/api/lib/application/target-profiles/presenter/pdf/drawer/TubeText.js index 14b25bb1504..89c527786e9 100644 --- a/api/lib/application/target-profiles/presenter/pdf/drawer/TubeText.js +++ b/api/lib/application/target-profiles/presenter/pdf/drawer/TubeText.js @@ -1,9 +1,9 @@ -const Text = require('./Text.js'); -const ColorManager = require('../manager/color-manager.js'); -const FontManager = require('../manager/font-manager.js'); -const PositionManager = require('../manager/position-manager.js'); +import { Text } from './Text.js'; +import * as ColorManager from '../manager/color-manager.js'; +import { FontManager } from '../manager/font-manager.js'; +import { PositionManager } from '../manager/position-manager.js'; -module.exports = class TubeText extends Text { +class TubeText extends Text { constructor({ practicalTitle, practicalDescription, positionY }) { super({ text: practicalTitle || 'error on practicalTitle', @@ -38,4 +38,6 @@ module.exports = class TubeText extends Text { get spaceUnderText() { return Math.max(FontManager.tubeTitleFontHeight, FontManager.tubeDescriptionFontHeight) / 2; } -}; +} + +export { TubeText }; diff --git a/api/lib/application/target-profiles/presenter/pdf/learning-content-pdf-presenter.js b/api/lib/application/target-profiles/presenter/pdf/learning-content-pdf-presenter.js index a7b7cc37856..8f812f30cd4 100644 --- a/api/lib/application/target-profiles/presenter/pdf/learning-content-pdf-presenter.js +++ b/api/lib/application/target-profiles/presenter/pdf/learning-content-pdf-presenter.js @@ -1,26 +1,20 @@ -const pdfLibFontKit = require('@pdf-lib/fontkit'); -require('dayjs/locale/fr'); -const FontManager = require('./manager/font-manager.js'); -const TemplatePageManager = require('./manager/template-page-manager.js'); -const learningContentBuilder = require('./builder/learning-content-builder.js'); -const coverPageBuilder = require('./builder/cover-page-builder.js'); -const { PDFDocument } = require('pdf-lib'); +import pdfLibFontKit from '@pdf-lib/fontkit'; +import 'dayjs/locale/fr.js'; +import { FontManager } from './manager/font-manager.js'; +import * as TemplatePageManager from './manager/template-page-manager.js'; +import * as learningContentBuilder from './builder/learning-content-builder.js'; +import * as coverPageBuilder from './builder/cover-page-builder.js'; +import { PDFDocument } from 'pdf-lib'; -module.exports = { - /** - * @param learningContent{LearningContent} - * @param title{string} - * @param language{string} - * @return {Promise} - */ - async present(learningContent, title, language) { - const pdfDocument = await _initializeNewPDFDocument(pdfLibFontKit); - coverPageBuilder.build(pdfDocument, title, language); - const pdfBytes = await learningContentBuilder.build(pdfDocument, learningContent, language).save(); - return Buffer.from(pdfBytes); - }, +const present = async function (learningContent, title, language) { + const pdfDocument = await _initializeNewPDFDocument(pdfLibFontKit); + coverPageBuilder.build(pdfDocument, title, language); + const pdfBytes = await learningContentBuilder.build(pdfDocument, learningContent, language).save(); + return Buffer.from(pdfBytes); }; +export { present }; + /** * @param fontKit {Fontkit} * @returns {Promise} diff --git a/api/lib/application/target-profiles/presenter/pdf/manager/color-manager.js b/api/lib/application/target-profiles/presenter/pdf/manager/color-manager.js index 3449a751bdf..231c657a76f 100644 --- a/api/lib/application/target-profiles/presenter/pdf/manager/color-manager.js +++ b/api/lib/application/target-profiles/presenter/pdf/manager/color-manager.js @@ -1,4 +1,5 @@ -const { rgb } = require('pdf-lib'); +import { rgb } from 'pdf-lib'; + const colorToRgb = { jaffa: rgb(0.949, 0.274, 0.27), emerald: rgb(0.102, 0.549, 0.537), @@ -20,69 +21,42 @@ const lighterColorToRgb = { const DEFAULT_COLOR = 'jaffa'; const DEFAULT_BACKGROUND = rgb(0.93, 0.93, 0.93); -module.exports = { - /** - * @param color {string} - * @return {RGB} - */ - findRGBColor(color = DEFAULT_COLOR) { - let rgbColor = colorToRgb[color]; - if (!rgbColor) { - rgbColor = colorToRgb[DEFAULT_COLOR]; - } - return rgbColor; - }, - /** - * @param color {string} - * @return {RGB} - */ - findLighterShadeRGBColor(color = DEFAULT_COLOR) { - let rgbColor = lighterColorToRgb[color]; - if (!rgbColor) { - rgbColor = lighterColorToRgb[DEFAULT_COLOR]; - } - return rgbColor; - }, - /** - * @return {RGB} - */ - get legalMentionColor() { - return colorToRgb['black']; - }, - /** - * @return {RGB} - */ - get coverPageTitleColor() { - return colorToRgb['white']; - }, - /** - * @return {RGB} - */ - get coverPageLegalMentionColor() { - return colorToRgb['white']; - }, - /** - * @return {RGB} - */ - get coverPageVersionColor() { - return colorToRgb['white']; - }, - /** - * @return {RGB} - */ - get competenceBackground() { - return DEFAULT_BACKGROUND; - }, - /** - * @return {RGB} - */ - get thematicBackground() { - return DEFAULT_BACKGROUND; - }, - /** - * @return {RGB} - */ - get tubeBackground() { - return rgb(0.89, 0.89, 0.89); - }, +const findRGBColor = function (color = DEFAULT_COLOR) { + let rgbColor = colorToRgb[color]; + if (!rgbColor) { + rgbColor = colorToRgb[DEFAULT_COLOR]; + } + return rgbColor; +}; + +const findLighterShadeRGBColor = function (color = DEFAULT_COLOR) { + let rgbColor = lighterColorToRgb[color]; + if (!rgbColor) { + rgbColor = lighterColorToRgb[DEFAULT_COLOR]; + } + return rgbColor; +}; + +const legalMentionColor = colorToRgb['black']; +const coverPageTitleColor = colorToRgb['white']; +const coverPageLegalMentionColor = colorToRgb['white']; + +const coverPageVersionColor = colorToRgb['white']; + +const competenceBackground = DEFAULT_BACKGROUND; + +const thematicBackground = DEFAULT_BACKGROUND; + +const tubeBackground = rgb(0.89, 0.89, 0.89); + +export { + findRGBColor, + findLighterShadeRGBColor, + legalMentionColor, + coverPageTitleColor, + coverPageLegalMentionColor, + coverPageVersionColor, + competenceBackground, + thematicBackground, + tubeBackground, }; diff --git a/api/lib/application/target-profiles/presenter/pdf/manager/font-manager.js b/api/lib/application/target-profiles/presenter/pdf/manager/font-manager.js index c40076e2353..7783ffe394b 100644 --- a/api/lib/application/target-profiles/presenter/pdf/manager/font-manager.js +++ b/api/lib/application/target-profiles/presenter/pdf/manager/font-manager.js @@ -1,4 +1,8 @@ -const { readFile } = require('fs/promises'); +import { readFile } from 'fs/promises'; + +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); const embeddedFonts = {}; const COVER_PAGE_VERSION_TEXT_FONT_SIZE = 20; @@ -187,4 +191,4 @@ const FontManager = { }, }; -module.exports = FontManager; +export { FontManager }; diff --git a/api/lib/application/target-profiles/presenter/pdf/manager/position-manager.js b/api/lib/application/target-profiles/presenter/pdf/manager/position-manager.js index 4c01c73bdbd..36e794dee0c 100644 --- a/api/lib/application/target-profiles/presenter/pdf/manager/position-manager.js +++ b/api/lib/application/target-profiles/presenter/pdf/manager/position-manager.js @@ -79,4 +79,4 @@ const PositionManager = { }, }; -module.exports = PositionManager; +export { PositionManager }; diff --git a/api/lib/application/target-profiles/presenter/pdf/manager/template-page-manager.js b/api/lib/application/target-profiles/presenter/pdf/manager/template-page-manager.js index 688e0d468d2..41ef6f6c91b 100644 --- a/api/lib/application/target-profiles/presenter/pdf/manager/template-page-manager.js +++ b/api/lib/application/target-profiles/presenter/pdf/manager/template-page-manager.js @@ -1,4 +1,7 @@ -const { readFile } = require('fs/promises'); +import { readFile } from 'fs/promises'; +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); const embeddedTemplatePages = {}; @@ -11,33 +14,24 @@ const templatesPages = { 'cover-page': 'cover-page.pdf', }; -module.exports = { - /** - * @param areaColor {string} - * @returns {PDFEmbeddedPage} - */ - findTemplatePage(areaColor) { - if (!embeddedTemplatePages[areaColor]) { - return embeddedTemplatePages['jaffa']; - } - return embeddedTemplatePages[areaColor]; - }, - /** - * @returns {PDFEmbeddedPage} - */ - getCoverPage() { - return embeddedTemplatePages['cover-page']; - }, - /** - * @param pdfDocument {PDFDocument} - * @returns {Promise} - */ - async initializeTemplatesPages(pdfDocument) { - for (const templateKey in templatesPages) { - const templateFilename = templatesPages[templateKey]; - const templateBuffer = await readFile(`${__dirname}/templates/${templateFilename}`); - const [templatePage] = await pdfDocument.embedPdf(templateBuffer); - embeddedTemplatePages[templateKey] = templatePage; - } - }, +const findTemplatePage = function (areaColor) { + if (!embeddedTemplatePages[areaColor]) { + return embeddedTemplatePages['jaffa']; + } + return embeddedTemplatePages[areaColor]; +}; + +const getCoverPage = function () { + return embeddedTemplatePages['cover-page']; }; + +const initializeTemplatesPages = async function (pdfDocument) { + for (const templateKey in templatesPages) { + const templateFilename = templatesPages[templateKey]; + const templateBuffer = await readFile(`${__dirname}/templates/${templateFilename}`); + const [templatePage] = await pdfDocument.embedPdf(templateBuffer); + embeddedTemplatePages[templateKey] = templatePage; + } +}; + +export { findTemplatePage, getCoverPage, initializeTemplatesPages }; diff --git a/api/lib/application/target-profiles/target-profile-controller.js b/api/lib/application/target-profiles/target-profile-controller.js index 0a20409f111..d3309866edf 100644 --- a/api/lib/application/target-profiles/target-profile-controller.js +++ b/api/lib/application/target-profiles/target-profile-controller.js @@ -1,147 +1,166 @@ -const usecases = require('../../domain/usecases/index.js'); -const tokenService = require('../../domain/services/token-service.js'); -const targetProfileSerializer = require('../../infrastructure/serializers/jsonapi/target-profile-serializer.js'); -const targetProfileSummaryForAdminSerializer = require('../../infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js'); -const targetProfileForAdminSerializer = require('../../infrastructure/serializers/jsonapi/target-profile-for-admin-serializer.js'); -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); -const organizationSerializer = require('../../infrastructure/serializers/jsonapi/organization-serializer.js'); -const badgeSerializer = require('../../infrastructure/serializers/jsonapi/badge-serializer.js'); -const badgeCreationSerializer = require('../../infrastructure/serializers/jsonapi/badge-creation-serializer.js'); -const targetProfileAttachOrganizationSerializer = require('../../infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer.js'); -const learningContentPDFPresenter = require('./presenter/pdf/learning-content-pdf-presenter.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); -const trainingSummarySerializer = require('../../infrastructure/serializers/jsonapi/training-summary-serializer'); - -module.exports = { - async findPaginatedFilteredTargetProfileSummariesForAdmin(request) { - const options = queryParamsUtils.extractParameters(request.query); - - const { models: targetProfileSummaries, meta } = await usecases.findPaginatedFilteredTargetProfileSummariesForAdmin( - { - filter: options.filter, - page: options.page, - } - ); - return targetProfileSummaryForAdminSerializer.serialize(targetProfileSummaries, meta); - }, - - async getTargetProfileForAdmin(request) { - const targetProfileId = request.params.id; - const targetProfileForAdmin = await usecases.getTargetProfileForAdmin({ targetProfileId }); - return targetProfileForAdminSerializer.serialize(targetProfileForAdmin); - }, - - async findPaginatedFilteredTargetProfileOrganizations(request) { - const targetProfileId = request.params.id; - const options = queryParamsUtils.extractParameters(request.query); - - const { models: organizations, pagination } = await usecases.findPaginatedFilteredTargetProfileOrganizations({ - targetProfileId, - filter: options.filter, - page: options.page, - }); - return organizationSerializer.serialize(organizations, pagination); - }, - - async getContentAsJsonFile(request, h) { - const targetProfileId = request.params.id; - const token = request.query.accessToken; - const userId = tokenService.extractUserId(token); - - const { jsonContent, fileName } = await usecases.getTargetProfileContentAsJson({ userId, targetProfileId }); - - const escapedFilename = requestResponseUtils.escapeFileName(fileName); - - return h - .response(jsonContent) - .header('Content-Type', 'text/json;charset=utf-8') - .header('Content-Disposition', `attachment; filename=${escapedFilename}`); - }, - - async attachOrganizations(request, h) { - const organizationIds = request.payload['organization-ids']; - const targetProfileId = request.params.id; - const results = await usecases.attachOrganizationsToTargetProfile({ targetProfileId, organizationIds }); - - return h.response(targetProfileAttachOrganizationSerializer.serialize({ ...results, targetProfileId })).code(200); - }, - - async attachOrganizationsFromExistingTargetProfile(request, h) { - const existingTargetProfileId = request.payload['target-profile-id']; - const targetProfileId = request.params.id; - await usecases.attachOrganizationsFromExistingTargetProfile({ targetProfileId, existingTargetProfileId }); - return h.response({}).code(204); - }, - - async updateTargetProfile(request, h) { - const id = request.params.id; - const { name, 'image-url': imageUrl, description, comment, category } = request.payload.data.attributes; - await usecases.updateTargetProfile({ id, name, imageUrl, description, comment, category }); - return h.response({}).code(204); - }, - - async outdateTargetProfile(request, h) { - const id = request.params.id; - - await usecases.outdateTargetProfile({ id }); - return h.response({}).code(204); - }, - - async createTargetProfile(request) { - const targetProfileCreationCommand = targetProfileSerializer.deserializeCreationCommand(request.payload); - - const targetProfileId = await DomainTransaction.execute(async (domainTransaction) => { - return usecases.createTargetProfile({ - targetProfileCreationCommand, - domainTransaction, - }); - }); - return targetProfileSerializer.serializeId(targetProfileId); - }, +import { usecases } from '../../domain/usecases/index.js'; +import { tokenService } from '../../domain/services/token-service.js'; +import * as targetProfileSerializer from '../../infrastructure/serializers/jsonapi/target-profile-serializer.js'; +import * as targetProfileSummaryForAdminSerializer from '../../infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js'; +import * as targetProfileForAdminSerializer from '../../infrastructure/serializers/jsonapi/target-profile-for-admin-serializer.js'; +import * as queryParamsUtils from '../../infrastructure/utils/query-params-utils.js'; +import { escapeFileName } from '../../infrastructure/utils/request-response-utils.js'; +import * as organizationSerializer from '../../infrastructure/serializers/jsonapi/organization-serializer.js'; +import * as badgeSerializer from '../../infrastructure/serializers/jsonapi/badge-serializer.js'; +import { deserializer as badgeCreationDeserializer } from '../../infrastructure/serializers/jsonapi/badge-creation-serializer.js'; +import * as targetProfileAttachOrganizationSerializer from '../../infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer.js'; +import * as learningContentPDFPresenter from './presenter/pdf/learning-content-pdf-presenter.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import * as trainingSummarySerializer from '../../infrastructure/serializers/jsonapi/training-summary-serializer.js'; + +const findPaginatedFilteredTargetProfileSummariesForAdmin = async function (request) { + const options = queryParamsUtils.extractParameters(request.query); + + const { models: targetProfileSummaries, meta } = await usecases.findPaginatedFilteredTargetProfileSummariesForAdmin({ + filter: options.filter, + page: options.page, + }); + return targetProfileSummaryForAdminSerializer.serialize(targetProfileSummaries, meta); +}; + +const getTargetProfileForAdmin = async function (request) { + const targetProfileId = request.params.id; + const targetProfileForAdmin = await usecases.getTargetProfileForAdmin({ targetProfileId }); + return targetProfileForAdminSerializer.serialize(targetProfileForAdmin); +}; + +const findPaginatedFilteredTargetProfileOrganizations = async function (request) { + const targetProfileId = request.params.id; + const options = queryParamsUtils.extractParameters(request.query); + + const { models: organizations, pagination } = await usecases.findPaginatedFilteredTargetProfileOrganizations({ + targetProfileId, + filter: options.filter, + page: options.page, + }); + return organizationSerializer.serialize(organizations, pagination); +}; + +const getContentAsJsonFile = async function (request, h, dependencies = { tokenService }) { + const targetProfileId = request.params.id; + const token = request.query.accessToken; + const userId = dependencies.tokenService.extractUserId(token); + + const { jsonContent, fileName } = await usecases.getTargetProfileContentAsJson({ userId, targetProfileId }); + const escapedFilename = escapeFileName(fileName); + + return h + .response(jsonContent) + .header('Content-Type', 'text/json;charset=utf-8') + .header('Content-Disposition', `attachment; filename=${escapedFilename}`); +}; + +const attachOrganizations = async function (request, h, dependencies = { targetProfileAttachOrganizationSerializer }) { + const organizationIds = request.payload['organization-ids']; + const targetProfileId = request.params.id; + const results = await usecases.attachOrganizationsToTargetProfile({ targetProfileId, organizationIds }); + + return h + .response(dependencies.targetProfileAttachOrganizationSerializer.serialize({ ...results, targetProfileId })) + .code(200); +}; - async findPaginatedTrainings(request, h, dependencies = { queryParamsUtils, trainingSummarySerializer }) { - const { page } = dependencies.queryParamsUtils.extractParameters(request.query); - const targetProfileId = request.params.id; +const attachOrganizationsFromExistingTargetProfile = async function (request, h) { + const existingTargetProfileId = request.payload['target-profile-id']; + const targetProfileId = request.params.id; + await usecases.attachOrganizationsFromExistingTargetProfile({ targetProfileId, existingTargetProfileId }); + return h.response({}).code(204); +}; + +const updateTargetProfile = async function (request, h) { + const id = request.params.id; + const { name, 'image-url': imageUrl, description, comment, category } = request.payload.data.attributes; + await usecases.updateTargetProfile({ id, name, imageUrl, description, comment, category }); + return h.response({}).code(204); +}; + +const outdateTargetProfile = async function (request, h) { + const id = request.params.id; - const { trainings, meta } = await usecases.findPaginatedTargetProfileTrainingSummaries({ - targetProfileId, - page, + await usecases.outdateTargetProfile({ id }); + return h.response({}).code(204); +}; + +const createTargetProfile = async function (request) { + const targetProfileCreationCommand = targetProfileSerializer.deserializeCreationCommand(request.payload); + + const targetProfileId = await DomainTransaction.execute(async (domainTransaction) => { + return usecases.createTargetProfile({ + targetProfileCreationCommand, + domainTransaction, }); - return dependencies.trainingSummarySerializer.serialize(trainings, meta); - }, + }); + return targetProfileSerializer.serializeId(targetProfileId); +}; - async createBadge(request, h) { - const targetProfileId = request.params.id; - const badgeCreation = await badgeCreationSerializer.deserialize(request.payload); +const findPaginatedTrainings = async function ( + request, + h, + dependencies = { queryParamsUtils, trainingSummarySerializer } +) { + const { page } = dependencies.queryParamsUtils.extractParameters(request.query); + const targetProfileId = request.params.id; + + const { trainings, meta } = await usecases.findPaginatedTargetProfileTrainingSummaries({ + targetProfileId, + page, + }); + return dependencies.trainingSummarySerializer.serialize(trainings, meta); +}; + +const createBadge = async function (request, h) { + const targetProfileId = request.params.id; + const badgeCreation = await badgeCreationDeserializer.deserialize(request.payload); - const createdBadge = await usecases.createBadge({ targetProfileId, badgeCreation }); + const createdBadge = await usecases.createBadge({ targetProfileId, badgeCreation }); - return h.response(badgeSerializer.serialize(createdBadge)).created(); - }, + return h.response(badgeSerializer.serialize(createdBadge)).created(); +}; - async markTargetProfileAsSimplifiedAccess(request, h) { - const id = request.params.id; +const markTargetProfileAsSimplifiedAccess = async function (request, h) { + const id = request.params.id; - const targetProfile = await usecases.markTargetProfileAsSimplifiedAccess({ id }); - return h.response(targetProfileSerializer.serialize(targetProfile)); - }, + const targetProfile = await usecases.markTargetProfileAsSimplifiedAccess({ id }); + return h.response(targetProfileSerializer.serialize(targetProfile)); +}; - async getLearningContentAsPdf(request, h) { - const targetProfileId = request.params.id; - const { title, language } = request.query; +const getLearningContentAsPdf = async function (request, h, dependencies = { learningContentPDFPresenter }) { + const targetProfileId = request.params.id; + const { title, language } = request.query; - const learningContent = await usecases.getLearningContentByTargetProfile({ targetProfileId, language }); - const pdfBuffer = await learningContentPDFPresenter.present(learningContent, title, language); + const learningContent = await usecases.getLearningContentByTargetProfile({ targetProfileId, language }); + const pdfBuffer = await dependencies.learningContentPDFPresenter.present(learningContent, title, language); - const date = new Date(); - const dateString = date.getDate() + '-' + (date.getMonth() + 1) + '-' + date.getFullYear(); - const timeString = date.getHours() + '-' + date.getMinutes(); - const fileName = `${title}_${dateString}_${timeString}.pdf`; + const date = new Date(); + const dateString = date.getDate() + '-' + (date.getMonth() + 1) + '-' + date.getFullYear(); + const timeString = date.getHours() + '-' + date.getMinutes(); + const fileName = `${title}_${dateString}_${timeString}.pdf`; - return h - .response(pdfBuffer) - .header('Content-Disposition', `attachment; filename=${fileName}`) - .header('Content-Type', 'application/pdf'); - }, + return h + .response(pdfBuffer) + .header('Content-Disposition', `attachment; filename=${fileName}`) + .header('Content-Type', 'application/pdf'); }; + +const targetProfileController = { + findPaginatedFilteredTargetProfileSummariesForAdmin, + getTargetProfileForAdmin, + findPaginatedFilteredTargetProfileOrganizations, + getContentAsJsonFile, + attachOrganizations, + attachOrganizationsFromExistingTargetProfile, + updateTargetProfile, + outdateTargetProfile, + createTargetProfile, + findPaginatedTrainings, + createBadge, + markTargetProfileAsSimplifiedAccess, + getLearningContentAsPdf, +}; + +export { targetProfileController }; diff --git a/api/lib/application/trainings/index.js b/api/lib/application/trainings/index.js index fd66a97225d..3d3517f861d 100644 --- a/api/lib/application/trainings/index.js +++ b/api/lib/application/trainings/index.js @@ -1,11 +1,11 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const trainingsController = require('./training-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const { sendJsonApiError, NotFoundError, BadRequestError } = require('../http-errors.js'); +import { trainingController as trainingsController } from './training-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { sendJsonApiError, NotFoundError, BadRequestError } from '../http-errors.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'GET', @@ -269,4 +269,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'trainings-api'; +const name = 'trainings-api'; +export { register, name }; diff --git a/api/lib/application/trainings/training-controller.js b/api/lib/application/trainings/training-controller.js index 3850bdbad02..87ce07cb8a7 100644 --- a/api/lib/application/trainings/training-controller.js +++ b/api/lib/application/trainings/training-controller.js @@ -1,67 +1,85 @@ -const trainingSerializer = require('../../infrastructure/serializers/jsonapi/training-serializer.js'); -const trainingSummarySerializer = require('../../infrastructure/serializers/jsonapi/training-summary-serializer.js'); -const trainingTriggerSerializer = require('../../infrastructure/serializers/jsonapi/training-trigger-serializer.js'); -const targetProfileSummaryForAdminSerializer = require('../../infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js'); -const usecases = require('../../domain/usecases/index.js'); -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction'); +import * as trainingSerializer from '../../infrastructure/serializers/jsonapi/training-serializer.js'; +import * as trainingSummarySerializer from '../../infrastructure/serializers/jsonapi/training-summary-serializer.js'; +import * as trainingTriggerSerializer from '../../infrastructure/serializers/jsonapi/training-trigger-serializer.js'; +import * as targetProfileSummaryForAdminSerializer from '../../infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js'; +import { usecases } from '../../domain/usecases/index.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import * as queryParamsUtils from '../../infrastructure/utils/query-params-utils.js'; -module.exports = { - async findPaginatedTrainingSummaries(request, h, dependencies = { trainingSummarySerializer, queryParamsUtils }) { - const { filter, page } = dependencies.queryParamsUtils.extractParameters(request.query); - const { trainings, meta } = await usecases.findPaginatedTrainingSummaries({ filter, page }); - return dependencies.trainingSummarySerializer.serialize(trainings, meta); - }, +const findPaginatedTrainingSummaries = async function ( + request, + h, + dependencies = { trainingSummarySerializer, queryParamsUtils } +) { + const { filter, page } = dependencies.queryParamsUtils.extractParameters(request.query); + const { trainings, meta } = await usecases.findPaginatedTrainingSummaries({ filter, page }); + return dependencies.trainingSummarySerializer.serialize(trainings, meta); +}; - async findTargetProfileSummaries(request, h, dependencies = { targetProfileSummaryForAdminSerializer }) { - const { trainingId } = request.params; - const targetProfileSummaries = await usecases.findTargetProfileSummariesForTraining({ trainingId }); - return dependencies.targetProfileSummaryForAdminSerializer.serialize(targetProfileSummaries); - }, +const findTargetProfileSummaries = async function ( + request, + h, + dependencies = { targetProfileSummaryForAdminSerializer } +) { + const { trainingId } = request.params; + const targetProfileSummaries = await usecases.findTargetProfileSummariesForTraining({ trainingId }); + return dependencies.targetProfileSummaryForAdminSerializer.serialize(targetProfileSummaries); +}; - async getById(request, h, dependencies = { trainingSerializer }) { - const { trainingId } = request.params; - const training = await usecases.getTraining({ trainingId }); - return dependencies.trainingSerializer.serializeForAdmin(training); - }, +const getById = async function (request, h, dependencies = { trainingSerializer }) { + const { trainingId } = request.params; + const training = await usecases.getTraining({ trainingId }); + return dependencies.trainingSerializer.serializeForAdmin(training); +}; - async create(request, h, dependencies = { trainingSerializer }) { - const deserializedTraining = await dependencies.trainingSerializer.deserialize(request.payload); - const createdTraining = await usecases.createTraining({ training: deserializedTraining }); - return h.response(dependencies.trainingSerializer.serialize(createdTraining)).created(); - }, +const create = async function (request, h, dependencies = { trainingSerializer }) { + const deserializedTraining = await dependencies.trainingSerializer.deserialize(request.payload); + const createdTraining = await usecases.createTraining({ training: deserializedTraining }); + return h.response(dependencies.trainingSerializer.serialize(createdTraining)).created(); +}; - async update(request, h, dependencies = { trainingSerializer }) { - const { trainingId } = request.params; - const training = await dependencies.trainingSerializer.deserialize(request.payload); - const updatedTraining = await usecases.updateTraining({ training: { ...training, id: trainingId } }); - return dependencies.trainingSerializer.serialize(updatedTraining); - }, +const update = async function (request, h, dependencies = { trainingSerializer }) { + const { trainingId } = request.params; + const training = await dependencies.trainingSerializer.deserialize(request.payload); + const updatedTraining = await usecases.updateTraining({ training: { ...training, id: trainingId } }); + return dependencies.trainingSerializer.serialize(updatedTraining); +}; - async createOrUpdateTrigger(request, h, dependencies = { trainingTriggerSerializer }) { - const { trainingId } = request.params; - const { threshold, tubes, type } = await dependencies.trainingTriggerSerializer.deserialize(request.payload); +const createOrUpdateTrigger = async function (request, h, dependencies = { trainingTriggerSerializer }) { + const { trainingId } = request.params; + const { threshold, tubes, type } = await dependencies.trainingTriggerSerializer.deserialize(request.payload); - const createdOrUpdatedTrainingTrigger = await DomainTransaction.execute(async (domainTransaction) => { - return usecases.createOrUpdateTrainingTrigger({ - trainingId, - threshold, - tubes, - type, - domainTransaction, - }); + const createdOrUpdatedTrainingTrigger = await DomainTransaction.execute(async (domainTransaction) => { + return usecases.createOrUpdateTrainingTrigger({ + trainingId, + threshold, + tubes, + type, + domainTransaction, }); + }); - return dependencies.trainingTriggerSerializer.serialize(createdOrUpdatedTrainingTrigger); - }, + return dependencies.trainingTriggerSerializer.serialize(createdOrUpdatedTrainingTrigger); +}; - async attachTargetProfiles(request, h) { - const { id: trainingId } = request.params; - const targetProfileIds = request.payload['target-profile-ids']; - await usecases.attachTargetProfilesToTraining({ - trainingId, - targetProfileIds, - }); - return h.response({}).code(204); - }, +const attachTargetProfiles = async function (request, h) { + const { id: trainingId } = request.params; + const targetProfileIds = request.payload['target-profile-ids']; + await usecases.attachTargetProfilesToTraining({ + trainingId, + targetProfileIds, + }); + return h.response({}).code(204); }; + +const trainingController = { + findPaginatedTrainingSummaries, + findTargetProfileSummaries, + getById, + create, + update, + createOrUpdateTrigger, + attachTargetProfiles, +}; + +export { trainingController }; diff --git a/api/lib/application/tutorial-evaluations/index.js b/api/lib/application/tutorial-evaluations/index.js index 3b4dff85a3c..e1c92086e10 100644 --- a/api/lib/application/tutorial-evaluations/index.js +++ b/api/lib/application/tutorial-evaluations/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const tutorialEvaluationsController = require('./tutorial-evaluations-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { tutorialEvaluationsController } from './tutorial-evaluations-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'PUT', @@ -37,4 +37,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'tutorial-evaluations-api'; +const name = 'tutorial-evaluations-api'; +export { register, name }; diff --git a/api/lib/application/tutorial-evaluations/tutorial-evaluations-controller.js b/api/lib/application/tutorial-evaluations/tutorial-evaluations-controller.js index 54c43f82e05..bf49482e96a 100644 --- a/api/lib/application/tutorial-evaluations/tutorial-evaluations-controller.js +++ b/api/lib/application/tutorial-evaluations/tutorial-evaluations-controller.js @@ -1,17 +1,18 @@ -const usecases = require('../../domain/usecases/index.js'); -const tutorialEvaluationSerializer = require('../../infrastructure/serializers/jsonapi/tutorial-evaluation-serializer.js'); -const TutorialEvaluation = require('../../../lib/domain/models/TutorialEvaluation.js'); +import { usecases } from '../../domain/usecases/index.js'; +import * as tutorialEvaluationSerializer from '../../infrastructure/serializers/jsonapi/tutorial-evaluation-serializer.js'; +import { TutorialEvaluation } from '../../../lib/domain/models/TutorialEvaluation.js'; -module.exports = { - async evaluate(request, h, dependencies = { tutorialEvaluationSerializer }) { - const { userId } = request.auth.credentials; - const { tutorialId } = request.params; - const { status = TutorialEvaluation.statuses.LIKED } = dependencies.tutorialEvaluationSerializer.deserialize( - request.payload - ); +const evaluate = async function (request, h, dependencies = { tutorialEvaluationSerializer }) { + const { userId } = request.auth.credentials; + const { tutorialId } = request.params; + const { status = TutorialEvaluation.statuses.LIKED } = dependencies.tutorialEvaluationSerializer.deserialize( + request.payload + ); - const tutorialEvaluation = await usecases.addTutorialEvaluation({ userId, tutorialId, status }); + const tutorialEvaluation = await usecases.addTutorialEvaluation({ userId, tutorialId, status }); - return h.response(tutorialEvaluationSerializer.serialize(tutorialEvaluation)).created(); - }, + return h.response(tutorialEvaluationSerializer.serialize(tutorialEvaluation)).created(); }; + +const tutorialEvaluationsController = { evaluate }; +export { tutorialEvaluationsController }; diff --git a/api/lib/application/usecases/checkAdminMemberHasRoleCertif.js b/api/lib/application/usecases/checkAdminMemberHasRoleCertif.js index e220c568921..c28ed764bbd 100644 --- a/api/lib/application/usecases/checkAdminMemberHasRoleCertif.js +++ b/api/lib/application/usecases/checkAdminMemberHasRoleCertif.js @@ -1,8 +1,8 @@ -const adminMemberRepository = require('../../infrastructure/repositories/admin-member-repository.js'); +import * as adminMemberRepository from '../../infrastructure/repositories/admin-member-repository.js'; -module.exports = { - async execute(userId, dependencies = { adminMemberRepository }) { - const adminMember = await dependencies.adminMemberRepository.get({ userId }); - return adminMember.isCertif; - }, +const execute = async function (userId, dependencies = { adminMemberRepository }) { + const adminMember = await dependencies.adminMemberRepository.get({ userId }); + return adminMember.isCertif; }; + +export { execute }; diff --git a/api/lib/application/usecases/checkAdminMemberHasRoleMetier.js b/api/lib/application/usecases/checkAdminMemberHasRoleMetier.js index 0bfca70b33b..44900b60f04 100644 --- a/api/lib/application/usecases/checkAdminMemberHasRoleMetier.js +++ b/api/lib/application/usecases/checkAdminMemberHasRoleMetier.js @@ -1,8 +1,8 @@ -const adminMemberRepository = require('../../infrastructure/repositories/admin-member-repository.js'); +import * as adminMemberRepository from '../../infrastructure/repositories/admin-member-repository.js'; -module.exports = { - async execute(userId, dependencies = { adminMemberRepository }) { - const adminMember = await dependencies.adminMemberRepository.get({ userId }); - return adminMember.isMetier; - }, +const execute = async function (userId, dependencies = { adminMemberRepository }) { + const adminMember = await dependencies.adminMemberRepository.get({ userId }); + return adminMember.isMetier; }; + +export { execute }; diff --git a/api/lib/application/usecases/checkAdminMemberHasRoleSuperAdmin.js b/api/lib/application/usecases/checkAdminMemberHasRoleSuperAdmin.js index 51026bed14b..b6264d6f3b7 100644 --- a/api/lib/application/usecases/checkAdminMemberHasRoleSuperAdmin.js +++ b/api/lib/application/usecases/checkAdminMemberHasRoleSuperAdmin.js @@ -1,8 +1,8 @@ -const adminMemberRepository = require('../../infrastructure/repositories/admin-member-repository.js'); +import * as adminMemberRepository from '../../infrastructure/repositories/admin-member-repository.js'; -module.exports = { - async execute(userId, dependencies = { adminMemberRepository }) { - const adminMember = await dependencies.adminMemberRepository.get({ userId }); - return adminMember.isSuperAdmin; - }, +const execute = async function (userId, dependencies = { adminMemberRepository }) { + const adminMember = await dependencies.adminMemberRepository.get({ userId }); + return adminMember.isSuperAdmin; }; + +export { execute }; diff --git a/api/lib/application/usecases/checkAdminMemberHasRoleSupport.js b/api/lib/application/usecases/checkAdminMemberHasRoleSupport.js index 770b586ceac..bbb2b0b608e 100644 --- a/api/lib/application/usecases/checkAdminMemberHasRoleSupport.js +++ b/api/lib/application/usecases/checkAdminMemberHasRoleSupport.js @@ -1,8 +1,8 @@ -const adminMemberRepository = require('../../infrastructure/repositories/admin-member-repository.js'); +import * as adminMemberRepository from '../../infrastructure/repositories/admin-member-repository.js'; -module.exports = { - async execute(userId, dependencies = { adminMemberRepository }) { - const adminMember = await dependencies.adminMemberRepository.get({ userId }); - return adminMember.isSupport; - }, +const execute = async function (userId, dependencies = { adminMemberRepository }) { + const adminMember = await dependencies.adminMemberRepository.get({ userId }); + return adminMember.isSupport; }; + +export { execute }; diff --git a/api/lib/application/usecases/checkAuthorizationToManageCampaign.js b/api/lib/application/usecases/checkAuthorizationToManageCampaign.js index 72ad59b42ba..cf2f29e03c9 100644 --- a/api/lib/application/usecases/checkAuthorizationToManageCampaign.js +++ b/api/lib/application/usecases/checkAuthorizationToManageCampaign.js @@ -1,9 +1,9 @@ -const prescriberRoleRepository = require('../../infrastructure/repositories/prescriber-role-repository.js'); -const CampaignAuthorization = require('../preHandlers/models/CampaignAuthorization.js'); +import * as prescriberRoleRepository from '../../infrastructure/repositories/prescriber-role-repository.js'; +import { CampaignAuthorization } from '../preHandlers/models/CampaignAuthorization.js'; -module.exports = { - async execute({ userId, campaignId }) { - const prescriberRole = await prescriberRoleRepository.getForCampaign({ userId, campaignId }); - return CampaignAuthorization.isAllowedToManage({ prescriberRole }); - }, +const execute = async function ({ userId, campaignId }) { + const prescriberRole = await prescriberRoleRepository.getForCampaign({ userId, campaignId }); + return CampaignAuthorization.isAllowedToManage({ prescriberRole }); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkIfUserIsBlocked.js b/api/lib/application/usecases/checkIfUserIsBlocked.js index dbc552fdc8f..c39c8220e0f 100644 --- a/api/lib/application/usecases/checkIfUserIsBlocked.js +++ b/api/lib/application/usecases/checkIfUserIsBlocked.js @@ -1,14 +1,14 @@ -const { UserIsTemporaryBlocked, UserIsBlocked } = require('../../domain/errors.js'); -const userLoginRepository = require('../../infrastructure/repositories/user-login-repository.js'); +import { UserIsTemporaryBlocked, UserIsBlocked } from '../../domain/errors.js'; +import * as userLoginRepository from '../../infrastructure/repositories/user-login-repository.js'; -module.exports = { - async execute(username) { - const foundUserLogin = await userLoginRepository.findByUsername(username); - if (foundUserLogin?.isUserMarkedAsBlocked()) { - throw new UserIsBlocked(); - } - if (foundUserLogin?.isUserMarkedAsTemporaryBlocked()) { - throw new UserIsTemporaryBlocked(); - } - }, +const execute = async function (username) { + const foundUserLogin = await userLoginRepository.findByUsername(username); + if (foundUserLogin?.isUserMarkedAsBlocked()) { + throw new UserIsBlocked(); + } + if (foundUserLogin?.isUserMarkedAsTemporaryBlocked()) { + throw new UserIsTemporaryBlocked(); + } }; + +export { execute }; diff --git a/api/lib/application/usecases/checkOrganizationIsScoAndManagingStudent.js b/api/lib/application/usecases/checkOrganizationIsScoAndManagingStudent.js index 793ccb8fb01..8d036bffb42 100644 --- a/api/lib/application/usecases/checkOrganizationIsScoAndManagingStudent.js +++ b/api/lib/application/usecases/checkOrganizationIsScoAndManagingStudent.js @@ -1,14 +1,15 @@ -const organizationRepository = require('../../infrastructure/repositories/organization-repository.js'); - -module.exports = { - async execute({ - organizationId, - dependencies = { - organizationRepository, - }, - }) { - const organization = await dependencies.organizationRepository.get(organizationId); - - return organization.isScoAndManagingStudents; +import * as organizationRepository from '../../infrastructure/repositories/organization-repository.js'; + +const execute = async function ({ + organizationId, + + dependencies = { + organizationRepository, }, +}) { + const organization = await dependencies.organizationRepository.get(organizationId); + + return organization.isScoAndManagingStudents; }; + +export { execute }; diff --git a/api/lib/application/usecases/checkPix1dEnabled.js b/api/lib/application/usecases/checkPix1dEnabled.js index 8a1055fb533..56154a6ed26 100644 --- a/api/lib/application/usecases/checkPix1dEnabled.js +++ b/api/lib/application/usecases/checkPix1dEnabled.js @@ -1,7 +1,7 @@ -const settings = require('../../config'); +import { config as settings } from '../../config.js'; -module.exports = { - async execute() { - return settings.featureToggles.isPix1dEnabled; - }, +const execute = async function () { + return settings.featureToggles.isPix1dEnabled; }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserBelongsToLearnersOrganization.js b/api/lib/application/usecases/checkUserBelongsToLearnersOrganization.js index 75d5876af1e..8f515016ab7 100644 --- a/api/lib/application/usecases/checkUserBelongsToLearnersOrganization.js +++ b/api/lib/application/usecases/checkUserBelongsToLearnersOrganization.js @@ -1,14 +1,18 @@ -const _ = require('lodash'); -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); -const organizationLearnerRepository = require('../../infrastructure/repositories/organization-learner-repository.js'); +import _ from 'lodash'; +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; +import * as organizationLearnerRepository from '../../infrastructure/repositories/organization-learner-repository.js'; -module.exports = { - async execute(userId, organizationLearnerId, dependencies = { membershipRepository, organizationLearnerRepository }) { - const organizationLearner = await dependencies.organizationLearnerRepository.get(organizationLearnerId); - const memberships = await dependencies.membershipRepository.findByUserIdAndOrganizationId({ - userId, - organizationId: organizationLearner.organizationId, - }); - return !_.isEmpty(memberships); - }, +const execute = async function ( + userId, + organizationLearnerId, + dependencies = { membershipRepository, organizationLearnerRepository } +) { + const organizationLearner = await dependencies.organizationLearnerRepository.get(organizationLearnerId); + const memberships = await dependencies.membershipRepository.findByUserIdAndOrganizationId({ + userId, + organizationId: organizationLearner.organizationId, + }); + return !_.isEmpty(memberships); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserBelongsToOrganization.js b/api/lib/application/usecases/checkUserBelongsToOrganization.js index a61768ee728..0c78bffab67 100644 --- a/api/lib/application/usecases/checkUserBelongsToOrganization.js +++ b/api/lib/application/usecases/checkUserBelongsToOrganization.js @@ -1,10 +1,10 @@ -const _ = require('lodash'); -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); +import _ from 'lodash'; +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; -module.exports = { - execute(userId, organizationId, dependencies = { membershipRepository }) { - return dependencies.membershipRepository - .findByUserIdAndOrganizationId({ userId, organizationId }) - .then((memberships) => !_.isEmpty(memberships)); - }, +const execute = function (userId, organizationId, dependencies = { membershipRepository }) { + return dependencies.membershipRepository + .findByUserIdAndOrganizationId({ userId, organizationId }) + .then((memberships) => !_.isEmpty(memberships)); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserBelongsToOrganizationManagingStudents.js b/api/lib/application/usecases/checkUserBelongsToOrganizationManagingStudents.js index 20b77565b33..4ea4022e835 100644 --- a/api/lib/application/usecases/checkUserBelongsToOrganizationManagingStudents.js +++ b/api/lib/application/usecases/checkUserBelongsToOrganizationManagingStudents.js @@ -1,15 +1,15 @@ -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; -module.exports = { - async execute(userId, organizationId, dependencies = { membershipRepository }) { - const memberships = await dependencies.membershipRepository.findByUserIdAndOrganizationId({ - userId, - organizationId, - includeOrganization: true, - }); - return memberships.reduce( - (belongsToScoOrganization, membership) => belongsToScoOrganization || membership.organization.isManagingStudents, - false - ); - }, +const execute = async function (userId, organizationId, dependencies = { membershipRepository }) { + const memberships = await dependencies.membershipRepository.findByUserIdAndOrganizationId({ + userId, + organizationId, + includeOrganization: true, + }); + return memberships.reduce( + (belongsToScoOrganization, membership) => belongsToScoOrganization || membership.organization.isManagingStudents, + false + ); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents.js b/api/lib/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents.js index 63b706ca0ec..350a59afd6d 100644 --- a/api/lib/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents.js +++ b/api/lib/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents.js @@ -1,15 +1,13 @@ -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; -module.exports = { - async execute(userId, organizationId, dependencies = { membershipRepository }) { - const memberships = await dependencies.membershipRepository.findByUserIdAndOrganizationId({ - userId, - organizationId, - includeOrganization: true, - }); +const execute = async function (userId, organizationId, dependencies = { membershipRepository }) { + const memberships = await dependencies.membershipRepository.findByUserIdAndOrganizationId({ + userId, + organizationId, + includeOrganization: true, + }); - return memberships.some( - (membership) => membership.organization.isManagingStudents && membership.organization.isSco - ); - }, + return memberships.some((membership) => membership.organization.isManagingStudents && membership.organization.isSco); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents.js b/api/lib/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents.js index 24ade861f71..a24e890b1b5 100644 --- a/api/lib/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents.js +++ b/api/lib/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents.js @@ -1,15 +1,13 @@ -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; -module.exports = { - async execute(userId, organizationId, dependencies = { membershipRepository }) { - const memberships = await dependencies.membershipRepository.findByUserIdAndOrganizationId({ - userId, - organizationId, - includeOrganization: true, - }); +const execute = async function (userId, organizationId, dependencies = { membershipRepository }) { + const memberships = await dependencies.membershipRepository.findByUserIdAndOrganizationId({ + userId, + organizationId, + includeOrganization: true, + }); - return memberships.some( - (membership) => membership.organization.isManagingStudents && membership.organization.isSup - ); - }, + return memberships.some((membership) => membership.organization.isManagingStudents && membership.organization.isSup); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization.js b/api/lib/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization.js index bbfb2247696..0b78a54f9c1 100644 --- a/api/lib/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization.js +++ b/api/lib/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization.js @@ -1,21 +1,21 @@ -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); -const Membership = require('../../domain/models/Membership.js'); +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; +import { Membership } from '../../domain/models/Membership.js'; -module.exports = { - async execute(userId, organizationId, type) { - const memberships = await membershipRepository.findByUserIdAndOrganizationId({ - userId, - organizationId, - includeOrganization: true, - }); - if (memberships.length === 0) { - return false; - } - return memberships.some( - (membership) => - membership.organization.isManagingStudents && - membership.organization.type === type && - membership.organizationRole === Membership.roles.ADMIN - ); - }, +const execute = async function (userId, organizationId, type) { + const memberships = await membershipRepository.findByUserIdAndOrganizationId({ + userId, + organizationId, + includeOrganization: true, + }); + if (memberships.length === 0) { + return false; + } + return memberships.some( + (membership) => + membership.organization.isManagingStudents && + membership.organization.type === type && + membership.organizationRole === Membership.roles.ADMIN + ); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserIsAdminInOrganization.js b/api/lib/application/usecases/checkUserIsAdminInOrganization.js index 1afc79ddeec..84aaa1175ec 100644 --- a/api/lib/application/usecases/checkUserIsAdminInOrganization.js +++ b/api/lib/application/usecases/checkUserIsAdminInOrganization.js @@ -1,11 +1,11 @@ -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; -module.exports = { - execute(userId, organizationId, dependencies = { membershipRepository }) { - return dependencies.membershipRepository - .findByUserIdAndOrganizationId({ userId, organizationId }) - .then((memberships) => - memberships.reduce((isAdminInOrganization, membership) => isAdminInOrganization || membership.isAdmin, false) - ); - }, +const execute = function (userId, organizationId, dependencies = { membershipRepository }) { + return dependencies.membershipRepository + .findByUserIdAndOrganizationId({ userId, organizationId }) + .then((memberships) => + memberships.reduce((isAdminInOrganization, membership) => isAdminInOrganization || membership.isAdmin, false) + ); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserIsMemberOfAnOrganization.js b/api/lib/application/usecases/checkUserIsMemberOfAnOrganization.js index 9234da19fd9..52aa47fc6b1 100644 --- a/api/lib/application/usecases/checkUserIsMemberOfAnOrganization.js +++ b/api/lib/application/usecases/checkUserIsMemberOfAnOrganization.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); +import _ from 'lodash'; +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; -module.exports = { - execute(userId) { - return membershipRepository.findByUserId({ userId }).then((memberships) => !_.isEmpty(memberships)); - }, +const execute = function (userId) { + return membershipRepository.findByUserId({ userId }).then((memberships) => !_.isEmpty(memberships)); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserIsMemberOfCertificationCenter.js b/api/lib/application/usecases/checkUserIsMemberOfCertificationCenter.js index 746b37e501f..f8ce26655e4 100644 --- a/api/lib/application/usecases/checkUserIsMemberOfCertificationCenter.js +++ b/api/lib/application/usecases/checkUserIsMemberOfCertificationCenter.js @@ -1,10 +1,14 @@ -const certificationCenterMembershipRepository = require('../../infrastructure/repositories/certification-center-membership-repository.js'); +import * as certificationCenterMembershipRepository from '../../infrastructure/repositories/certification-center-membership-repository.js'; -module.exports = { - async execute(userId, certificationCenterId, dependencies = { certificationCenterMembershipRepository }) { - return await dependencies.certificationCenterMembershipRepository.isMemberOfCertificationCenter({ - userId, - certificationCenterId, - }); - }, +const execute = async function ( + userId, + certificationCenterId, + dependencies = { certificationCenterMembershipRepository } +) { + return await dependencies.certificationCenterMembershipRepository.isMemberOfCertificationCenter({ + userId, + certificationCenterId, + }); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserIsMemberOfCertificationCenterSession.js b/api/lib/application/usecases/checkUserIsMemberOfCertificationCenterSession.js index 6d966c71409..ed6ab8cf4a1 100644 --- a/api/lib/application/usecases/checkUserIsMemberOfCertificationCenterSession.js +++ b/api/lib/application/usecases/checkUserIsMemberOfCertificationCenterSession.js @@ -1,16 +1,16 @@ -const certificationCourseRepository = require('../../infrastructure/repositories/certification-course-repository.js'); -const sessionRepository = require('../../infrastructure/repositories/sessions/session-repository.js'); +import * as certificationCourseRepository from '../../infrastructure/repositories/certification-course-repository.js'; +import * as sessionRepository from '../../infrastructure/repositories/sessions/session-repository.js'; -module.exports = { - async execute({ +const execute = async function ({ + userId, + certificationCourseId, + dependencies = { certificationCourseRepository, sessionRepository }, +}) { + const certificationCourse = await dependencies.certificationCourseRepository.get(certificationCourseId); + return dependencies.sessionRepository.doesUserHaveCertificationCenterMembershipForSession( userId, - certificationCourseId, - dependencies = { certificationCourseRepository, sessionRepository }, - }) { - const certificationCourse = await dependencies.certificationCourseRepository.get(certificationCourseId); - return dependencies.sessionRepository.doesUserHaveCertificationCenterMembershipForSession( - userId, - certificationCourse.getSessionId() - ); - }, + certificationCourse.getSessionId() + ); }; + +export { execute }; diff --git a/api/lib/application/usecases/checkUserOwnsCertificationCourse.js b/api/lib/application/usecases/checkUserOwnsCertificationCourse.js index 54bd54b99a0..c4e1ad41377 100644 --- a/api/lib/application/usecases/checkUserOwnsCertificationCourse.js +++ b/api/lib/application/usecases/checkUserOwnsCertificationCourse.js @@ -1,8 +1,8 @@ -const certificationCourseRepository = require('../../infrastructure/repositories/certification-course-repository.js'); +import * as certificationCourseRepository from '../../infrastructure/repositories/certification-course-repository.js'; -module.exports = { - async execute({ userId, certificationCourseId, dependencies = { certificationCourseRepository } }) { - const certificationCourse = await dependencies.certificationCourseRepository.get(certificationCourseId); - return certificationCourse.doesBelongTo(userId); - }, +const execute = async function ({ userId, certificationCourseId, dependencies = { certificationCourseRepository } }) { + const certificationCourse = await dependencies.certificationCourseRepository.get(certificationCourseId); + return certificationCourse.doesBelongTo(userId); }; + +export { execute }; diff --git a/api/lib/application/user-orga-settings/index.js b/api/lib/application/user-orga-settings/index.js index 71c2d6c5e99..525d60325cb 100644 --- a/api/lib/application/user-orga-settings/index.js +++ b/api/lib/application/user-orga-settings/index.js @@ -1,9 +1,9 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const userOrgaSettingsController = require('./user-orga-settings-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { userOrgaSettingsController } from './user-orga-settings-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; -exports.register = async function (server) { +const register = async function (server) { server.route([ { method: 'PUT', @@ -40,4 +40,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'user-orga-settings-api'; +const name = 'user-orga-settings-api'; +export { register, name }; diff --git a/api/lib/application/user-orga-settings/user-orga-settings-controller.js b/api/lib/application/user-orga-settings/user-orga-settings-controller.js index 9ba69b020ce..16a6ac1cb44 100644 --- a/api/lib/application/user-orga-settings/user-orga-settings-controller.js +++ b/api/lib/application/user-orga-settings/user-orga-settings-controller.js @@ -1,19 +1,21 @@ -const userOrgaSettingsSerializer = require('../../infrastructure/serializers/jsonapi/user-orga-settings-serializer.js'); -const { UserNotAuthorizedToCreateResourceError } = require('../../domain/errors.js'); -const usecases = require('../../domain/usecases/index.js'); +import * as userOrgaSettingsSerializer from '../../infrastructure/serializers/jsonapi/user-orga-settings-serializer.js'; +import { UserNotAuthorizedToCreateResourceError } from '../../domain/errors.js'; +import { usecases } from '../../domain/usecases/index.js'; -module.exports = { - async createOrUpdate(request, h, dependencies = { userOrgaSettingsSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - const userId = request.params.id; - const organizationId = request.payload.data.relationships.organization.data.id; +const createOrUpdate = async function (request, h, dependencies = { userOrgaSettingsSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + const userId = request.params.id; + const organizationId = request.payload.data.relationships.organization.data.id; - if (userId !== authenticatedUserId) { - throw new UserNotAuthorizedToCreateResourceError(); - } + if (userId !== authenticatedUserId) { + throw new UserNotAuthorizedToCreateResourceError(); + } - const result = await usecases.createOrUpdateUserOrgaSettings({ userId, organizationId }); + const result = await usecases.createOrUpdateUserOrgaSettings({ userId, organizationId }); - return dependencies.userOrgaSettingsSerializer.serialize(result); - }, + return dependencies.userOrgaSettingsSerializer.serialize(result); }; + +const userOrgaSettingsController = { createOrUpdate }; + +export { userOrgaSettingsController }; diff --git a/api/lib/application/user-tutorials/index.js b/api/lib/application/user-tutorials/index.js index 13f40ad471c..4f15a3346e7 100644 --- a/api/lib/application/user-tutorials/index.js +++ b/api/lib/application/user-tutorials/index.js @@ -1,10 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const userTutorialsController = require('./user-tutorials-controller.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const securityPreHandlers = require('../security-pre-handlers.js'); +import { userTutorialsController } from './user-tutorials-controller.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import { securityPreHandlers } from '../security-pre-handlers.js'; -exports.register = async (server) => { +const register = async function (server) { server.route([ { method: 'PUT', @@ -85,4 +85,5 @@ exports.register = async (server) => { ]); }; -exports.name = 'tutorials-api'; +const name = 'tutorials-api'; +export { register, name }; diff --git a/api/lib/application/user-tutorials/user-tutorials-controller.js b/api/lib/application/user-tutorials/user-tutorials-controller.js index 71688854706..1ad5fd612d6 100644 --- a/api/lib/application/user-tutorials/user-tutorials-controller.js +++ b/api/lib/application/user-tutorials/user-tutorials-controller.js @@ -1,40 +1,45 @@ -const usecases = require('../../domain/usecases/index.js'); -const userSavedTutorialSerializer = require('../../infrastructure/serializers/jsonapi/user-saved-tutorial-serializer.js'); -const tutorialSerializer = require('../../infrastructure/serializers/jsonapi/tutorial-serializer.js'); -const userSavedTutorialRepository = require('../../infrastructure/repositories/user-saved-tutorial-repository.js'); -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); - -module.exports = { - async add(request, h, dependencies = { userSavedTutorialSerializer }) { - const { userId } = request.auth.credentials; - const { tutorialId } = request.params; - const userSavedTutorial = dependencies.userSavedTutorialSerializer.deserialize(request.payload); - - const createdUserSavedTutorial = await usecases.addTutorialToUser({ ...userSavedTutorial, userId, tutorialId }); - - return h.response(dependencies.userSavedTutorialSerializer.serialize(createdUserSavedTutorial)).created(); - }, - - async find(request, h, dependencies = { queryParamsUtils, requestResponseUtils, tutorialSerializer }) { - const { userId } = request.auth.credentials; - const { page, filter: filters } = dependencies.queryParamsUtils.extractParameters(request.query); - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - const { tutorials, meta } = await usecases.findPaginatedFilteredTutorials({ - userId, - filters, - page, - locale, - }); - return dependencies.tutorialSerializer.serialize(tutorials, meta); - }, - - async removeFromUser(request, h, dependencies = { userSavedTutorialRepository }) { - const { userId } = request.auth.credentials; - const { tutorialId } = request.params; - - await dependencies.userSavedTutorialRepository.removeFromUser({ userId, tutorialId }); - - return h.response().code(204); - }, +import { usecases } from '../../domain/usecases/index.js'; +import * as userSavedTutorialSerializer from '../../infrastructure/serializers/jsonapi/user-saved-tutorial-serializer.js'; +import * as tutorialSerializer from '../../infrastructure/serializers/jsonapi/tutorial-serializer.js'; +import * as userSavedTutorialRepository from '../../infrastructure/repositories/user-saved-tutorial-repository.js'; +import * as queryParamsUtils from '../../infrastructure/utils/query-params-utils.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; + +const add = async function (request, h, dependencies = { userSavedTutorialSerializer }) { + const { userId } = request.auth.credentials; + const { tutorialId } = request.params; + const userSavedTutorial = dependencies.userSavedTutorialSerializer.deserialize(request.payload); + + const createdUserSavedTutorial = await usecases.addTutorialToUser({ ...userSavedTutorial, userId, tutorialId }); + + return h.response(dependencies.userSavedTutorialSerializer.serialize(createdUserSavedTutorial)).created(); +}; + +const find = async function ( + request, + h, + dependencies = { queryParamsUtils, requestResponseUtils, tutorialSerializer } +) { + const { userId } = request.auth.credentials; + const { page, filter: filters } = dependencies.queryParamsUtils.extractParameters(request.query); + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const { tutorials, meta } = await usecases.findPaginatedFilteredTutorials({ + userId, + filters, + page, + locale, + }); + return dependencies.tutorialSerializer.serialize(tutorials, meta); }; + +const removeFromUser = async function (request, h, dependencies = { userSavedTutorialRepository }) { + const { userId } = request.auth.credentials; + const { tutorialId } = request.params; + + await dependencies.userSavedTutorialRepository.removeFromUser({ userId, tutorialId }); + + return h.response().code(204); +}; + +const userTutorialsController = { add, find, removeFromUser }; +export { userTutorialsController }; diff --git a/api/lib/application/users/index.js b/api/lib/application/users/index.js index 785e7f7924c..19af6e8faeb 100644 --- a/api/lib/application/users/index.js +++ b/api/lib/application/users/index.js @@ -1,15 +1,18 @@ -const Joi = require('joi'); -const XRegExp = require('xregexp'); -const securityPreHandlers = require('../security-pre-handlers.js'); -const userController = require('./user-controller.js'); -const { sendJsonApiError, BadRequestError } = require('../http-errors.js'); -const userVerification = require('../preHandlers/user-existence-verification.js'); -const { passwordValidationPattern } = require('../../config.js').account; -const { EntityValidationError } = require('../../domain/errors.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); -const OidcIdentityProviders = require('../../domain/constants/oidc-identity-providers.js'); +import Joi from 'joi'; +import XRegExp from 'xregexp'; +import { securityPreHandlers } from '../security-pre-handlers.js'; +import { userController } from './user-controller.js'; +import { sendJsonApiError, BadRequestError } from '../http-errors.js'; +import { userVerification } from '../preHandlers/user-existence-verification.js'; +import { config } from '../../config.js'; -exports.register = async function (server) { +const { passwordValidationPattern } = config.account; + +import { EntityValidationError } from '../../domain/errors.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; +import * as OidcIdentityProviders from '../../domain/constants/oidc-identity-providers.js'; + +const register = async function (server) { const adminRoutes = [ { method: 'GET', @@ -970,4 +973,5 @@ exports.register = async function (server) { ]); }; -exports.name = 'users-api'; +const name = 'users-api'; +export { register, name }; diff --git a/api/lib/application/users/user-controller.js b/api/lib/application/users/user-controller.js index d27c3350823..1a165e1cac1 100644 --- a/api/lib/application/users/user-controller.js +++ b/api/lib/application/users/user-controller.js @@ -1,412 +1,477 @@ -const campaignParticipationSerializer = require('../../infrastructure/serializers/jsonapi/campaign-participation-serializer.js'); -const campaignParticipationOverviewSerializer = require('../../infrastructure/serializers/jsonapi/campaign-participation-overview-serializer.js'); -const certificationEligibilitySerializer = require('../../infrastructure/serializers/jsonapi/certification-eligibility-serializer.js'); -const scorecardSerializer = require('../../infrastructure/serializers/jsonapi/scorecard-serializer.js'); -const profileSerializer = require('../../infrastructure/serializers/jsonapi/profile-serializer.js'); -const participantResultSerializer = require('../../infrastructure/serializers/jsonapi/participant-result-serializer.js'); -const sharedProfileForCampaignSerializer = require('../../infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer.js'); -const userSerializer = require('../../infrastructure/serializers/jsonapi/user-serializer.js'); -const userForAdminSerializer = require('../../infrastructure/serializers/jsonapi/user-for-admin-serializer.js'); -const userWithActivitySerializer = require('../../infrastructure/serializers/jsonapi/user-with-activity-serializer.js'); -const emailVerificationSerializer = require('../../infrastructure/serializers/jsonapi/email-verification-serializer.js'); -const userDetailsForAdminSerializer = require('../../infrastructure/serializers/jsonapi/user-details-for-admin-serializer.js'); -const userAnonymizedDetailsForAdminSerializer = require('../../infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer.js'); -const updateEmailSerializer = require('../../infrastructure/serializers/jsonapi/update-email-serializer.js'); -const authenticationMethodsSerializer = require('../../infrastructure/serializers/jsonapi/authentication-methods-serializer.js'); -const campaignParticipationForUserManagementSerializer = require('../../infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer.js'); -const userOrganizationForAdminSerializer = require('../../infrastructure/serializers/jsonapi/user-organization-for-admin-serializer.js'); -const certificationCenterMembershipSerializer = require('../../infrastructure/serializers/jsonapi/certification-center-membership-serializer.js'); -const trainingSerializer = require('../../infrastructure/serializers/jsonapi/training-serializer.js'); -const userLoginSerializer = require('../../infrastructure/serializers/jsonapi/user-login-serializer.js'); - -const queryParamsUtils = require('../../infrastructure/utils/query-params-utils.js'); -const requestResponseUtils = require('../../infrastructure/utils/request-response-utils.js'); - -const usecases = require('../../domain/usecases/index.js'); -const localeService = require('../../domain/services/locale-service.js'); - -module.exports = { - async save(request, h, dependencies = { userSerializer, requestResponseUtils, localeService }) { - const localeFromCookie = request.state?.locale; - const canonicalLocaleFromCookie = localeFromCookie - ? dependencies.localeService.getCanonicalLocale(localeFromCookie) - : undefined; - const campaignCode = request.payload.meta ? request.payload.meta['campaign-code'] : null; - const user = { ...dependencies.userSerializer.deserialize(request.payload), locale: canonicalLocaleFromCookie }; - const localeFromHeader = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - - const password = request.payload.data.attributes.password; - - const savedUser = await usecases.createUser({ - user, - password, - campaignCode, - localeFromHeader, - }); - - return h.response(dependencies.userSerializer.serialize(savedUser)).created(); - }, - - getCurrentUser(request, h, dependencies = { userWithActivitySerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - return usecases.getCurrentUser({ authenticatedUserId }).then(dependencies.userWithActivitySerializer.serialize); - }, - - async getUserDetailsForAdmin(request, h, dependencies = { userDetailsForAdminSerializer }) { - const userId = request.params.id; - const userDetailsForAdmin = await usecases.getUserDetailsForAdmin({ userId }); - return dependencies.userDetailsForAdminSerializer.serialize(userDetailsForAdmin); - }, - - async updatePassword(request, h, dependencies = { userSerializer }) { - const userId = request.params.id; - const password = request.payload.data.attributes.password; - - const updatedUser = await usecases.updateUserPassword({ - userId, - password, - temporaryKey: request.query['temporary-key'] || '', - }); - - return dependencies.userSerializer.serialize(updatedUser); - }, - - async updateUserDetailsForAdministration(request, h, dependencies = { userDetailsForAdminSerializer }) { - const userId = request.params.id; - const userDetailsForAdministration = dependencies.userDetailsForAdminSerializer.deserialize(request.payload); - - const updatedUser = await usecases.updateUserDetailsForAdministration({ - userId, - userDetailsForAdministration, - }); - - return dependencies.userDetailsForAdminSerializer.serializeForUpdate(updatedUser); - }, - - async acceptPixLastTermsOfService(request, h, dependencies = { userSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - - const updatedUser = await usecases.acceptPixLastTermsOfService({ - userId: authenticatedUserId, - }); - - return dependencies.userSerializer.serialize(updatedUser); - }, - - async changeLang(request, h, dependencies = { userSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - const lang = request.params.lang; - const updatedUser = await usecases.changeUserLang({ - userId: authenticatedUserId, - lang, - }); - - return dependencies.userSerializer.serialize(updatedUser); - }, - - async acceptPixOrgaTermsOfService(request, h, dependencies = { userSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - - const updatedUser = await usecases.acceptPixOrgaTermsOfService({ - userId: authenticatedUserId, - }); - - return dependencies.userSerializer.serialize(updatedUser); - }, - - async acceptPixCertifTermsOfService(request, h) { - const authenticatedUserId = request.auth.credentials.userId; - - await usecases.acceptPixCertifTermsOfService({ - userId: authenticatedUserId, - }); - - return h.response().code(204); - }, - - async rememberUserHasSeenAssessmentInstructions(request, h, dependencies = { userSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - - const updatedUser = await usecases.rememberUserHasSeenAssessmentInstructions({ userId: authenticatedUserId }); - return dependencies.userSerializer.serialize(updatedUser); - }, - - async rememberUserHasSeenNewDashboardInfo(request, h, dependencies = { userSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - - const updatedUser = await usecases.rememberUserHasSeenNewDashboardInfo({ userId: authenticatedUserId }); - return dependencies.userSerializer.serialize(updatedUser); - }, - - async rememberUserHasSeenChallengeTooltip(request, h, dependencies = { userSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - const challengeType = request.params.challengeType; - - const updatedUser = await usecases.rememberUserHasSeenChallengeTooltip({ - userId: authenticatedUserId, - challengeType, - }); - return dependencies.userSerializer.serialize(updatedUser); - }, - - async findPaginatedFilteredUsers(request, h, dependencies = { userForAdminSerializer, queryParamsUtils }) { - const options = dependencies.queryParamsUtils.extractParameters(request.query); - - const { models: users, pagination } = await usecases.findPaginatedFilteredUsers({ - filter: options.filter, - page: options.page, - }); - return dependencies.userForAdminSerializer.serialize(users, pagination); - }, - - async findPaginatedUserRecommendedTrainings( - request, - h, - dependencies = { - trainingSerializer, - requestResponseUtils, - queryParamsUtils, - } - ) { - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - const { page } = dependencies.queryParamsUtils.extractParameters(request.query); - const { userRecommendedTrainings, meta } = await usecases.findPaginatedUserRecommendedTrainings({ - userId: request.auth.credentials.userId, - locale, - page, - }); - - return dependencies.trainingSerializer.serialize(userRecommendedTrainings, meta); - }, - - getCampaignParticipations(request, h, dependencies = { campaignParticipationSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - - return usecases - .findLatestOngoingUserCampaignParticipations({ userId: authenticatedUserId }) - .then(dependencies.campaignParticipationSerializer.serialize); - }, - - async getCampaignParticipationOverviews( - request, - h, - dependencies = { - campaignParticipationOverviewSerializer, - queryParamsUtils, - } - ) { - const authenticatedUserId = request.auth.credentials.userId; - const query = dependencies.queryParamsUtils.extractParameters(request.query); - - const userCampaignParticipationOverviews = await usecases.findUserCampaignParticipationOverviews({ - userId: authenticatedUserId, - states: query.filter.states, - page: query.page, - }); - - return dependencies.campaignParticipationOverviewSerializer.serializeForPaginatedList( - userCampaignParticipationOverviews - ); - }, - - async isCertifiable(request, h, dependencies = { certificationEligibilitySerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - - const certificationEligibility = await usecases.getUserCertificationEligibility({ userId: authenticatedUserId }); - return dependencies.certificationEligibilitySerializer.serialize(certificationEligibility); - }, - - getProfile(request, h, dependencies = { profileSerializer, requestResponseUtils }) { - const authenticatedUserId = request.auth.credentials.userId; - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - - return usecases - .getUserProfile({ userId: authenticatedUserId, locale }) - .then(dependencies.profileSerializer.serialize); - }, - - getProfileForAdmin(request, h, dependencies = { profileSerializer, requestResponseUtils }) { - const userId = request.params.id; - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - - return usecases.getUserProfile({ userId, locale }).then(dependencies.profileSerializer.serialize); - }, - - resetScorecard(request, h, dependencies = { scorecardSerializer, requestResponseUtils }) { - const authenticatedUserId = request.auth.credentials.userId; - const competenceId = request.params.competenceId; - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - - return usecases - .resetScorecard({ userId: authenticatedUserId, competenceId, locale }) - .then(dependencies.scorecardSerializer.serialize); - }, - - getUserCampaignParticipationToCampaign(request, h, dependencies = { campaignParticipationSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - const campaignId = request.params.campaignId; - - return usecases - .getUserCampaignParticipationToCampaign({ userId: authenticatedUserId, campaignId }) - .then((campaignParticipation) => dependencies.campaignParticipationSerializer.serialize(campaignParticipation)); - }, - - async getUserProfileSharedForCampaign( - request, - h, - dependencies = { - sharedProfileForCampaignSerializer, - requestResponseUtils, - } - ) { - const authenticatedUserId = request.auth.credentials.userId; - const campaignId = request.params.campaignId; - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - - const sharedProfileForCampaign = await usecases.getUserProfileSharedForCampaign({ - userId: authenticatedUserId, - campaignId, - locale, - }); - - return dependencies.sharedProfileForCampaignSerializer.serialize(sharedProfileForCampaign); - }, - - async getUserCampaignAssessmentResult( - request, - h, - dependencies = { - participantResultSerializer, - requestResponseUtils, - } - ) { - const authenticatedUserId = request.auth.credentials.userId; - const campaignId = request.params.campaignId; - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - - const campaignAssessmentResult = await usecases.getUserCampaignAssessmentResult({ - userId: authenticatedUserId, - campaignId, - locale, - }); - - return dependencies.participantResultSerializer.serialize(campaignAssessmentResult); - }, - - async anonymizeUser(request, h, dependencies = { userAnonymizedDetailsForAdminSerializer }) { - const userToAnonymizeId = request.params.id; - const adminMemberId = request.auth.credentials.userId; - const user = await usecases.anonymizeUser({ userId: userToAnonymizeId, updatedByUserId: adminMemberId }); - return h.response(dependencies.userAnonymizedDetailsForAdminSerializer.serialize(user)).code(200); - }, - - async unblockUserAccount(request, h, dependencies = { userLoginSerializer }) { - const userId = request.params.id; - const userLogin = await usecases.unblockUserAccount({ userId }); - return h.response(dependencies.userLoginSerializer.serialize(userLogin)).code(200); - }, - - async removeAuthenticationMethod(request, h) { - const userId = request.params.id; - const type = request.payload.data.attributes.type; - await usecases.removeAuthenticationMethod({ userId, type }); - return h.response().code(204); - }, - - async sendVerificationCode(request, h, dependencies = { emailVerificationSerializer, requestResponseUtils }) { - const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); - const i18n = request.i18n; - const userId = request.params.id; - const { newEmail, password } = await dependencies.emailVerificationSerializer.deserialize(request.payload); - - await usecases.sendVerificationCode({ i18n, locale, newEmail, password, userId }); - return h.response().code(204); - }, - - async updateUserEmailWithValidation(request, h, dependencies = { updateEmailSerializer }) { - const userId = request.params.id; - const code = request.payload.data.attributes.code; - - const updatedUserAttributes = await usecases.updateUserEmailWithValidation({ - userId, - code, - }); - - return dependencies.updateEmailSerializer.serialize(updatedUserAttributes); - }, - - async getUserAuthenticationMethods(request, h, dependencies = { authenticationMethodsSerializer }) { - const userId = request.params.id; - - const authenticationMethods = await usecases.findUserAuthenticationMethods({ userId }); - - return dependencies.authenticationMethodsSerializer.serialize(authenticationMethods); - }, - - async addPixAuthenticationMethodByEmail(request, h, dependencies = { userDetailsForAdminSerializer }) { - const userId = request.params.id; - const email = request.payload.data.attributes.email.trim().toLowerCase(); - - const userUpdated = await usecases.addPixAuthenticationMethodByEmail({ - userId, - email, - }); - return h.response(dependencies.userDetailsForAdminSerializer.serialize(userUpdated)).created(); - }, - - async reassignAuthenticationMethods(request, h) { - const authenticationMethodId = request.params.authenticationMethodId; - const originUserId = request.params.userId; - const targetUserId = request.payload.data.attributes['user-id']; - - await usecases.reassignAuthenticationMethodToAnotherUser({ - originUserId, - targetUserId, - authenticationMethodId, - }); - return h.response().code(204); - }, - - async findCampaignParticipationsForUserManagement( - request, - h, - dependencies = { campaignParticipationForUserManagementSerializer } - ) { - const userId = request.params.id; - const campaignParticipations = await usecases.findCampaignParticipationsForUserManagement({ - userId, - }); - return h.response(dependencies.campaignParticipationForUserManagementSerializer.serialize(campaignParticipations)); - }, - - async findUserOrganizationsForAdmin(request, h, dependencies = { userOrganizationForAdminSerializer }) { - const userId = request.params.id; - const organizations = await usecases.findUserOrganizationsForAdmin({ - userId, - }); - return h.response(dependencies.userOrganizationForAdminSerializer.serialize(organizations)); - }, - - async findCertificationCenterMembershipsByUser( - request, - h, - dependencies = { certificationCenterMembershipSerializer } - ) { - const userId = request.params.id; - const certificationCenterMemberships = await usecases.findCertificationCenterMembershipsByUser({ - userId, - }); - return h.response( - dependencies.certificationCenterMembershipSerializer.serializeForAdmin(certificationCenterMemberships) - ); - }, - - async rememberUserHasSeenLastDataProtectionPolicyInformation(request, h, dependencies = { userSerializer }) { - const authenticatedUserId = request.auth.credentials.userId; - - const updatedUser = await usecases.rememberUserHasSeenLastDataProtectionPolicyInformation({ - userId: authenticatedUserId, - }); - return dependencies.userSerializer.serialize(updatedUser); - }, +import * as campaignParticipationSerializer from '../../infrastructure/serializers/jsonapi/campaign-participation-serializer.js'; +import * as campaignParticipationOverviewSerializer from '../../infrastructure/serializers/jsonapi/campaign-participation-overview-serializer.js'; +import * as certificationEligibilitySerializer from '../../infrastructure/serializers/jsonapi/certification-eligibility-serializer.js'; +import * as scorecardSerializer from '../../infrastructure/serializers/jsonapi/scorecard-serializer.js'; +import * as profileSerializer from '../../infrastructure/serializers/jsonapi/profile-serializer.js'; +import * as participantResultSerializer from '../../infrastructure/serializers/jsonapi/participant-result-serializer.js'; +import * as sharedProfileForCampaignSerializer from '../../infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer.js'; +import * as userSerializer from '../../infrastructure/serializers/jsonapi/user-serializer.js'; +import * as userForAdminSerializer from '../../infrastructure/serializers/jsonapi/user-for-admin-serializer.js'; +import * as userWithActivitySerializer from '../../infrastructure/serializers/jsonapi/user-with-activity-serializer.js'; +import * as emailVerificationSerializer from '../../infrastructure/serializers/jsonapi/email-verification-serializer.js'; +import * as userDetailsForAdminSerializer from '../../infrastructure/serializers/jsonapi/user-details-for-admin-serializer.js'; +import * as userAnonymizedDetailsForAdminSerializer from '../../infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer.js'; +import * as updateEmailSerializer from '../../infrastructure/serializers/jsonapi/update-email-serializer.js'; +import * as authenticationMethodsSerializer from '../../infrastructure/serializers/jsonapi/authentication-methods-serializer.js'; +import * as campaignParticipationForUserManagementSerializer from '../../infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer.js'; +import * as userOrganizationForAdminSerializer from '../../infrastructure/serializers/jsonapi/user-organization-for-admin-serializer.js'; +import * as certificationCenterMembershipSerializer from '../../infrastructure/serializers/jsonapi/certification-center-membership-serializer.js'; +import * as trainingSerializer from '../../infrastructure/serializers/jsonapi/training-serializer.js'; +import * as userLoginSerializer from '../../infrastructure/serializers/jsonapi/user-login-serializer.js'; + +import * as queryParamsUtils from '../../infrastructure/utils/query-params-utils.js'; +import * as requestResponseUtils from '../../infrastructure/utils/request-response-utils.js'; +import { usecases } from '../../domain/usecases/index.js'; +import * as localeService from '../../domain/services/locale-service.js'; + +const save = async function (request, h, dependencies = { userSerializer, requestResponseUtils, localeService }) { + const localeFromCookie = request.state?.locale; + const canonicalLocaleFromCookie = localeFromCookie + ? dependencies.localeService.getCanonicalLocale(localeFromCookie) + : undefined; + const campaignCode = request.payload.meta ? request.payload.meta['campaign-code'] : null; + const user = { ...dependencies.userSerializer.deserialize(request.payload), locale: canonicalLocaleFromCookie }; + const localeFromHeader = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + + const password = request.payload.data.attributes.password; + + const savedUser = await usecases.createUser({ + user, + password, + campaignCode, + localeFromHeader, + }); + + return h.response(dependencies.userSerializer.serialize(savedUser)).created(); }; + +const getCurrentUser = function (request, h, dependencies = { userWithActivitySerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + return usecases.getCurrentUser({ authenticatedUserId }).then(dependencies.userWithActivitySerializer.serialize); +}; + +const getUserDetailsForAdmin = async function (request, h, dependencies = { userDetailsForAdminSerializer }) { + const userId = request.params.id; + const userDetailsForAdmin = await usecases.getUserDetailsForAdmin({ userId }); + return dependencies.userDetailsForAdminSerializer.serialize(userDetailsForAdmin); +}; + +const updatePassword = async function (request, h, dependencies = { userSerializer }) { + const userId = request.params.id; + const password = request.payload.data.attributes.password; + + const updatedUser = await usecases.updateUserPassword({ + userId, + password, + temporaryKey: request.query['temporary-key'] || '', + }); + + return dependencies.userSerializer.serialize(updatedUser); +}; + +const updateUserDetailsForAdministration = async function ( + request, + h, + dependencies = { userDetailsForAdminSerializer } +) { + const userId = request.params.id; + const userDetailsForAdministration = dependencies.userDetailsForAdminSerializer.deserialize(request.payload); + + const updatedUser = await usecases.updateUserDetailsForAdministration({ + userId, + userDetailsForAdministration, + }); + + return dependencies.userDetailsForAdminSerializer.serializeForUpdate(updatedUser); +}; + +const acceptPixLastTermsOfService = async function (request, h, dependencies = { userSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + + const updatedUser = await usecases.acceptPixLastTermsOfService({ + userId: authenticatedUserId, + }); + + return dependencies.userSerializer.serialize(updatedUser); +}; + +const changeLang = async function (request, h, dependencies = { userSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + const lang = request.params.lang; + const updatedUser = await usecases.changeUserLang({ + userId: authenticatedUserId, + lang, + }); + + return dependencies.userSerializer.serialize(updatedUser); +}; + +const acceptPixOrgaTermsOfService = async function (request, h, dependencies = { userSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + + const updatedUser = await usecases.acceptPixOrgaTermsOfService({ + userId: authenticatedUserId, + }); + + return dependencies.userSerializer.serialize(updatedUser); +}; + +const acceptPixCertifTermsOfService = async function (request, h) { + const authenticatedUserId = request.auth.credentials.userId; + + await usecases.acceptPixCertifTermsOfService({ + userId: authenticatedUserId, + }); + + return h.response().code(204); +}; + +const rememberUserHasSeenAssessmentInstructions = async function (request, h, dependencies = { userSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + + const updatedUser = await usecases.rememberUserHasSeenAssessmentInstructions({ userId: authenticatedUserId }); + return dependencies.userSerializer.serialize(updatedUser); +}; + +const rememberUserHasSeenNewDashboardInfo = async function (request, h, dependencies = { userSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + + const updatedUser = await usecases.rememberUserHasSeenNewDashboardInfo({ userId: authenticatedUserId }); + return dependencies.userSerializer.serialize(updatedUser); +}; + +const rememberUserHasSeenChallengeTooltip = async function (request, h, dependencies = { userSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + const challengeType = request.params.challengeType; + + const updatedUser = await usecases.rememberUserHasSeenChallengeTooltip({ + userId: authenticatedUserId, + challengeType, + }); + return dependencies.userSerializer.serialize(updatedUser); +}; + +const findPaginatedFilteredUsers = async function ( + request, + h, + dependencies = { userForAdminSerializer, queryParamsUtils } +) { + const options = dependencies.queryParamsUtils.extractParameters(request.query); + + const { models: users, pagination } = await usecases.findPaginatedFilteredUsers({ + filter: options.filter, + page: options.page, + }); + return dependencies.userForAdminSerializer.serialize(users, pagination); +}; + +const findPaginatedUserRecommendedTrainings = async function ( + request, + h, + dependencies = { + trainingSerializer, + requestResponseUtils, + queryParamsUtils, + } +) { + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const { page } = dependencies.queryParamsUtils.extractParameters(request.query); + const { userRecommendedTrainings, meta } = await usecases.findPaginatedUserRecommendedTrainings({ + userId: request.auth.credentials.userId, + locale, + page, + }); + + return dependencies.trainingSerializer.serialize(userRecommendedTrainings, meta); +}; + +const getCampaignParticipations = function (request, h, dependencies = { campaignParticipationSerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + + return usecases + .findLatestOngoingUserCampaignParticipations({ userId: authenticatedUserId }) + .then(dependencies.campaignParticipationSerializer.serialize); +}; + +const getCampaignParticipationOverviews = async function ( + request, + h, + dependencies = { + campaignParticipationOverviewSerializer, + queryParamsUtils, + } +) { + const authenticatedUserId = request.auth.credentials.userId; + const query = dependencies.queryParamsUtils.extractParameters(request.query); + + const userCampaignParticipationOverviews = await usecases.findUserCampaignParticipationOverviews({ + userId: authenticatedUserId, + states: query.filter.states, + page: query.page, + }); + + return dependencies.campaignParticipationOverviewSerializer.serializeForPaginatedList( + userCampaignParticipationOverviews + ); +}; + +const isCertifiable = async function (request, h, dependencies = { certificationEligibilitySerializer }) { + const authenticatedUserId = request.auth.credentials.userId; + + const certificationEligibility = await usecases.getUserCertificationEligibility({ userId: authenticatedUserId }); + return dependencies.certificationEligibilitySerializer.serialize(certificationEligibility); +}; + +const getProfile = function (request, h, dependencies = { profileSerializer, requestResponseUtils }) { + const authenticatedUserId = request.auth.credentials.userId; + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + + return usecases + .getUserProfile({ userId: authenticatedUserId, locale }) + .then(dependencies.profileSerializer.serialize); +}; + +const getProfileForAdmin = function (request, h, dependencies = { profileSerializer, requestResponseUtils }) { + const userId = request.params.id; + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + + return usecases.getUserProfile({ userId, locale }).then(dependencies.profileSerializer.serialize); +}; + +const resetScorecard = function (request, h, dependencies = { scorecardSerializer, requestResponseUtils }) { + const authenticatedUserId = request.auth.credentials.userId; + const competenceId = request.params.competenceId; + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + + return usecases + .resetScorecard({ userId: authenticatedUserId, competenceId, locale }) + .then(dependencies.scorecardSerializer.serialize); +}; + +const getUserCampaignParticipationToCampaign = function ( + request, + h, + dependencies = { campaignParticipationSerializer } +) { + const authenticatedUserId = request.auth.credentials.userId; + const campaignId = request.params.campaignId; + + return usecases + .getUserCampaignParticipationToCampaign({ userId: authenticatedUserId, campaignId }) + .then((campaignParticipation) => dependencies.campaignParticipationSerializer.serialize(campaignParticipation)); +}; + +const getUserProfileSharedForCampaign = async function ( + request, + h, + dependencies = { + sharedProfileForCampaignSerializer, + requestResponseUtils, + } +) { + const authenticatedUserId = request.auth.credentials.userId; + const campaignId = request.params.campaignId; + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + + const sharedProfileForCampaign = await usecases.getUserProfileSharedForCampaign({ + userId: authenticatedUserId, + campaignId, + locale, + }); + + return dependencies.sharedProfileForCampaignSerializer.serialize(sharedProfileForCampaign); +}; + +const getUserCampaignAssessmentResult = async function ( + request, + h, + dependencies = { + participantResultSerializer, + requestResponseUtils, + } +) { + const authenticatedUserId = request.auth.credentials.userId; + const campaignId = request.params.campaignId; + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + + const campaignAssessmentResult = await usecases.getUserCampaignAssessmentResult({ + userId: authenticatedUserId, + campaignId, + locale, + }); + + return dependencies.participantResultSerializer.serialize(campaignAssessmentResult); +}; + +const anonymizeUser = async function (request, h, dependencies = { userAnonymizedDetailsForAdminSerializer }) { + const userToAnonymizeId = request.params.id; + const adminMemberId = request.auth.credentials.userId; + const user = await usecases.anonymizeUser({ userId: userToAnonymizeId, updatedByUserId: adminMemberId }); + return h.response(dependencies.userAnonymizedDetailsForAdminSerializer.serialize(user)).code(200); +}; + +const unblockUserAccount = async function (request, h, dependencies = { userLoginSerializer }) { + const userId = request.params.id; + const userLogin = await usecases.unblockUserAccount({ userId }); + return h.response(dependencies.userLoginSerializer.serialize(userLogin)).code(200); +}; + +const removeAuthenticationMethod = async function (request, h) { + const userId = request.params.id; + const type = request.payload.data.attributes.type; + await usecases.removeAuthenticationMethod({ userId, type }); + return h.response().code(204); +}; + +const sendVerificationCode = async function ( + request, + h, + dependencies = { emailVerificationSerializer, requestResponseUtils } +) { + const locale = dependencies.requestResponseUtils.extractLocaleFromRequest(request); + const i18n = request.i18n; + const userId = request.params.id; + const { newEmail, password } = await dependencies.emailVerificationSerializer.deserialize(request.payload); + + await usecases.sendVerificationCode({ i18n, locale, newEmail, password, userId }); + return h.response().code(204); +}; + +const updateUserEmailWithValidation = async function (request, h, dependencies = { updateEmailSerializer }) { + const userId = request.params.id; + const code = request.payload.data.attributes.code; + + const updatedUserAttributes = await usecases.updateUserEmailWithValidation({ + userId, + code, + }); + + return dependencies.updateEmailSerializer.serialize(updatedUserAttributes); +}; + +const getUserAuthenticationMethods = async function (request, h, dependencies = { authenticationMethodsSerializer }) { + const userId = request.params.id; + + const authenticationMethods = await usecases.findUserAuthenticationMethods({ userId }); + + return dependencies.authenticationMethodsSerializer.serialize(authenticationMethods); +}; + +const addPixAuthenticationMethodByEmail = async function ( + request, + h, + dependencies = { userDetailsForAdminSerializer } +) { + const userId = request.params.id; + const email = request.payload.data.attributes.email.trim().toLowerCase(); + + const userUpdated = await usecases.addPixAuthenticationMethodByEmail({ + userId, + email, + }); + return h.response(dependencies.userDetailsForAdminSerializer.serialize(userUpdated)).created(); +}; + +const reassignAuthenticationMethods = async function (request, h) { + const authenticationMethodId = request.params.authenticationMethodId; + const originUserId = request.params.userId; + const targetUserId = request.payload.data.attributes['user-id']; + + await usecases.reassignAuthenticationMethodToAnotherUser({ + originUserId, + targetUserId, + authenticationMethodId, + }); + return h.response().code(204); +}; + +const findCampaignParticipationsForUserManagement = async function ( + request, + h, + dependencies = { campaignParticipationForUserManagementSerializer } +) { + const userId = request.params.id; + const campaignParticipations = await usecases.findCampaignParticipationsForUserManagement({ + userId, + }); + return h.response(dependencies.campaignParticipationForUserManagementSerializer.serialize(campaignParticipations)); +}; + +const findUserOrganizationsForAdmin = async function ( + request, + h, + dependencies = { userOrganizationForAdminSerializer } +) { + const userId = request.params.id; + const organizations = await usecases.findUserOrganizationsForAdmin({ + userId, + }); + return h.response(dependencies.userOrganizationForAdminSerializer.serialize(organizations)); +}; + +const findCertificationCenterMembershipsByUser = async function ( + request, + h, + dependencies = { certificationCenterMembershipSerializer } +) { + const userId = request.params.id; + const certificationCenterMemberships = await usecases.findCertificationCenterMembershipsByUser({ + userId, + }); + return h.response( + dependencies.certificationCenterMembershipSerializer.serializeForAdmin(certificationCenterMemberships) + ); +}; + +const rememberUserHasSeenLastDataProtectionPolicyInformation = async function ( + request, + h, + dependencies = { userSerializer } +) { + const authenticatedUserId = request.auth.credentials.userId; + + const updatedUser = await usecases.rememberUserHasSeenLastDataProtectionPolicyInformation({ + userId: authenticatedUserId, + }); + return dependencies.userSerializer.serialize(updatedUser); +}; + +const userController = { + save, + getCurrentUser, + getUserDetailsForAdmin, + updatePassword, + updateUserDetailsForAdministration, + acceptPixLastTermsOfService, + changeLang, + acceptPixOrgaTermsOfService, + acceptPixCertifTermsOfService, + rememberUserHasSeenAssessmentInstructions, + rememberUserHasSeenNewDashboardInfo, + rememberUserHasSeenChallengeTooltip, + findPaginatedFilteredUsers, + findPaginatedUserRecommendedTrainings, + getCampaignParticipations, + getCampaignParticipationOverviews, + isCertifiable, + getProfile, + getProfileForAdmin, + resetScorecard, + getUserCampaignParticipationToCampaign, + getUserProfileSharedForCampaign, + getUserCampaignAssessmentResult, + anonymizeUser, + unblockUserAccount, + removeAuthenticationMethod, + sendVerificationCode, + updateUserEmailWithValidation, + getUserAuthenticationMethods, + addPixAuthenticationMethodByEmail, + reassignAuthenticationMethods, + findCampaignParticipationsForUserManagement, + findUserOrganizationsForAdmin, + findCertificationCenterMembershipsByUser, + rememberUserHasSeenLastDataProtectionPolicyInformation, +}; + +export { userController }; diff --git a/api/lib/config.js b/api/lib/config.js index 83635849279..35410a6404a 100644 --- a/api/lib/config.js +++ b/api/lib/config.js @@ -1,9 +1,15 @@ -/* eslint-disable node/no-process-env*/ -const path = require('path'); -const moment = require('moment'); -const ms = require('ms'); +import * as dotenv from 'dotenv'; +dotenv.config(); +// eslint-disable-next-line eslint-comments/disable-enable-pair +/* eslint-disable node/no-process-env */ +import path from 'path'; +import moment from 'moment'; +import ms from 'ms'; -const { getArrayOfStrings } = require('../lib/infrastructure/utils/string-utils.js'); +import { getArrayOfStrings } from '../lib/infrastructure/utils/string-utils.js'; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); function parseJSONEnv(varName) { if (process.env[varName]) { @@ -453,5 +459,4 @@ const configuration = (function () { return config; })(); -module.exports = configuration; -/* eslint-enable node/no-process-env*/ +export { configuration as config }; diff --git a/api/lib/domain/constants.js b/api/lib/domain/constants.js index 05c2ce55694..c757bd094f3 100644 --- a/api/lib/domain/constants.js +++ b/api/lib/domain/constants.js @@ -1,17 +1,17 @@ -const settings = require('../config.js'); +import { config } from '../config.js'; const PIX_COUNT_BY_LEVEL = 8; const COMPETENCES_COUNT = 16; -const MAX_REACHABLE_PIX_BY_COMPETENCE = settings.features.maxReachableLevel * PIX_COUNT_BY_LEVEL; +const MAX_REACHABLE_PIX_BY_COMPETENCE = config.features.maxReachableLevel * PIX_COUNT_BY_LEVEL; -const MAX_REACHABLE_LEVEL = settings.features.maxReachableLevel; +const MAX_REACHABLE_LEVEL = config.features.maxReachableLevel; const MAX_REACHABLE_PIX_SCORE = MAX_REACHABLE_PIX_BY_COMPETENCE * COMPETENCES_COUNT; const MAX_CHALLENGES_PER_COMPETENCE_FOR_CERTIFICATION = 3; const MAX_CHALLENGES_PER_AREA_FOR_CERTIFICATION_PLUS = 4; const MAX_MASTERY_RATE = 1; -const MINIMUM_DELAY_IN_DAYS_FOR_RESET = settings.features.dayBeforeCompetenceResetV2; -const MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING = settings.features.dayBeforeImproving; -const MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING = settings.features.dayBeforeRetrying; +const MINIMUM_DELAY_IN_DAYS_FOR_RESET = config.features.dayBeforeCompetenceResetV2; +const MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING = config.features.dayBeforeImproving; +const MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING = config.features.dayBeforeRetrying; const MINIMUM_CERTIFIABLE_COMPETENCES_FOR_CERTIFIABILITY = 5; const MINIMUM_COMPETENCE_LEVEL_FOR_CERTIFIABILITY = 1; @@ -141,7 +141,7 @@ const constants = { ORGANIZATION_FEATURE, }; -module.exports = { +export { constants, PIX_COUNT_BY_LEVEL, COMPETENCES_COUNT, diff --git a/api/lib/domain/constants/certification-candidates-errors.js b/api/lib/domain/constants/certification-candidates-errors.js index 9a53660b34f..0ff0b4d7353 100644 --- a/api/lib/domain/constants/certification-candidates-errors.js +++ b/api/lib/domain/constants/certification-candidates-errors.js @@ -1,4 +1,4 @@ -module.exports.CERTIFICATION_CANDIDATES_ERRORS = { +const CERTIFICATION_CANDIDATES_ERRORS = { CANDIDATE_BILLING_MODE_MUST_BE_A_STRING: { code: 'CANDIDATE_BILLING_MODE_MUST_BE_A_STRING', getMessage: () => '', @@ -129,3 +129,5 @@ module.exports.CERTIFICATION_CANDIDATES_ERRORS = { getMessage: () => '', }, }; + +export { CERTIFICATION_CANDIDATES_ERRORS }; diff --git a/api/lib/domain/constants/oidc-identity-providers.js b/api/lib/domain/constants/oidc-identity-providers.js index 08fcc995ef3..e55c1d81cd6 100644 --- a/api/lib/domain/constants/oidc-identity-providers.js +++ b/api/lib/domain/constants/oidc-identity-providers.js @@ -1,6 +1,6 @@ -const PoleEmploiOidcAuthenticationService = require('../services/authentication/pole-emploi-oidc-authentication-service.js'); -const CnavOidcAuthenticationService = require('../services/authentication/cnav-oidc-authentication-service.js'); -const FwbOidcAuthenticationService = require('../services/authentication/fwb-oidc-authentication-service.js'); +import { PoleEmploiOidcAuthenticationService } from '../services/authentication/pole-emploi-oidc-authentication-service.js'; +import { CnavOidcAuthenticationService } from '../services/authentication/cnav-oidc-authentication-service.js'; +import { FwbOidcAuthenticationService } from '../services/authentication/fwb-oidc-authentication-service.js'; const DEFAULT_PROPERTY_PATHS_TO_PICK = ['clientId', 'authenticationUrl', 'userInfoUrl', 'tokenUrl', 'clientSecret']; @@ -20,8 +20,4 @@ const FWB = { service: new FwbOidcAuthenticationService(), }; -module.exports = { - POLE_EMPLOI, - CNAV, - FWB, -}; +export { POLE_EMPLOI, CNAV, FWB }; diff --git a/api/lib/domain/constants/organization-places-categories.js b/api/lib/domain/constants/organization-places-categories.js index d11a06e9804..e6a8a563a5a 100644 --- a/api/lib/domain/constants/organization-places-categories.js +++ b/api/lib/domain/constants/organization-places-categories.js @@ -1,14 +1,12 @@ -const organisationPlacesCategories = { - T0: 'T0', - T1: 'T1', - T2: 'T2', - T2bis: 'T2bis', - T3: 'T3', - FREE_RATE: 'FREE_RATE', - PUBLIC_RATE: 'PUBLIC_RATE', - REDUCE_RATE: 'REDUCE_RATE', - SPECIAL_REDUCE_RATE: 'SPECIAL_REDUCE_RATE', - FULL_RATE: 'FULL_RATE', -}; +const T0 = 'T0'; +const T1 = 'T1'; +const T2 = 'T2'; +const T2bis = 'T2bis'; +const T3 = 'T3'; +const FREE_RATE = 'FREE_RATE'; +const PUBLIC_RATE = 'PUBLIC_RATE'; +const REDUCE_RATE = 'REDUCE_RATE'; +const SPECIAL_REDUCE_RATE = 'SPECIAL_REDUCE_RATE'; +const FULL_RATE = 'FULL_RATE'; -module.exports = organisationPlacesCategories; +export { T0, T1, T2, T2bis, T3, FREE_RATE, PUBLIC_RATE, REDUCE_RATE, SPECIAL_REDUCE_RATE, FULL_RATE }; diff --git a/api/lib/domain/constants/saml-identity-providers.js b/api/lib/domain/constants/saml-identity-providers.js index 8c796e35361..f490bbc1359 100644 --- a/api/lib/domain/constants/saml-identity-providers.js +++ b/api/lib/domain/constants/saml-identity-providers.js @@ -4,6 +4,4 @@ const SamlIdentityProviders = { }, }; -module.exports = { - SamlIdentityProviders, -}; +export { SamlIdentityProviders }; diff --git a/api/lib/domain/constants/session-supervising.js b/api/lib/domain/constants/session-supervising.js index a054f944a70..21fe035345a 100644 --- a/api/lib/domain/constants/session-supervising.js +++ b/api/lib/domain/constants/session-supervising.js @@ -1,6 +1,8 @@ -module.exports.SESSION_SUPERVISING = { +const SESSION_SUPERVISING = { INCORRECT_DATA: { code: 'INCORRECT_DATA', getMessage: () => `Le numéro de session et/ou le mot de passe saisis sont incorrects.`, }, }; + +export { SESSION_SUPERVISING }; diff --git a/api/lib/domain/constants/sessions-errors.js b/api/lib/domain/constants/sessions-errors.js index 4abc8604d0d..fcfc634f207 100644 --- a/api/lib/domain/constants/sessions-errors.js +++ b/api/lib/domain/constants/sessions-errors.js @@ -1,4 +1,4 @@ -module.exports.CERTIFICATION_SESSIONS_ERRORS = { +const CERTIFICATION_SESSIONS_ERRORS = { INFORMATION_NOT_ALLOWED_WITH_SESSION_ID: { code: 'INFORMATION_NOT_ALLOWED_WITH_SESSION_ID', getMessage: () => `Merci de ne pas renseigner les informations de session`, @@ -60,3 +60,4 @@ module.exports.CERTIFICATION_SESSIONS_ERRORS = { getMessage: () => '', }, }; +export { CERTIFICATION_SESSIONS_ERRORS }; diff --git a/api/lib/domain/errors.js b/api/lib/domain/errors.js index db9c8550f6e..201b1c257d3 100644 --- a/api/lib/domain/errors.js +++ b/api/lib/domain/errors.js @@ -1,4 +1,4 @@ -const { SESSION_SUPERVISING } = require('./constants/session-supervising'); +import { SESSION_SUPERVISING } from './constants/session-supervising.js'; class DomainError extends Error { constructor(message, code, meta) { @@ -1319,7 +1319,7 @@ class InvalidStageError extends DomainError { } } -module.exports = { +export { LocaleFormatError, LocaleNotSupportedError, AccountRecoveryDemandNotCreatedError, diff --git a/api/lib/domain/events/AssessmentCompleted.js b/api/lib/domain/events/AssessmentCompleted.js index b27014241bf..d257be96e21 100644 --- a/api/lib/domain/events/AssessmentCompleted.js +++ b/api/lib/domain/events/AssessmentCompleted.js @@ -15,4 +15,4 @@ class AssessmentCompleted { } } -module.exports = AssessmentCompleted; +export { AssessmentCompleted }; diff --git a/api/lib/domain/events/AutoJuryDone.js b/api/lib/domain/events/AutoJuryDone.js index 724b1c931f3..8df960328d3 100644 --- a/api/lib/domain/events/AutoJuryDone.js +++ b/api/lib/domain/events/AutoJuryDone.js @@ -1,4 +1,4 @@ -module.exports = class AutoJuryDone { +class AutoJuryDone { constructor({ sessionId, finalizedAt, certificationCenterName, sessionDate, sessionTime, hasExaminerGlobalComment }) { this.sessionId = sessionId; this.finalizedAt = finalizedAt; @@ -7,4 +7,6 @@ module.exports = class AutoJuryDone { this.sessionTime = sessionTime; this.hasExaminerGlobalComment = hasExaminerGlobalComment; } -}; +} + +export { AutoJuryDone }; diff --git a/api/lib/domain/events/CampaignParticipationResultsShared.js b/api/lib/domain/events/CampaignParticipationResultsShared.js index 138ff377cb9..667eaa07b44 100644 --- a/api/lib/domain/events/CampaignParticipationResultsShared.js +++ b/api/lib/domain/events/CampaignParticipationResultsShared.js @@ -1,4 +1,4 @@ -const Event = require('./Event.js'); +import { Event } from './Event.js'; class CampaignParticipationResultsShared extends Event { constructor({ campaignParticipationId } = {}) { @@ -7,4 +7,4 @@ class CampaignParticipationResultsShared extends Event { } } -module.exports = CampaignParticipationResultsShared; +export { CampaignParticipationResultsShared }; diff --git a/api/lib/domain/events/CampaignParticipationStarted.js b/api/lib/domain/events/CampaignParticipationStarted.js index bc31a2860a9..0bdd41b9487 100644 --- a/api/lib/domain/events/CampaignParticipationStarted.js +++ b/api/lib/domain/events/CampaignParticipationStarted.js @@ -4,4 +4,4 @@ class CampaignParticipationStarted { } } -module.exports = CampaignParticipationStarted; +export { CampaignParticipationStarted }; diff --git a/api/lib/domain/events/CertificationJuryDone.js b/api/lib/domain/events/CertificationJuryDone.js index aa70a3667be..592973e1ff7 100644 --- a/api/lib/domain/events/CertificationJuryDone.js +++ b/api/lib/domain/events/CertificationJuryDone.js @@ -1,5 +1,7 @@ -module.exports = class CertificationJuryDone { +class CertificationJuryDone { constructor({ certificationCourseId }) { this.certificationCourseId = certificationCourseId; } -}; +} + +export { CertificationJuryDone }; diff --git a/api/lib/domain/events/CertificationRescoringCompleted.js b/api/lib/domain/events/CertificationRescoringCompleted.js index ca768ed2e4b..4af035f8a94 100644 --- a/api/lib/domain/events/CertificationRescoringCompleted.js +++ b/api/lib/domain/events/CertificationRescoringCompleted.js @@ -6,4 +6,4 @@ class CertificationRescoringCompleted { } } -module.exports = CertificationRescoringCompleted; +export { CertificationRescoringCompleted }; diff --git a/api/lib/domain/events/CertificationScoringCompleted.js b/api/lib/domain/events/CertificationScoringCompleted.js index 069b06cf9ec..9c4f2f4dea2 100644 --- a/api/lib/domain/events/CertificationScoringCompleted.js +++ b/api/lib/domain/events/CertificationScoringCompleted.js @@ -6,4 +6,4 @@ class CertificationScoringCompleted { } } -module.exports = CertificationScoringCompleted; +export { CertificationScoringCompleted }; diff --git a/api/lib/domain/events/ChallengeDeneutralized.js b/api/lib/domain/events/ChallengeDeneutralized.js index be424160665..c00f4f624c5 100644 --- a/api/lib/domain/events/ChallengeDeneutralized.js +++ b/api/lib/domain/events/ChallengeDeneutralized.js @@ -5,4 +5,4 @@ class ChallengeDeneutralized { } } -module.exports = ChallengeDeneutralized; +export { ChallengeDeneutralized }; diff --git a/api/lib/domain/events/ChallengeNeutralized.js b/api/lib/domain/events/ChallengeNeutralized.js index f4482fe40d1..4e082a87d9b 100644 --- a/api/lib/domain/events/ChallengeNeutralized.js +++ b/api/lib/domain/events/ChallengeNeutralized.js @@ -5,4 +5,4 @@ class ChallengeNeutralized { } } -module.exports = ChallengeNeutralized; +export { ChallengeNeutralized }; diff --git a/api/lib/domain/events/Event.js b/api/lib/domain/events/Event.js index 7b0167a85b3..197cf817403 100644 --- a/api/lib/domain/events/Event.js +++ b/api/lib/domain/events/Event.js @@ -7,4 +7,4 @@ class Event { } } -module.exports = Event; +export { Event }; diff --git a/api/lib/domain/events/SessionFinalized.js b/api/lib/domain/events/SessionFinalized.js index 4cd21182781..3cc2f41b207 100644 --- a/api/lib/domain/events/SessionFinalized.js +++ b/api/lib/domain/events/SessionFinalized.js @@ -1,4 +1,4 @@ -module.exports = class SessionFinalized { +class SessionFinalized { constructor({ sessionId, finalizedAt, hasExaminerGlobalComment, sessionDate, sessionTime, certificationCenterName }) { this.sessionId = sessionId; this.finalizedAt = finalizedAt; @@ -7,4 +7,6 @@ module.exports = class SessionFinalized { this.sessionTime = sessionTime; this.certificationCenterName = certificationCenterName; } -}; +} + +export { SessionFinalized }; diff --git a/api/lib/domain/events/UserAlreadyLinkedToCertificationCandidate.js b/api/lib/domain/events/UserAlreadyLinkedToCertificationCandidate.js index 34553b313e2..bb4a0c5e1e2 100644 --- a/api/lib/domain/events/UserAlreadyLinkedToCertificationCandidate.js +++ b/api/lib/domain/events/UserAlreadyLinkedToCertificationCandidate.js @@ -1 +1,2 @@ -module.exports = class UserAlreadyLinkedToCertificationCandidate {}; +class UserAlreadyLinkedToCertificationCandidate {} +export { UserAlreadyLinkedToCertificationCandidate }; diff --git a/api/lib/domain/events/UserLinkedToCertificationCandidate.js b/api/lib/domain/events/UserLinkedToCertificationCandidate.js index afdfc7062e6..943e0331246 100644 --- a/api/lib/domain/events/UserLinkedToCertificationCandidate.js +++ b/api/lib/domain/events/UserLinkedToCertificationCandidate.js @@ -1 +1,2 @@ -module.exports = class UserLinkedToCertificationCandidate {}; +class UserLinkedToCertificationCandidate {} +export { UserLinkedToCertificationCandidate }; diff --git a/api/lib/domain/events/check-event-types.js b/api/lib/domain/events/check-event-types.js index 379130b5fed..359acc5516e 100644 --- a/api/lib/domain/events/check-event-types.js +++ b/api/lib/domain/events/check-event-types.js @@ -1,13 +1,14 @@ -const _ = require('lodash'); -module.exports = { - checkEventTypes(receivedEvent, acceptedEventTypes) { - if ( - !_.some(acceptedEventTypes, (acceptedEventType) => { - return receivedEvent instanceof acceptedEventType; - }) - ) { - const acceptedEventNames = acceptedEventTypes.map((acceptedEventType) => acceptedEventType.name); - throw new Error(`event must be one of types ${acceptedEventNames.join(', ')}`); - } - }, +import _ from 'lodash'; + +const checkEventTypes = function (receivedEvent, acceptedEventTypes) { + if ( + !_.some(acceptedEventTypes, (acceptedEventType) => { + return receivedEvent instanceof acceptedEventType; + }) + ) { + const acceptedEventNames = acceptedEventTypes.map((acceptedEventType) => acceptedEventType.name); + throw new Error(`event must be one of types ${acceptedEventNames.join(', ')}`); + } }; + +export { checkEventTypes }; diff --git a/api/lib/domain/events/handle-auto-jury.js b/api/lib/domain/events/handle-auto-jury.js index 64e88aab334..e632fa375a1 100644 --- a/api/lib/domain/events/handle-auto-jury.js +++ b/api/lib/domain/events/handle-auto-jury.js @@ -1,12 +1,10 @@ -const { checkEventTypes } = require('./check-event-types.js'); -const SessionFinalized = require('./SessionFinalized.js'); -const CertificationIssueReportResolutionAttempt = require('../models/CertificationIssueReportResolutionAttempt.js'); -const AutoJuryDone = require('./AutoJuryDone.js'); -const CertificationJuryDone = require('./CertificationJuryDone.js'); -const bluebird = require('bluebird'); -const { - CertificationIssueReportResolutionStrategies, -} = require('../models/CertificationIssueReportResolutionStrategies.js'); +import { checkEventTypes } from './check-event-types.js'; +import { SessionFinalized } from './SessionFinalized.js'; +import { CertificationIssueReportResolutionAttempt } from '../models/CertificationIssueReportResolutionAttempt.js'; +import { AutoJuryDone } from './AutoJuryDone.js'; +import { CertificationJuryDone } from './CertificationJuryDone.js'; +import bluebird from 'bluebird'; +import { CertificationIssueReportResolutionStrategies } from '../models/CertificationIssueReportResolutionStrategies.js'; const eventTypes = [SessionFinalized]; @@ -129,4 +127,4 @@ async function _autoResolveCertificationIssueReport({ } handleAutoJury.eventTypes = eventTypes; -module.exports = handleAutoJury; +export { handleAutoJury }; diff --git a/api/lib/domain/events/handle-certification-rescoring.js b/api/lib/domain/events/handle-certification-rescoring.js index 49f1ac4b780..52bd21a8d58 100644 --- a/api/lib/domain/events/handle-certification-rescoring.js +++ b/api/lib/domain/events/handle-certification-rescoring.js @@ -1,13 +1,13 @@ -const AssessmentResult = require('../models/AssessmentResult.js'); -const CertificationResult = require('../models/CertificationResult.js'); -const CompetenceMark = require('../models/CompetenceMark.js'); -const CertificationRescoringCompleted = require('./CertificationRescoringCompleted.js'); -const bluebird = require('bluebird'); -const { CertificationComputeError } = require('../errors.js'); -const ChallengeNeutralized = require('./ChallengeNeutralized.js'); -const ChallengeDeneutralized = require('./ChallengeDeneutralized.js'); -const CertificationJuryDone = require('./CertificationJuryDone.js'); -const { checkEventTypes } = require('./check-event-types.js'); +import { AssessmentResult } from '../models/AssessmentResult.js'; +import { CertificationResult } from '../models/CertificationResult.js'; +import { CompetenceMark } from '../models/CompetenceMark.js'; +import { CertificationRescoringCompleted } from './CertificationRescoringCompleted.js'; +import bluebird from 'bluebird'; +import { CertificationComputeError } from '../errors.js'; +import { ChallengeNeutralized } from './ChallengeNeutralized.js'; +import { ChallengeDeneutralized } from './ChallengeDeneutralized.js'; +import { CertificationJuryDone } from './CertificationJuryDone.js'; +import { checkEventTypes } from './check-event-types.js'; const eventTypes = [ChallengeNeutralized, ChallengeDeneutralized, CertificationJuryDone]; @@ -157,4 +157,4 @@ function _getEmitterFromEvent(event) { } handleCertificationRescoring.eventTypes = eventTypes; -module.exports = handleCertificationRescoring; +export { handleCertificationRescoring }; diff --git a/api/lib/domain/events/handle-certification-scoring.js b/api/lib/domain/events/handle-certification-scoring.js index a76e182f58d..09e95119fbd 100644 --- a/api/lib/domain/events/handle-certification-scoring.js +++ b/api/lib/domain/events/handle-certification-scoring.js @@ -1,10 +1,10 @@ -const AssessmentResult = require('../models/AssessmentResult.js'); -const CertificationScoringCompleted = require('./CertificationScoringCompleted.js'); -const CompetenceMark = require('../models/CompetenceMark.js'); -const bluebird = require('bluebird'); -const { CertificationComputeError } = require('../errors.js'); -const AssessmentCompleted = require('./AssessmentCompleted.js'); -const { checkEventTypes } = require('./check-event-types.js'); +import { AssessmentResult } from '../models/AssessmentResult.js'; +import { CertificationScoringCompleted } from './CertificationScoringCompleted.js'; +import { CompetenceMark } from '../models/CompetenceMark.js'; +import bluebird from 'bluebird'; +import { CertificationComputeError } from '../errors.js'; +import { AssessmentCompleted } from './AssessmentCompleted.js'; +import { checkEventTypes } from './check-event-types.js'; const eventTypes = [AssessmentCompleted]; const EMITTER = 'PIX-ALGO'; @@ -135,4 +135,4 @@ async function _saveResultAfterCertificationComputeError({ return certificationCourseRepository.update(certificationCourse); } handleCertificationScoring.eventTypes = eventTypes; -module.exports = handleCertificationScoring; +export { handleCertificationScoring }; diff --git a/api/lib/domain/events/handle-complementary-certifications-scoring.js b/api/lib/domain/events/handle-complementary-certifications-scoring.js index a60834b2f65..ba5892d1db3 100644 --- a/api/lib/domain/events/handle-complementary-certifications-scoring.js +++ b/api/lib/domain/events/handle-complementary-certifications-scoring.js @@ -1,10 +1,10 @@ -const { checkEventTypes } = require('./check-event-types.js'); -const CertificationScoringCompleted = require('./CertificationScoringCompleted.js'); -const CertificationRescoringCompleted = require('./CertificationRescoringCompleted.js'); -const { ReproducibilityRate } = require('../models/ReproducibilityRate.js'); -const AnswerCollectionForScoring = require('../models/AnswerCollectionForScoring.js'); -const ComplementaryCertificationScoringWithComplementaryReferential = require('../models/ComplementaryCertificationScoringWithComplementaryReferential.js'); -const ComplementaryCertificationScoringWithoutComplementaryReferential = require('../models/ComplementaryCertificationScoringWithoutComplementaryReferential.js'); +import { checkEventTypes } from './check-event-types.js'; +import { CertificationScoringCompleted } from './CertificationScoringCompleted.js'; +import { CertificationRescoringCompleted } from './CertificationRescoringCompleted.js'; +import { ReproducibilityRate } from '../models/ReproducibilityRate.js'; +import { AnswerCollectionForScoring } from '../models/AnswerCollectionForScoring.js'; +import { ComplementaryCertificationScoringWithComplementaryReferential } from '../models/ComplementaryCertificationScoringWithComplementaryReferential.js'; +import { ComplementaryCertificationScoringWithoutComplementaryReferential } from '../models/ComplementaryCertificationScoringWithoutComplementaryReferential.js'; const eventTypes = [CertificationScoringCompleted, CertificationRescoringCompleted]; @@ -96,4 +96,4 @@ function _buildComplementaryCertificationScoringWithReferential( } handleComplementaryCertificationsScoring.eventTypes = eventTypes; -module.exports = handleComplementaryCertificationsScoring; +export { handleComplementaryCertificationsScoring }; diff --git a/api/lib/domain/events/handle-pole-emploi-participation-finished.js b/api/lib/domain/events/handle-pole-emploi-participation-finished.js index 1110c9c29e2..eea197c7581 100644 --- a/api/lib/domain/events/handle-pole-emploi-participation-finished.js +++ b/api/lib/domain/events/handle-pole-emploi-participation-finished.js @@ -1,7 +1,7 @@ -const { checkEventTypes } = require('./check-event-types.js'); -const PoleEmploiPayload = require('../../infrastructure/externals/pole-emploi/PoleEmploiPayload.js'); -const AssessmentCompleted = require('./AssessmentCompleted.js'); -const PoleEmploiSending = require('../models/PoleEmploiSending.js'); +import { checkEventTypes } from './check-event-types.js'; +import { PoleEmploiPayload } from '../../infrastructure/externals/pole-emploi/PoleEmploiPayload.js'; +import { AssessmentCompleted } from './AssessmentCompleted.js'; +import { PoleEmploiSending } from '../models/PoleEmploiSending.js'; const eventTypes = [AssessmentCompleted]; @@ -52,4 +52,4 @@ async function handlePoleEmploiParticipationFinished({ } handlePoleEmploiParticipationFinished.eventTypes = eventTypes; -module.exports = handlePoleEmploiParticipationFinished; +export { handlePoleEmploiParticipationFinished }; diff --git a/api/lib/domain/events/handle-pole-emploi-participation-started.js b/api/lib/domain/events/handle-pole-emploi-participation-started.js index 98c01a30962..cc5545a4021 100644 --- a/api/lib/domain/events/handle-pole-emploi-participation-started.js +++ b/api/lib/domain/events/handle-pole-emploi-participation-started.js @@ -1,7 +1,7 @@ -const { checkEventTypes } = require('./check-event-types.js'); -const CampaignParticipationStarted = require('./CampaignParticipationStarted.js'); -const PoleEmploiPayload = require('../../infrastructure/externals/pole-emploi/PoleEmploiPayload.js'); -const PoleEmploiSending = require('../models/PoleEmploiSending.js'); +import { checkEventTypes } from './check-event-types.js'; +import { CampaignParticipationStarted } from './CampaignParticipationStarted.js'; +import { PoleEmploiPayload } from '../../infrastructure/externals/pole-emploi/PoleEmploiPayload.js'; +import { PoleEmploiSending } from '../models/PoleEmploiSending.js'; const eventTypes = [CampaignParticipationStarted]; @@ -48,4 +48,4 @@ async function handlePoleEmploiParticipationStarted({ } handlePoleEmploiParticipationStarted.eventTypes = eventTypes; -module.exports = handlePoleEmploiParticipationStarted; +export { handlePoleEmploiParticipationStarted }; diff --git a/api/lib/domain/events/handle-session-finalized.js b/api/lib/domain/events/handle-session-finalized.js index 07a50db8eb1..3cb6c6aed28 100644 --- a/api/lib/domain/events/handle-session-finalized.js +++ b/api/lib/domain/events/handle-session-finalized.js @@ -1,6 +1,6 @@ -const FinalizedSession = require('../models/FinalizedSession.js'); -const { checkEventTypes } = require('./check-event-types.js'); -const AutoJuryDone = require('./AutoJuryDone.js'); +import { FinalizedSession } from '../models/FinalizedSession.js'; +import { checkEventTypes } from './check-event-types.js'; +import { AutoJuryDone } from './AutoJuryDone.js'; const eventTypes = [AutoJuryDone]; @@ -32,4 +32,4 @@ async function handleSessionFinalized({ } handleSessionFinalized.eventTypes = eventTypes; -module.exports = handleSessionFinalized; +export { handleSessionFinalized }; diff --git a/api/lib/domain/events/index.js b/api/lib/domain/events/index.js index 7ac6eddc92c..221c00147ee 100644 --- a/api/lib/domain/events/index.js +++ b/api/lib/domain/events/index.js @@ -1,45 +1,48 @@ -const { injectDefaults, injectDependencies } = require('../../infrastructure/utils/dependency-injection.js'); -const EventDispatcher = require('../../infrastructure/events/EventDispatcher.js'); -const EventDispatcherLogger = require('../../infrastructure/events/EventDispatcherLogger.js'); -const MonitoringTools = require('../../infrastructure/monitoring-tools.js'); -const settings = require('../../config.js'); -const _ = require('lodash'); -const { performance } = require('perf_hooks'); -const eventBusBuilder = require('../../infrastructure/events/EventBusBuilder.js'); +import { injectDefaults, injectDependencies } from '../../infrastructure/utils/dependency-injection.js'; +import { EventDispatcher } from '../../infrastructure/events/EventDispatcher.js'; +import { EventDispatcherLogger } from '../../infrastructure/events/EventDispatcherLogger.js'; +import { monitoringTools as MonitoringTools } from '../../infrastructure/monitoring-tools.js'; +import { config } from '../../config.js'; +import _ from 'lodash'; +import perf_hooks from 'perf_hooks'; -const assessmentRepository = require('../../infrastructure/repositories/assessment-repository.js'); -const assessmentResultRepository = require('../../infrastructure/repositories/assessment-result-repository.js'); -const badgeAcquisitionRepository = require('../../infrastructure/repositories/badge-acquisition-repository.js'); -const badgeRepository = require('../../infrastructure/repositories/badge-repository.js'); -const campaignRepository = require('../../infrastructure/repositories/campaign-repository.js'); -const campaignParticipationRepository = require('../../infrastructure/repositories/campaign-participation-repository.js'); -const campaignParticipationResultRepository = require('../../infrastructure/repositories/campaign-participation-result-repository.js'); -const certificationAssessmentRepository = require('../../infrastructure/repositories/certification-assessment-repository.js'); -const certificationCenterRepository = require('../../infrastructure/repositories/certification-center-repository.js'); -const certificationCourseRepository = require('../../infrastructure/repositories/certification-course-repository.js'); -const certificationIssueReportRepository = require('../../infrastructure/repositories/certification-issue-report-repository.js'); -const competenceMarkRepository = require('../../infrastructure/repositories/competence-mark-repository.js'); -const competenceRepository = require('../../infrastructure/repositories/competence-repository.js'); -const complementaryCertificationCourseRepository = require('../../infrastructure/repositories/complementary-certification-course-repository.js'); -const complementaryCertificationScoringCriteriaRepository = require('../../infrastructure/repositories/complementary-certification-scoring-criteria-repository.js'); -const knowledgeElementRepository = require('../../infrastructure/repositories/knowledge-element-repository.js'); -const organizationRepository = require('../../infrastructure/repositories/organization-repository.js'); -const poleEmploiSendingRepository = require('../../infrastructure/repositories/pole-emploi-sending-repository.js'); -const scoringCertificationService = require('../services/scoring/scoring-certification-service.js'); -const skillRepository = require('../../infrastructure/repositories/skill-repository.js'); -const supervisorAccessRepository = require('../../infrastructure/repositories/supervisor-access-repository.js'); -const targetProfileRepository = require('../../infrastructure/repositories/target-profile-repository.js'); -const userRepository = require('../../infrastructure/repositories/user-repository.js'); -const participantResultsSharedRepository = require('../../infrastructure/repositories/participant-results-shared-repository.js'); -const juryCertificationSummaryRepository = require('../../infrastructure/repositories/jury-certification-summary-repository.js'); -const finalizedSessionRepository = require('../../infrastructure/repositories/sessions/finalized-session-repository.js'); -const challengeRepository = require('../../infrastructure/repositories/challenge-repository.js'); -const logger = require('../../infrastructure/logger.js'); -const poleEmploiNotifier = require('../../infrastructure/externals/pole-emploi/pole-emploi-notifier.js'); -const disabledPoleEmploiNotifier = require('../../infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js'); +const { performance } = perf_hooks; + +import * as eventBusBuilder from '../../infrastructure/events/EventBusBuilder.js'; + +import * as assessmentRepository from '../../infrastructure/repositories/assessment-repository.js'; +import * as assessmentResultRepository from '../../infrastructure/repositories/assessment-result-repository.js'; +import * as badgeAcquisitionRepository from '../../infrastructure/repositories/badge-acquisition-repository.js'; +import * as badgeRepository from '../../infrastructure/repositories/badge-repository.js'; +import * as campaignRepository from '../../infrastructure/repositories/campaign-repository.js'; +import * as campaignParticipationRepository from '../../infrastructure/repositories/campaign-participation-repository.js'; +import * as campaignParticipationResultRepository from '../../infrastructure/repositories/campaign-participation-result-repository.js'; +import * as certificationAssessmentRepository from '../../infrastructure/repositories/certification-assessment-repository.js'; +import * as certificationCenterRepository from '../../infrastructure/repositories/certification-center-repository.js'; +import * as certificationCourseRepository from '../../infrastructure/repositories/certification-course-repository.js'; +import * as certificationIssueReportRepository from '../../infrastructure/repositories/certification-issue-report-repository.js'; +import * as competenceMarkRepository from '../../infrastructure/repositories/competence-mark-repository.js'; +import * as competenceRepository from '../../infrastructure/repositories/competence-repository.js'; +import * as complementaryCertificationCourseRepository from '../../infrastructure/repositories/complementary-certification-course-repository.js'; +import * as complementaryCertificationScoringCriteriaRepository from '../../infrastructure/repositories/complementary-certification-scoring-criteria-repository.js'; +import * as knowledgeElementRepository from '../../infrastructure/repositories/knowledge-element-repository.js'; +import * as organizationRepository from '../../infrastructure/repositories/organization-repository.js'; +import * as poleEmploiSendingRepository from '../../infrastructure/repositories/pole-emploi-sending-repository.js'; +import * as scoringCertificationService from '../services/scoring/scoring-certification-service.js'; +import * as skillRepository from '../../infrastructure/repositories/skill-repository.js'; +import * as supervisorAccessRepository from '../../infrastructure/repositories/supervisor-access-repository.js'; +import * as targetProfileRepository from '../../infrastructure/repositories/target-profile-repository.js'; +import * as userRepository from '../../infrastructure/repositories/user-repository.js'; +import { participantResultsSharedRepository } from '../../infrastructure/repositories/participant-results-shared-repository.js'; +import * as juryCertificationSummaryRepository from '../../infrastructure/repositories/jury-certification-summary-repository.js'; +import * as finalizedSessionRepository from '../../infrastructure/repositories/sessions/finalized-session-repository.js'; +import * as challengeRepository from '../../infrastructure/repositories/challenge-repository.js'; +import { logger } from '../../infrastructure/logger.js'; +import * as poleEmploiNotifier from '../../infrastructure/externals/pole-emploi/pole-emploi-notifier.js'; +import * as disabledPoleEmploiNotifier from '../../infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js'; function requirePoleEmploiNotifier() { - if (settings.poleEmploi.pushEnabled) { + if (config.poleEmploi.pushEnabled) { return poleEmploiNotifier; } else { return disabledPoleEmploiNotifier; @@ -78,17 +81,17 @@ const dependencies = { logger, }; -const dependency = require('../../infrastructure/repositories/partner-certification-scoring-repository.js'); +import * as dependency from '../../infrastructure/repositories/partner-certification-scoring-repository.js'; const partnerCertificationScoringRepository = injectDependencies(dependency, dependencies); dependencies.partnerCertificationScoringRepository = partnerCertificationScoringRepository; -const handleAutoJury = require('./handle-auto-jury.js'); -const handleCertificationScoring = require('./handle-certification-scoring.js'); -const handleCertificationRescoring = require('./handle-certification-rescoring.js'); -const handleComplementaryCertificationsScoring = require('./handle-complementary-certifications-scoring.js'); -const handlePoleEmploiParticipationFinished = require('./handle-pole-emploi-participation-finished.js'); -const handlePoleEmploiParticipationStarted = require('./handle-pole-emploi-participation-started.js'); -const handleSessionFinalized = require('./handle-session-finalized.js'); +import { handleAutoJury } from './handle-auto-jury.js'; +import { handleCertificationScoring } from './handle-certification-scoring.js'; +import { handleCertificationRescoring } from './handle-certification-rescoring.js'; +import { handleComplementaryCertificationsScoring } from './handle-complementary-certifications-scoring.js'; +import { handlePoleEmploiParticipationFinished } from './handle-pole-emploi-participation-finished.js'; +import { handlePoleEmploiParticipationStarted } from './handle-pole-emploi-participation-started.js'; +import { handleSessionFinalized } from './handle-session-finalized.js'; const handlersToBeInjected = { handleAutoJury, @@ -101,7 +104,7 @@ const handlersToBeInjected = { }; function buildEventDispatcher(handlersStubs) { - const eventDispatcher = new EventDispatcher(new EventDispatcherLogger(MonitoringTools, settings, performance)); + const eventDispatcher = new EventDispatcher(new EventDispatcherLogger(MonitoringTools, config, performance)); const handlersNames = _.map(handlersToBeInjected, (handler) => handler.name); @@ -134,8 +137,4 @@ const _forTestOnly = { }, }; -module.exports = { - eventDispatcher, - eventBus, - _forTestOnly, -}; +export { eventDispatcher, eventBus, _forTestOnly }; diff --git a/api/lib/domain/models/AccountRecoveryDemand.js b/api/lib/domain/models/AccountRecoveryDemand.js index 20aab5d3417..0ff483af371 100644 --- a/api/lib/domain/models/AccountRecoveryDemand.js +++ b/api/lib/domain/models/AccountRecoveryDemand.js @@ -11,4 +11,4 @@ class AccountRecoveryDemand { } } -module.exports = AccountRecoveryDemand; +export { AccountRecoveryDemand }; diff --git a/api/lib/domain/models/AdminMember.js b/api/lib/domain/models/AdminMember.js index d3932d169d7..c7c0e452651 100644 --- a/api/lib/domain/models/AdminMember.js +++ b/api/lib/domain/models/AdminMember.js @@ -1,11 +1,14 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { validateEntity } = require('../validators/entity-validator.js'); -const isNil = require('lodash/isNil'); -const { ROLES } = require('../constants.js').PIX_ADMIN; +import { validateEntity } from '../validators/entity-validator.js'; +import lodash from 'lodash'; +const { isNil } = lodash; +import { PIX_ADMIN } from '../constants.js'; -module.exports = class AdminMember { +const { ROLES } = PIX_ADMIN; + +class AdminMember { constructor({ id, userId, firstName, lastName, email, role, createdAt, updatedAt, disabledAt }) { this.id = id; this.userId = userId; @@ -52,4 +55,6 @@ module.exports = class AdminMember { get isSupport() { return this.role === ROLES.SUPPORT && isNil(this.disabledAt); } -}; +} + +export { AdminMember }; diff --git a/api/lib/domain/models/Answer.js b/api/lib/domain/models/Answer.js index af222adc010..aa468a832e4 100644 --- a/api/lib/domain/models/Answer.js +++ b/api/lib/domain/models/Answer.js @@ -1,5 +1,5 @@ -const AnswerStatus = require('./AnswerStatus.js'); -const _ = require('lodash'); +import { AnswerStatus } from './AnswerStatus.js'; +import _ from 'lodash'; class Answer { constructor({ @@ -68,4 +68,4 @@ class Answer { // and transform it to an AnswerStatus "aband" in the api Answer.FAKE_VALUE_FOR_SKIPPED_QUESTIONS = '#ABAND#'; -module.exports = Answer; +export { Answer }; diff --git a/api/lib/domain/models/AnswerCollectionForScoring.js b/api/lib/domain/models/AnswerCollectionForScoring.js index 1a55be21443..3ec135b4304 100644 --- a/api/lib/domain/models/AnswerCollectionForScoring.js +++ b/api/lib/domain/models/AnswerCollectionForScoring.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); +import _ from 'lodash'; const qrocmDepChallenge = 'QROCM-dep'; -module.exports = class AnswerCollectionForScoring { +class AnswerCollectionForScoring { constructor(challengesWithAnswers) { this.challengesWithAnswers = challengesWithAnswers; } @@ -96,7 +96,9 @@ module.exports = class AnswerCollectionForScoring { }) .sum(); } -}; +} + +export { AnswerCollectionForScoring }; class ChallengeWithAnswer { constructor(answer, challenge) { diff --git a/api/lib/domain/models/AnswerStatus.js b/api/lib/domain/models/AnswerStatus.js index d7d4fcad8cd..bc1fe5708eb 100644 --- a/api/lib/domain/models/AnswerStatus.js +++ b/api/lib/domain/models/AnswerStatus.js @@ -92,4 +92,4 @@ class AnswerStatus { } } -module.exports = AnswerStatus; +export { AnswerStatus }; diff --git a/api/lib/domain/models/Area.js b/api/lib/domain/models/Area.js index 972c4e67064..0404e10a8ef 100644 --- a/api/lib/domain/models/Area.js +++ b/api/lib/domain/models/Area.js @@ -10,4 +10,4 @@ class Area { } } -module.exports = Area; +export { Area }; diff --git a/api/lib/domain/models/Assessment.js b/api/lib/domain/models/Assessment.js index c08e203caaa..32424b27f85 100644 --- a/api/lib/domain/models/Assessment.js +++ b/api/lib/domain/models/Assessment.js @@ -1,5 +1,5 @@ -const { ObjectValidationError } = require('../errors.js'); -const Answer = require('./Answer.js'); +import { ObjectValidationError } from '../errors.js'; +import { Answer } from './Answer.js'; const courseIdMessage = { COMPETENCE_EVALUATION: '[NOT USED] CompetenceId is in Competence Evaluation.', @@ -216,4 +216,4 @@ Assessment.types = types; Assessment.statesOfLastQuestion = statesOfLastQuestion; Assessment.methods = methods; -module.exports = Assessment; +export { Assessment }; diff --git a/api/lib/domain/models/AssessmentResult.js b/api/lib/domain/models/AssessmentResult.js index f3d2de2740d..7d42cc92bf4 100644 --- a/api/lib/domain/models/AssessmentResult.js +++ b/api/lib/domain/models/AssessmentResult.js @@ -1,4 +1,4 @@ -const Assessment = require('./Assessment.js'); +import { Assessment } from './Assessment.js'; const status = { REJECTED: 'rejected', @@ -95,4 +95,4 @@ class AssessmentResult { } AssessmentResult.status = status; -module.exports = AssessmentResult; +export { AssessmentResult, status }; diff --git a/api/lib/domain/models/Authentication.js b/api/lib/domain/models/Authentication.js index 8618e822274..a76de344091 100644 --- a/api/lib/domain/models/Authentication.js +++ b/api/lib/domain/models/Authentication.js @@ -12,4 +12,4 @@ class Authentication { } } -module.exports = Authentication; +export { Authentication }; diff --git a/api/lib/domain/models/AuthenticationMethod.js b/api/lib/domain/models/AuthenticationMethod.js index b6555e03693..8300156a523 100644 --- a/api/lib/domain/models/AuthenticationMethod.js +++ b/api/lib/domain/models/AuthenticationMethod.js @@ -1,7 +1,7 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { validateEntity } = require('../validators/entity-validator.js'); +import { validateEntity } from '../validators/entity-validator.js'; const identityProviders = { PIX: 'PIX', @@ -118,4 +118,4 @@ AuthenticationMethod.identityProviders = identityProviders; AuthenticationMethod.PixAuthenticationComplement = PixAuthenticationComplement; AuthenticationMethod.OidcAuthenticationComplement = OidcAuthenticationComplement; AuthenticationMethod.GARAuthenticationComplement = GARAuthenticationComplement; -module.exports = AuthenticationMethod; +export { AuthenticationMethod }; diff --git a/api/lib/domain/models/AuthenticationSessionContent.js b/api/lib/domain/models/AuthenticationSessionContent.js index 80fc4851927..9ed425f8961 100644 --- a/api/lib/domain/models/AuthenticationSessionContent.js +++ b/api/lib/domain/models/AuthenticationSessionContent.js @@ -7,4 +7,4 @@ class AuthenticationSessionContent { } } -module.exports = AuthenticationSessionContent; +export { AuthenticationSessionContent }; diff --git a/api/lib/domain/models/Badge.js b/api/lib/domain/models/Badge.js index e7f8e73fca4..76e0e07870c 100644 --- a/api/lib/domain/models/Badge.js +++ b/api/lib/domain/models/Badge.js @@ -28,4 +28,4 @@ class Badge { } } -module.exports = Badge; +export { Badge }; diff --git a/api/lib/domain/models/BadgeAcquisition.js b/api/lib/domain/models/BadgeAcquisition.js index 40a86d74662..c69532b71b0 100644 --- a/api/lib/domain/models/BadgeAcquisition.js +++ b/api/lib/domain/models/BadgeAcquisition.js @@ -12,4 +12,4 @@ class BadgeAcquisition { } } -module.exports = BadgeAcquisition; +export { BadgeAcquisition }; diff --git a/api/lib/domain/models/BadgeCriterion.js b/api/lib/domain/models/BadgeCriterion.js index 6e69c1176dc..6d416d74e80 100644 --- a/api/lib/domain/models/BadgeCriterion.js +++ b/api/lib/domain/models/BadgeCriterion.js @@ -8,10 +8,12 @@ class BadgeCriterion { } } -BadgeCriterion.SCOPES = { +const SCOPES = { CAMPAIGN_PARTICIPATION: 'CampaignParticipation', SKILL_SET: 'SkillSet', CAPPED_TUBES: 'CappedTubes', }; -module.exports = BadgeCriterion; +BadgeCriterion.SCOPES = SCOPES; + +export { BadgeCriterion, SCOPES }; diff --git a/api/lib/domain/models/BadgeDetails.js b/api/lib/domain/models/BadgeDetails.js index 727ce2d2c74..1bf29962500 100644 --- a/api/lib/domain/models/BadgeDetails.js +++ b/api/lib/domain/models/BadgeDetails.js @@ -1,4 +1,4 @@ -const { SCOPES } = require('./BadgeCriterion.js'); +import { SCOPES } from './BadgeCriterion.js'; class BadgeDetails { constructor({ id, key, altMessage, imageUrl, message, title, isCertifiable, isAlwaysVisible, criteria }) { @@ -70,4 +70,4 @@ BadgeCriterion.SCOPES = { CAPPED_TUBES: 'CappedTubes', }; -module.exports = { BadgeDetails, BadgeCriterion, SkillSet, CappedTube, SCOPES }; +export { BadgeDetails, BadgeCriterion, SkillSet, CappedTube, SCOPES }; diff --git a/api/lib/domain/models/BadgeForCalculation.js b/api/lib/domain/models/BadgeForCalculation.js index 57f994d327b..88108ed61b5 100644 --- a/api/lib/domain/models/BadgeForCalculation.js +++ b/api/lib/domain/models/BadgeForCalculation.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; class BadgeForCalculation { constructor({ id, badgeCriteria }) { @@ -37,7 +37,4 @@ function _computeMasteryPercentage(validatedSkillsCount, totalSkillsCount) { return Math.round((validatedSkillsCount * 100) / totalSkillsCount); } -module.exports = { - BadgeForCalculation, - BadgeCriterion, -}; +export { BadgeForCalculation, BadgeCriterion }; diff --git a/api/lib/domain/models/Campaign.js b/api/lib/domain/models/Campaign.js index 7f973289f32..dd18e4cd32e 100644 --- a/api/lib/domain/models/Campaign.js +++ b/api/lib/domain/models/Campaign.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const CampaignTypes = require('./CampaignTypes.js'); +import _ from 'lodash'; +import { CampaignTypes } from './CampaignTypes.js'; class Campaign { constructor({ @@ -71,4 +71,4 @@ class Campaign { } } -module.exports = Campaign; +export { Campaign }; diff --git a/api/lib/domain/models/CampaignCreator.js b/api/lib/domain/models/CampaignCreator.js index 628ae71f0a2..23f62174af4 100644 --- a/api/lib/domain/models/CampaignCreator.js +++ b/api/lib/domain/models/CampaignCreator.js @@ -1,6 +1,6 @@ -const CampaignForCreation = require('./CampaignForCreation.js'); -const CampaignTypes = require('./CampaignTypes.js'); -const { UserNotAuthorizedToCreateCampaignError } = require('../errors.js'); +import { CampaignForCreation } from './CampaignForCreation.js'; +import { CampaignTypes } from './CampaignTypes.js'; +import { UserNotAuthorizedToCreateCampaignError } from '../errors.js'; class CampaignCreator { constructor(availableTargetProfileIds) { @@ -26,4 +26,4 @@ function _checkAssessmentCampaignCreationAllowed(targetProfileId, availableTarge } } -module.exports = CampaignCreator; +export { CampaignCreator }; diff --git a/api/lib/domain/models/CampaignForArchiving.js b/api/lib/domain/models/CampaignForArchiving.js index ab4bbec00b9..46db62ee362 100644 --- a/api/lib/domain/models/CampaignForArchiving.js +++ b/api/lib/domain/models/CampaignForArchiving.js @@ -1,4 +1,4 @@ -const { ArchivedCampaignError, ObjectValidationError } = require('../errors.js'); +import { ArchivedCampaignError, ObjectValidationError } from '../errors.js'; class CampaignForArchiving { constructor({ id, code, archivedAt, archivedBy } = {}) { @@ -29,4 +29,4 @@ class CampaignForArchiving { } } -module.exports = CampaignForArchiving; +export { CampaignForArchiving }; diff --git a/api/lib/domain/models/CampaignForCreation.js b/api/lib/domain/models/CampaignForCreation.js index b3e84cede72..d16d92bd5bd 100644 --- a/api/lib/domain/models/CampaignForCreation.js +++ b/api/lib/domain/models/CampaignForCreation.js @@ -1,4 +1,4 @@ -const validate = require('../validators/campaign-creation-validator.js'); +import { validate } from '../validators/campaign-creation-validator.js'; class CampaignForCreation { constructor({ name, @@ -28,4 +28,4 @@ class CampaignForCreation { } } -module.exports = CampaignForCreation; +export { CampaignForCreation }; diff --git a/api/lib/domain/models/CampaignLearningContent.js b/api/lib/domain/models/CampaignLearningContent.js index cc865aa08d2..aa25207aebb 100644 --- a/api/lib/domain/models/CampaignLearningContent.js +++ b/api/lib/domain/models/CampaignLearningContent.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); +import _ from 'lodash'; -module.exports = class CampaignLearningContent { +class CampaignLearningContent { constructor(learningContent) { this._learningContent = learningContent; } @@ -120,4 +120,6 @@ module.exports = class CampaignLearningContent { const area = this.findArea(competence.areaId); return area || null; } -}; +} + +export { CampaignLearningContent }; diff --git a/api/lib/domain/models/CampaignParticipant.js b/api/lib/domain/models/CampaignParticipant.js index 8b2da34187c..0de9154e162 100644 --- a/api/lib/domain/models/CampaignParticipant.js +++ b/api/lib/domain/models/CampaignParticipant.js @@ -1,7 +1,8 @@ -const { EntityValidationError, ForbiddenAccess, AlreadyExistingCampaignParticipationError } = require('../errors.js'); -const CampaignParticipation = require('./CampaignParticipation.js'); -const Assessment = require('./Assessment.js'); -const OrganizationLearner = require('./OrganizationLearner.js'); +import { EntityValidationError, ForbiddenAccess, AlreadyExistingCampaignParticipationError } from '../errors.js'; + +import { CampaignParticipation } from './CampaignParticipation.js'; +import { Assessment } from './Assessment.js'; +import { OrganizationLearner } from './OrganizationLearner.js'; const couldNotJoinCampaignErrorMessage = "Vous n'êtes pas autorisé à rejoindre la campagne"; const couldNotImproveCampaignErrorMessage = 'Vous ne pouvez pas repasser la campagne'; @@ -118,4 +119,4 @@ class CampaignParticipant { } } -module.exports = CampaignParticipant; +export { CampaignParticipant }; diff --git a/api/lib/domain/models/CampaignParticipation.js b/api/lib/domain/models/CampaignParticipation.js index 40463ef433b..458876490e8 100644 --- a/api/lib/domain/models/CampaignParticipation.js +++ b/api/lib/domain/models/CampaignParticipation.js @@ -1,12 +1,14 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { ArchivedCampaignError, AssessmentNotCompletedError, AlreadySharedCampaignParticipationError, CantImproveCampaignParticipationError, CampaignParticipationDeletedError, -} = require('../errors.js'); -const CampaignParticipationStatuses = require('./CampaignParticipationStatuses.js'); +} from '../errors.js'; + +import { CampaignParticipationStatuses } from './CampaignParticipationStatuses.js'; class CampaignParticipation { constructor({ @@ -116,4 +118,4 @@ function lastAssessmentNotCompleted(campaignParticipation) { return !campaignParticipation.lastAssessment || !campaignParticipation.lastAssessment.isCompleted(); } -module.exports = CampaignParticipation; +export { CampaignParticipation }; diff --git a/api/lib/domain/models/CampaignParticipationBadge.js b/api/lib/domain/models/CampaignParticipationBadge.js index fd5d0a7189d..75ea03a8fcf 100644 --- a/api/lib/domain/models/CampaignParticipationBadge.js +++ b/api/lib/domain/models/CampaignParticipationBadge.js @@ -1,4 +1,4 @@ -const Badge = require('./Badge.js'); +import { Badge } from './Badge.js'; class CampaignParticipationBadge extends Badge { constructor({ @@ -40,4 +40,4 @@ class CampaignParticipationBadge extends Badge { } } -module.exports = CampaignParticipationBadge; +export { CampaignParticipationBadge }; diff --git a/api/lib/domain/models/CampaignParticipationResult.js b/api/lib/domain/models/CampaignParticipationResult.js index 33c08a9f68b..1f9fcca1d38 100644 --- a/api/lib/domain/models/CampaignParticipationResult.js +++ b/api/lib/domain/models/CampaignParticipationResult.js @@ -1,7 +1,7 @@ -const campaignParticipationService = require('../services/campaign-participation-service.js'); -const CompetenceResult = require('./CompetenceResult.js'); +import * as campaignParticipationService from '../services/campaign-participation-service.js'; +import { CompetenceResult } from './CompetenceResult.js'; -const _ = require('lodash'); +import _ from 'lodash'; class CampaignParticipationResult { constructor({ @@ -117,4 +117,4 @@ function _getTestedCompetenceResults(competence, area, targetedKnowledgeElements }); } -module.exports = CampaignParticipationResult; +export { CampaignParticipationResult }; diff --git a/api/lib/domain/models/CampaignParticipationStatuses.js b/api/lib/domain/models/CampaignParticipationStatuses.js index 70c64167b4f..02fb6fe2c0c 100644 --- a/api/lib/domain/models/CampaignParticipationStatuses.js +++ b/api/lib/domain/models/CampaignParticipationStatuses.js @@ -4,4 +4,4 @@ const CampaignParticipationStatuses = { SHARED: 'SHARED', }; -module.exports = CampaignParticipationStatuses; +export { CampaignParticipationStatuses }; diff --git a/api/lib/domain/models/CampaignToStartParticipation.js b/api/lib/domain/models/CampaignToStartParticipation.js index a102ab53248..26fe026ab8e 100644 --- a/api/lib/domain/models/CampaignToStartParticipation.js +++ b/api/lib/domain/models/CampaignToStartParticipation.js @@ -1,4 +1,4 @@ -const CampaignTypes = require('../models/CampaignTypes.js'); +import { CampaignTypes } from '../models/CampaignTypes.js'; class CampaignToStartParticipation { constructor({ @@ -32,4 +32,4 @@ class CampaignToStartParticipation { } } -module.exports = CampaignToStartParticipation; +export { CampaignToStartParticipation }; diff --git a/api/lib/domain/models/CampaignTypes.js b/api/lib/domain/models/CampaignTypes.js index d757fe1aa86..fc4db246654 100644 --- a/api/lib/domain/models/CampaignTypes.js +++ b/api/lib/domain/models/CampaignTypes.js @@ -3,4 +3,4 @@ const CampaignTypes = { PROFILES_COLLECTION: 'PROFILES_COLLECTION', }; -module.exports = CampaignTypes; +export { CampaignTypes }; diff --git a/api/lib/domain/models/CertifiableBadgeAcquisition.js b/api/lib/domain/models/CertifiableBadgeAcquisition.js index 153d12656e4..09b90ec4752 100644 --- a/api/lib/domain/models/CertifiableBadgeAcquisition.js +++ b/api/lib/domain/models/CertifiableBadgeAcquisition.js @@ -20,4 +20,4 @@ class CertifiableBadgeAcquisition { } } -module.exports = CertifiableBadgeAcquisition; +export { CertifiableBadgeAcquisition }; diff --git a/api/lib/domain/models/CertifiableProfileForLearningContent.js b/api/lib/domain/models/CertifiableProfileForLearningContent.js index ff901a84074..a386ce52d10 100644 --- a/api/lib/domain/models/CertifiableProfileForLearningContent.js +++ b/api/lib/domain/models/CertifiableProfileForLearningContent.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const KnowledgeElement = require('./KnowledgeElement.js'); +import _ from 'lodash'; +import { KnowledgeElement } from './KnowledgeElement.js'; class CertifiableProfileForLearningContent { constructor({ learningContent, knowledgeElements, answerAndChallengeIdsByAnswerId }) { @@ -144,4 +144,4 @@ class ResultByArea { } } -module.exports = CertifiableProfileForLearningContent; +export { CertifiableProfileForLearningContent }; diff --git a/api/lib/domain/models/CertificationAnswerStatusChangeAttempt.js b/api/lib/domain/models/CertificationAnswerStatusChangeAttempt.js index f4f9d14b034..3e4ca9af10b 100644 --- a/api/lib/domain/models/CertificationAnswerStatusChangeAttempt.js +++ b/api/lib/domain/models/CertificationAnswerStatusChangeAttempt.js @@ -1,4 +1,4 @@ -module.exports = class CertificationAnswerStatusChangeAttempt { +class CertificationAnswerStatusChangeAttempt { constructor(questionNumber, status) { this.questionNumber = questionNumber; this.status = status; @@ -27,7 +27,9 @@ module.exports = class CertificationAnswerStatusChangeAttempt { wasSkipped() { return this.status === CertificationAnswerStatusChangeStatus.SKIPPED; } -}; +} + +export { CertificationAnswerStatusChangeAttempt }; const CertificationAnswerStatusChangeStatus = { CHANGED: 'CHANGED', diff --git a/api/lib/domain/models/CertificationAssessment.js b/api/lib/domain/models/CertificationAssessment.js index 481ebef2cf1..733dafac827 100644 --- a/api/lib/domain/models/CertificationAssessment.js +++ b/api/lib/domain/models/CertificationAssessment.js @@ -1,12 +1,14 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { validateEntity } = require('../validators/entity-validator.js'); -const _ = require('lodash'); -const { ChallengeToBeNeutralizedNotFoundError, ChallengeToBeDeneutralizedNotFoundError } = require('../errors.js'); -const AnswerStatus = require('./AnswerStatus.js'); -const NeutralizationAttempt = require('./NeutralizationAttempt.js'); -const CertificationAnswerStatusChangeAttempt = require('./CertificationAnswerStatusChangeAttempt.js'); +import { validateEntity } from '../validators/entity-validator.js'; +import _ from 'lodash'; + +import { ChallengeToBeNeutralizedNotFoundError, ChallengeToBeDeneutralizedNotFoundError } from '../errors.js'; + +import { AnswerStatus } from './AnswerStatus.js'; +import { NeutralizationAttempt } from './NeutralizationAttempt.js'; +import { CertificationAnswerStatusChangeAttempt } from './CertificationAnswerStatusChangeAttempt.js'; const states = { COMPLETED: 'completed', @@ -169,4 +171,4 @@ function _isAnswerKoOrSkippedOrPartially(answerStatus) { CertificationAssessment.states = states; -module.exports = CertificationAssessment; +export { CertificationAssessment, states }; diff --git a/api/lib/domain/models/CertificationAssessmentScore.js b/api/lib/domain/models/CertificationAssessmentScore.js index 09e0dda337e..2a39b958432 100644 --- a/api/lib/domain/models/CertificationAssessmentScore.js +++ b/api/lib/domain/models/CertificationAssessmentScore.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const { status } = require('./AssessmentResult.js'); +import _ from 'lodash'; +import { status } from './AssessmentResult.js'; class CertificationAssessmentScore { constructor({ @@ -35,5 +35,6 @@ class CertificationAssessmentScore { } } -module.exports = CertificationAssessmentScore; -module.exports.statuses = status; +CertificationAssessmentScore.statuses = status; + +export { CertificationAssessmentScore, status as statuses }; diff --git a/api/lib/domain/models/CertificationAttestation.js b/api/lib/domain/models/CertificationAttestation.js index e3d22efdd47..43686be3dbd 100644 --- a/api/lib/domain/models/CertificationAttestation.js +++ b/api/lib/domain/models/CertificationAttestation.js @@ -46,4 +46,4 @@ class CertificationAttestation { } } -module.exports = CertificationAttestation; +export { CertificationAttestation }; diff --git a/api/lib/domain/models/CertificationCandidate.js b/api/lib/domain/models/CertificationCandidate.js index d8f3c89454d..1a53a967a85 100644 --- a/api/lib/domain/models/CertificationCandidate.js +++ b/api/lib/domain/models/CertificationCandidate.js @@ -1,14 +1,16 @@ -const isNil = require('lodash/isNil'); -const endsWith = require('lodash/endsWith'); -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import lodash from 'lodash'; + +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { +const { isNil, endsWith } = lodash; +import { InvalidCertificationCandidate, CertificationCandidatePersonalInfoFieldMissingError, CertificationCandidatePersonalInfoWrongFormat, -} = require('../errors.js'); -const { CERTIFICATION_CANDIDATES_ERRORS } = require('../constants/certification-candidates-errors'); +} from '../errors.js'; + +import { CERTIFICATION_CANDIDATES_ERRORS } from '../constants/certification-candidates-errors.js'; const BILLING_MODES = { FREE: 'FREE', @@ -258,4 +260,4 @@ class CertificationCandidate { CertificationCandidate.BILLING_MODES = BILLING_MODES; -module.exports = CertificationCandidate; +export { CertificationCandidate }; diff --git a/api/lib/domain/models/CertificationCandidateForSupervising.js b/api/lib/domain/models/CertificationCandidateForSupervising.js index 8edda9e4172..f3a3ab70192 100644 --- a/api/lib/domain/models/CertificationCandidateForSupervising.js +++ b/api/lib/domain/models/CertificationCandidateForSupervising.js @@ -1,5 +1,6 @@ -const isNil = require('lodash/isNil'); +import lodash from 'lodash'; +const { isNil } = lodash; class CertificationCandidateForSupervising { constructor({ id, @@ -41,4 +42,4 @@ class CertificationCandidateForSupervising { } } -module.exports = CertificationCandidateForSupervising; +export { CertificationCandidateForSupervising }; diff --git a/api/lib/domain/models/CertificationCenter.js b/api/lib/domain/models/CertificationCenter.js index 847e40e3393..ba1194c95ac 100644 --- a/api/lib/domain/models/CertificationCenter.js +++ b/api/lib/domain/models/CertificationCenter.js @@ -1,4 +1,4 @@ -const { CERTIFICATION_CENTER_TYPES } = require('../constants.js'); +import { CERTIFICATION_CENTER_TYPES } from '../constants.js'; class CertificationCenter { constructor({ id, name, externalId, type, createdAt, updatedAt, habilitations = [] } = {}) { @@ -23,6 +23,6 @@ class CertificationCenter { return this.habilitations.some((habilitation) => habilitation.key === key); } } +CertificationCenter.types = CERTIFICATION_CENTER_TYPES; -module.exports = CertificationCenter; -module.exports.types = CERTIFICATION_CENTER_TYPES; +export { CertificationCenter, CERTIFICATION_CENTER_TYPES as types }; diff --git a/api/lib/domain/models/CertificationCenterForAdmin.js b/api/lib/domain/models/CertificationCenterForAdmin.js index 23e5c1aba15..13adf52f0ca 100644 --- a/api/lib/domain/models/CertificationCenterForAdmin.js +++ b/api/lib/domain/models/CertificationCenterForAdmin.js @@ -1,4 +1,4 @@ -const { CERTIFICATION_CENTER_TYPES } = require('../constants.js'); +import { CERTIFICATION_CENTER_TYPES } from '../constants.js'; class CertificationCenterForAdmin { constructor({ @@ -34,5 +34,6 @@ class CertificationCenterForAdmin { } } -module.exports = CertificationCenterForAdmin; -module.exports.types = CERTIFICATION_CENTER_TYPES; +CertificationCenterForAdmin.types = CERTIFICATION_CENTER_TYPES; + +export { CertificationCenterForAdmin, CERTIFICATION_CENTER_TYPES as types }; diff --git a/api/lib/domain/models/CertificationCenterInvitation.js b/api/lib/domain/models/CertificationCenterInvitation.js index f313e4559a8..a731a90aec2 100644 --- a/api/lib/domain/models/CertificationCenterInvitation.js +++ b/api/lib/domain/models/CertificationCenterInvitation.js @@ -1,8 +1,8 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { validateEntity } = require('../validators/entity-validator.js'); -const randomString = require('randomstring'); +import { validateEntity } from '../validators/entity-validator.js'; +import randomString from 'randomstring'; const statuses = { PENDING: 'pending', @@ -67,4 +67,4 @@ class CertificationCenterInvitation { CertificationCenterInvitation.StatusType = statuses; -module.exports = CertificationCenterInvitation; +export { CertificationCenterInvitation }; diff --git a/api/lib/domain/models/CertificationCenterInvitedUser.js b/api/lib/domain/models/CertificationCenterInvitedUser.js index 5742b7da879..c066c975c6c 100644 --- a/api/lib/domain/models/CertificationCenterInvitedUser.js +++ b/api/lib/domain/models/CertificationCenterInvitedUser.js @@ -1,5 +1,5 @@ -const { NotFoundError, AlreadyAcceptedOrCancelledInvitationError } = require('../errors.js'); -const CertificationCenterInvitation = require('./CertificationCenterInvitation.js'); +import { NotFoundError, AlreadyAcceptedOrCancelledInvitationError } from '../errors.js'; +import { CertificationCenterInvitation } from './CertificationCenterInvitation.js'; class CertificationCenterInvitedUser { constructor({ userId, invitation, status } = {}) { @@ -23,4 +23,4 @@ class CertificationCenterInvitedUser { } } -module.exports = CertificationCenterInvitedUser; +export { CertificationCenterInvitedUser }; diff --git a/api/lib/domain/models/CertificationCenterMembership.js b/api/lib/domain/models/CertificationCenterMembership.js index deb42f65d83..01d6b1838a2 100644 --- a/api/lib/domain/models/CertificationCenterMembership.js +++ b/api/lib/domain/models/CertificationCenterMembership.js @@ -9,4 +9,4 @@ class CertificationCenterMembership { } } -module.exports = CertificationCenterMembership; +export { CertificationCenterMembership }; diff --git a/api/lib/domain/models/CertificationChallenge.js b/api/lib/domain/models/CertificationChallenge.js index 85cd880f3b2..43ca3c8de1f 100644 --- a/api/lib/domain/models/CertificationChallenge.js +++ b/api/lib/domain/models/CertificationChallenge.js @@ -52,4 +52,4 @@ class CertificationChallenge { } } -module.exports = CertificationChallenge; +export { CertificationChallenge }; diff --git a/api/lib/domain/models/CertificationChallengeWithType.js b/api/lib/domain/models/CertificationChallengeWithType.js index 80f0b02dd8d..6fb2356b7ce 100644 --- a/api/lib/domain/models/CertificationChallengeWithType.js +++ b/api/lib/domain/models/CertificationChallengeWithType.js @@ -1,4 +1,4 @@ -const { Type } = require('./Challenge.js'); +import { Type } from './Challenge.js'; class CertificationChallengeWithType { constructor({ @@ -39,4 +39,4 @@ class CertificationChallengeWithType { } } -module.exports = CertificationChallengeWithType; +export { CertificationChallengeWithType }; diff --git a/api/lib/domain/models/CertificationContract.js b/api/lib/domain/models/CertificationContract.js index 033b6b2ce33..2f658db6428 100644 --- a/api/lib/domain/models/CertificationContract.js +++ b/api/lib/domain/models/CertificationContract.js @@ -1,5 +1,5 @@ -const { CertificationComputeError } = require('../../../lib/domain/errors.js'); -const _ = require('lodash'); +import { CertificationComputeError } from '../../../lib/domain/errors.js'; +import _ from 'lodash'; class CertificationContract { /* PUBLIC INTERFACE */ @@ -56,4 +56,4 @@ class CertificationContract { } } -module.exports = CertificationContract; +export { CertificationContract }; diff --git a/api/lib/domain/models/CertificationCourse.js b/api/lib/domain/models/CertificationCourse.js index 5568ff6582b..9131e8a8359 100644 --- a/api/lib/domain/models/CertificationCourse.js +++ b/api/lib/domain/models/CertificationCourse.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import _ from 'lodash'; +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { EntityValidationError } = require('../errors.js'); +import { EntityValidationError } from '../errors.js'; const ABORT_REASONS = ['candidate', 'technical']; const cpfImportStatus = { @@ -260,4 +260,4 @@ function _sanitizedString(string) { CertificationCourse.cpfImportStatus = cpfImportStatus; -module.exports = CertificationCourse; +export { CertificationCourse, cpfImportStatus }; diff --git a/api/lib/domain/models/CertificationCpfCity.js b/api/lib/domain/models/CertificationCpfCity.js index 6e4f5cfbae4..47692c2fb55 100644 --- a/api/lib/domain/models/CertificationCpfCity.js +++ b/api/lib/domain/models/CertificationCpfCity.js @@ -8,4 +8,4 @@ class CertificationCpfCity { } } -module.exports = CertificationCpfCity; +export { CertificationCpfCity }; diff --git a/api/lib/domain/models/CertificationCpfCountry.js b/api/lib/domain/models/CertificationCpfCountry.js index 38636600df8..e1609ed7ca7 100644 --- a/api/lib/domain/models/CertificationCpfCountry.js +++ b/api/lib/domain/models/CertificationCpfCountry.js @@ -16,4 +16,4 @@ class CertificationCpfCountry { } } -module.exports = CertificationCpfCountry; +export { CertificationCpfCountry }; diff --git a/api/lib/domain/models/CertificationIssueReport.js b/api/lib/domain/models/CertificationIssueReport.js index 406381286dc..d57cac78448 100644 --- a/api/lib/domain/models/CertificationIssueReport.js +++ b/api/lib/domain/models/CertificationIssueReport.js @@ -1,17 +1,19 @@ -const Joi = require('joi'); -const { +import Joi from 'joi'; + +import { InvalidCertificationIssueReportForSaving, DeprecatedCertificationIssueReportCategoryError, DeprecatedCertificationIssueReportSubcategoryError, -} = require('../errors.js'); -const { - CertificationIssueReportCategories, +} from '../errors.js'; + +import { + CertificationIssueReportCategory as CertificationIssueReportCategories, CertificationIssueReportSubcategories, ImpactfulCategories, ImpactfulSubcategories, DeprecatedCategories, DeprecatedSubcategories, -} = require('./CertificationIssueReportCategory.js'); +} from './CertificationIssueReportCategory.js'; const categoryNonBlockingTechnicalIssueJoiSchema = Joi.object({ certificationCourseId: Joi.number().required().empty(null), @@ -180,7 +182,7 @@ class CertificationIssueReport { } } -module.exports = CertificationIssueReport; +export { CertificationIssueReport }; function _isImpactful({ category, subcategory }) { return ImpactfulCategories.includes(category) || ImpactfulSubcategories.includes(subcategory); diff --git a/api/lib/domain/models/CertificationIssueReportCategory.js b/api/lib/domain/models/CertificationIssueReportCategory.js index f30f4b0ec5f..e84a346e4dc 100644 --- a/api/lib/domain/models/CertificationIssueReportCategory.js +++ b/api/lib/domain/models/CertificationIssueReportCategory.js @@ -63,8 +63,8 @@ const DeprecatedSubcategories = [ CertificationIssueReportSubcategories.LEFT_EXAM_ROOM, ]; -module.exports = { - CertificationIssueReportCategories, +export { + CertificationIssueReportCategories as CertificationIssueReportCategory, CertificationIssueReportSubcategories, ImpactfulCategories, ImpactfulSubcategories, diff --git a/api/lib/domain/models/CertificationIssueReportResolutionAttempt.js b/api/lib/domain/models/CertificationIssueReportResolutionAttempt.js index fa7a4daf17e..7ec5ce29fce 100644 --- a/api/lib/domain/models/CertificationIssueReportResolutionAttempt.js +++ b/api/lib/domain/models/CertificationIssueReportResolutionAttempt.js @@ -1,4 +1,4 @@ -module.exports = class CertificationIssueReportResolutionAttempt { +class CertificationIssueReportResolutionAttempt { constructor(status) { this.status = status; } @@ -18,7 +18,9 @@ module.exports = class CertificationIssueReportResolutionAttempt { isResolvedWithEffect() { return this.status === ResolutionStatus.RESOLVED_WITH_EFFECT; } -}; +} + +export { CertificationIssueReportResolutionAttempt }; const ResolutionStatus = { RESOLVED_WITH_EFFECT: 'RESOLVED_WITH_EFFECT', diff --git a/api/lib/domain/models/CertificationIssueReportResolutionStrategies.js b/api/lib/domain/models/CertificationIssueReportResolutionStrategies.js index 5fe7cc21468..1ae1d5c462e 100644 --- a/api/lib/domain/models/CertificationIssueReportResolutionStrategies.js +++ b/api/lib/domain/models/CertificationIssueReportResolutionStrategies.js @@ -1,5 +1,5 @@ -const CertificationIssueReportResolutionAttempt = require('./CertificationIssueReportResolutionAttempt.js'); -const { CertificationIssueReportSubcategories } = require('./CertificationIssueReportCategory.js'); +import { CertificationIssueReportResolutionAttempt } from './CertificationIssueReportResolutionAttempt.js'; +import { CertificationIssueReportSubcategories } from './CertificationIssueReportCategory.js'; async function neutralizeIfTimedChallengeStrategy({ certificationIssueReport, @@ -163,7 +163,7 @@ class CertificationIssueReportResolutionStrategies { } } -module.exports = { +export { neutralizeWithoutCheckingStrategy, neutralizeIfImageOrEmbedStrategy, neutralizeIfAttachmentStrategy, diff --git a/api/lib/domain/models/CertificationOfficer.js b/api/lib/domain/models/CertificationOfficer.js index f91d380fe0c..45830afb75c 100644 --- a/api/lib/domain/models/CertificationOfficer.js +++ b/api/lib/domain/models/CertificationOfficer.js @@ -10,4 +10,4 @@ class CertificationOfficer { } } -module.exports = CertificationOfficer; +export { CertificationOfficer }; diff --git a/api/lib/domain/models/CertificationReport.js b/api/lib/domain/models/CertificationReport.js index f56655b96fc..758a1a86d58 100644 --- a/api/lib/domain/models/CertificationReport.js +++ b/api/lib/domain/models/CertificationReport.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const Joi = require('joi'); +import _ from 'lodash'; +import Joi from 'joi'; -const { InvalidCertificationReportForFinalization } = require('../errors.js'); +import { InvalidCertificationReportForFinalization } from '../errors.js'; const NO_EXAMINER_COMMENT = null; @@ -74,5 +74,6 @@ class CertificationReport { } } -module.exports = CertificationReport; -module.exports.NO_EXAMINER_COMMENT = NO_EXAMINER_COMMENT; +CertificationReport.NO_EXAMINER_COMMENT = NO_EXAMINER_COMMENT; + +export { CertificationReport, NO_EXAMINER_COMMENT }; diff --git a/api/lib/domain/models/CertificationResult.js b/api/lib/domain/models/CertificationResult.js index 48bf6e5a33b..ec86f7e6818 100644 --- a/api/lib/domain/models/CertificationResult.js +++ b/api/lib/domain/models/CertificationResult.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); -const CompetenceMark = require('./CompetenceMark.js'); -const ComplementaryCertificationCourseResult = require('./ComplementaryCertificationCourseResult.js'); +import _ from 'lodash'; +import { CompetenceMark } from './CompetenceMark.js'; +import { ComplementaryCertificationCourseResult } from './ComplementaryCertificationCourseResult.js'; const status = { REJECTED: 'rejected', @@ -153,4 +153,4 @@ class CertificationResult { CertificationResult.status = status; CertificationResult.emitters = emitters; -module.exports = CertificationResult; +export { CertificationResult }; diff --git a/api/lib/domain/models/CertifiedLevel.js b/api/lib/domain/models/CertifiedLevel.js index c23692ee543..f2f5c8f54ba 100644 --- a/api/lib/domain/models/CertifiedLevel.js +++ b/api/lib/domain/models/CertifiedLevel.js @@ -1,5 +1,5 @@ -const { UNCERTIFIED_LEVEL } = require('../constants.js'); -const { DomainError } = require('../errors.js'); +import { UNCERTIFIED_LEVEL } from '../constants.js'; +import { DomainError } from '../errors.js'; class CertifiedLevel { constructor({ value, status }) { @@ -57,9 +57,7 @@ const statuses = { VALIDATED: 'VALIDATED', }; -module.exports = { - CertifiedLevel, -}; +export { CertifiedLevel }; class Rule { constructor({ diff --git a/api/lib/domain/models/CertifiedScore.js b/api/lib/domain/models/CertifiedScore.js index 64d391cb431..bbaeae3b5cd 100644 --- a/api/lib/domain/models/CertifiedScore.js +++ b/api/lib/domain/models/CertifiedScore.js @@ -1,4 +1,4 @@ -const { PIX_COUNT_BY_LEVEL } = require('../constants.js'); +import { PIX_COUNT_BY_LEVEL } from '../constants.js'; class CertifiedScore { constructor(value) { @@ -15,6 +15,4 @@ class CertifiedScore { } } -module.exports = { - CertifiedScore, -}; +export { CertifiedScore }; diff --git a/api/lib/domain/models/Challenge.js b/api/lib/domain/models/Challenge.js index 8207b88a09d..56a5808d7bf 100644 --- a/api/lib/domain/models/Challenge.js +++ b/api/lib/domain/models/Challenge.js @@ -1,10 +1,10 @@ -const _ = require('lodash'); -const Validator = require('./Validator.js'); -const ValidatorQCM = require('./ValidatorQCM.js'); -const ValidatorQCU = require('./ValidatorQCU.js'); -const ValidatorQROC = require('./ValidatorQROC.js'); -const ValidatorQROCMDep = require('./ValidatorQROCMDep.js'); -const ValidatorQROCMInd = require('./ValidatorQROCMInd.js'); +import _ from 'lodash'; +import { Validator } from './Validator.js'; +import { ValidatorQCM } from './ValidatorQCM.js'; +import { ValidatorQCU } from './ValidatorQCU.js'; +import { ValidatorQROC } from './ValidatorQROC.js'; +import { ValidatorQROCMDep } from './ValidatorQROCMDep.js'; +import { ValidatorQROCMInd } from './ValidatorQROCMInd.js'; const ChallengeType = Object.freeze({ QCU: 'QCU', @@ -168,4 +168,4 @@ class Challenge { Challenge.Type = ChallengeType; -module.exports = Challenge; +export { Challenge, ChallengeType as Type }; diff --git a/api/lib/domain/models/Competence.js b/api/lib/domain/models/Competence.js index 7526f4c24d9..a7affb82672 100644 --- a/api/lib/domain/models/Competence.js +++ b/api/lib/domain/models/Competence.js @@ -37,4 +37,4 @@ class Competence { } } -module.exports = Competence; +export { Competence }; diff --git a/api/lib/domain/models/CompetenceEvaluation.js b/api/lib/domain/models/CompetenceEvaluation.js index 480129f9f2b..72ae082df0c 100644 --- a/api/lib/domain/models/CompetenceEvaluation.js +++ b/api/lib/domain/models/CompetenceEvaluation.js @@ -20,4 +20,4 @@ class CompetenceEvaluation { CompetenceEvaluation.statuses = statuses; -module.exports = CompetenceEvaluation; +export { CompetenceEvaluation }; diff --git a/api/lib/domain/models/CompetenceMark.js b/api/lib/domain/models/CompetenceMark.js index de94fd203a2..f5e8ffb19c3 100644 --- a/api/lib/domain/models/CompetenceMark.js +++ b/api/lib/domain/models/CompetenceMark.js @@ -1,5 +1,5 @@ -const Joi = require('joi'); -const { validateEntity } = require('../validators/entity-validator.js'); +import Joi from 'joi'; +import { validateEntity } from '../validators/entity-validator.js'; const schema = Joi.object({ id: Joi.number().integer().optional(), @@ -27,4 +27,4 @@ class CompetenceMark { } } -module.exports = CompetenceMark; +export { CompetenceMark }; diff --git a/api/lib/domain/models/CompetenceResult.js b/api/lib/domain/models/CompetenceResult.js index 8bbc6e774ba..5b5a0a1a911 100644 --- a/api/lib/domain/models/CompetenceResult.js +++ b/api/lib/domain/models/CompetenceResult.js @@ -28,4 +28,4 @@ class CompetenceResult { } } -module.exports = CompetenceResult; +export { CompetenceResult }; diff --git a/api/lib/domain/models/CompetenceTree.js b/api/lib/domain/models/CompetenceTree.js index c0c5910b12e..3847d49f18b 100644 --- a/api/lib/domain/models/CompetenceTree.js +++ b/api/lib/domain/models/CompetenceTree.js @@ -5,4 +5,4 @@ class CompetenceTree { } } -module.exports = CompetenceTree; +export { CompetenceTree }; diff --git a/api/lib/domain/models/ComplementaryCertification.js b/api/lib/domain/models/ComplementaryCertification.js index c778a6ac6a1..ad62efd87da 100644 --- a/api/lib/domain/models/ComplementaryCertification.js +++ b/api/lib/domain/models/ComplementaryCertification.js @@ -16,4 +16,4 @@ ComplementaryCertification.CLEA = CLEA; ComplementaryCertification.PIX_PLUS_EDU_1ER_DEGRE = PIX_PLUS_EDU_1ER_DEGRE; ComplementaryCertification.PIX_PLUS_EDU_2ND_DEGRE = PIX_PLUS_EDU_2ND_DEGRE; -module.exports = ComplementaryCertification; +export { ComplementaryCertification, PIX_PLUS_DROIT, CLEA, PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE }; diff --git a/api/lib/domain/models/ComplementaryCertificationCourse.js b/api/lib/domain/models/ComplementaryCertificationCourse.js index 3c73c4169e2..0dc8e837f45 100644 --- a/api/lib/domain/models/ComplementaryCertificationCourse.js +++ b/api/lib/domain/models/ComplementaryCertificationCourse.js @@ -7,4 +7,4 @@ class ComplementaryCertificationCourse { } } -module.exports = ComplementaryCertificationCourse; +export { ComplementaryCertificationCourse }; diff --git a/api/lib/domain/models/ComplementaryCertificationCourseResult.js b/api/lib/domain/models/ComplementaryCertificationCourseResult.js index cfa2bf76aa3..908a7c39349 100644 --- a/api/lib/domain/models/ComplementaryCertificationCourseResult.js +++ b/api/lib/domain/models/ComplementaryCertificationCourseResult.js @@ -55,4 +55,4 @@ class ComplementaryCertificationCourseResult { ComplementaryCertificationCourseResult.sources = sources; -module.exports = ComplementaryCertificationCourseResult; +export { ComplementaryCertificationCourseResult, sources }; diff --git a/api/lib/domain/models/ComplementaryCertificationForSupervising.js b/api/lib/domain/models/ComplementaryCertificationForSupervising.js index 09a03fdf212..e1986187f4d 100644 --- a/api/lib/domain/models/ComplementaryCertificationForSupervising.js +++ b/api/lib/domain/models/ComplementaryCertificationForSupervising.js @@ -6,4 +6,4 @@ class ComplementaryCertificationForSupervising { } } -module.exports = ComplementaryCertificationForSupervising; +export { ComplementaryCertificationForSupervising }; diff --git a/api/lib/domain/models/ComplementaryCertificationHabilitation.js b/api/lib/domain/models/ComplementaryCertificationHabilitation.js index 3d4c8837dc8..01c75ad0ed1 100644 --- a/api/lib/domain/models/ComplementaryCertificationHabilitation.js +++ b/api/lib/domain/models/ComplementaryCertificationHabilitation.js @@ -6,4 +6,4 @@ class ComplementaryCertificationHabilitation { } } -module.exports = ComplementaryCertificationHabilitation; +export { ComplementaryCertificationHabilitation }; diff --git a/api/lib/domain/models/ComplementaryCertificationScoringCriteria.js b/api/lib/domain/models/ComplementaryCertificationScoringCriteria.js index 9e580938139..ca42199568a 100644 --- a/api/lib/domain/models/ComplementaryCertificationScoringCriteria.js +++ b/api/lib/domain/models/ComplementaryCertificationScoringCriteria.js @@ -14,4 +14,4 @@ class ComplementaryCertificationScoringCriteria { } } -module.exports = ComplementaryCertificationScoringCriteria; +export { ComplementaryCertificationScoringCriteria }; diff --git a/api/lib/domain/models/ComplementaryCertificationScoringWithComplementaryReferential.js b/api/lib/domain/models/ComplementaryCertificationScoringWithComplementaryReferential.js index ecb907a53a1..85e532faf99 100644 --- a/api/lib/domain/models/ComplementaryCertificationScoringWithComplementaryReferential.js +++ b/api/lib/domain/models/ComplementaryCertificationScoringWithComplementaryReferential.js @@ -1,5 +1,5 @@ -const ComplementaryCertificationCourseResult = require('./ComplementaryCertificationCourseResult.js'); -const PartnerCertificationScoring = require('./PartnerCertificationScoring.js'); +import { ComplementaryCertificationCourseResult } from './ComplementaryCertificationCourseResult.js'; +import { PartnerCertificationScoring } from './PartnerCertificationScoring.js'; class ComplementaryCertificationScoringWithComplementaryReferential extends PartnerCertificationScoring { constructor({ @@ -25,4 +25,4 @@ class ComplementaryCertificationScoringWithComplementaryReferential extends Part } } -module.exports = ComplementaryCertificationScoringWithComplementaryReferential; +export { ComplementaryCertificationScoringWithComplementaryReferential }; diff --git a/api/lib/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential.js b/api/lib/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential.js index 746d6f2eb5d..9bdb5068b27 100644 --- a/api/lib/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential.js +++ b/api/lib/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential.js @@ -1,4 +1,4 @@ -const PartnerCertificationScoring = require('./PartnerCertificationScoring.js'); +import { PartnerCertificationScoring } from './PartnerCertificationScoring.js'; class ComplementaryCertificationScoringWithoutComplementaryReferential extends PartnerCertificationScoring { constructor({ @@ -34,4 +34,4 @@ class ComplementaryCertificationScoringWithoutComplementaryReferential extends P } } -module.exports = ComplementaryCertificationScoringWithoutComplementaryReferential; +export { ComplementaryCertificationScoringWithoutComplementaryReferential }; diff --git a/api/lib/domain/models/Correction.js b/api/lib/domain/models/Correction.js index 2a690c649e3..6e30c1f9071 100644 --- a/api/lib/domain/models/Correction.js +++ b/api/lib/domain/models/Correction.js @@ -9,4 +9,4 @@ class Correction { } } -module.exports = Correction; +export { Correction }; diff --git a/api/lib/domain/models/CorrectionBlockQROCMDep.js b/api/lib/domain/models/CorrectionBlockQROCMDep.js index 7b3da8291a0..d078aca0b33 100644 --- a/api/lib/domain/models/CorrectionBlockQROCMDep.js +++ b/api/lib/domain/models/CorrectionBlockQROCMDep.js @@ -1,4 +1,4 @@ -const Joi = require('joi'); +import Joi from 'joi'; class CorrectionBlockQROCMDep { /** @@ -60,4 +60,4 @@ class CorrectionBlockQROCMDep { } } -module.exports = CorrectionBlockQROCMDep; +export { CorrectionBlockQROCMDep }; diff --git a/api/lib/domain/models/Course.js b/api/lib/domain/models/Course.js index 31c634a15ab..67c377795e8 100644 --- a/api/lib/domain/models/Course.js +++ b/api/lib/domain/models/Course.js @@ -13,4 +13,4 @@ class Course { } } -module.exports = Course; +export { Course }; diff --git a/api/lib/domain/models/DataProtectionOfficer.js b/api/lib/domain/models/DataProtectionOfficer.js index 8d10e52462c..c3b771eff00 100644 --- a/api/lib/domain/models/DataProtectionOfficer.js +++ b/api/lib/domain/models/DataProtectionOfficer.js @@ -20,4 +20,4 @@ class DataProtectionOfficer { } } -module.exports = DataProtectionOfficer; +export { DataProtectionOfficer }; diff --git a/api/lib/domain/models/Division.js b/api/lib/domain/models/Division.js index 4f4f92240da..48da47210af 100644 --- a/api/lib/domain/models/Division.js +++ b/api/lib/domain/models/Division.js @@ -4,4 +4,4 @@ class Division { } } -module.exports = Division; +export { Division }; diff --git a/api/lib/domain/models/EmailModificationDemand.js b/api/lib/domain/models/EmailModificationDemand.js index fd9c073c9f9..664fb5d33f1 100644 --- a/api/lib/domain/models/EmailModificationDemand.js +++ b/api/lib/domain/models/EmailModificationDemand.js @@ -5,4 +5,4 @@ class EmailModificationDemand { } } -module.exports = EmailModificationDemand; +export { EmailModificationDemand }; diff --git a/api/lib/domain/models/EmailingAttempt.js b/api/lib/domain/models/EmailingAttempt.js index f1bbd928588..f7b6ef935e4 100644 --- a/api/lib/domain/models/EmailingAttempt.js +++ b/api/lib/domain/models/EmailingAttempt.js @@ -1,4 +1,4 @@ -module.exports = class EmailingAttempt { +class EmailingAttempt { static errorCode = { PROVIDER_ERROR: 'PROVIDER_ERROR', INVALID_DOMAIN: 'INVALID_DOMAIN', @@ -35,7 +35,9 @@ module.exports = class EmailingAttempt { static failure(email, errorCode = EmailingAttempt.errorCode.PROVIDER_ERROR, errorMessage) { return new EmailingAttempt(email, AttemptStatus.FAILURE, errorCode, errorMessage); } -}; +} + +export { EmailingAttempt }; const AttemptStatus = { SUCCESS: 'SUCCESS', diff --git a/api/lib/domain/models/Examiner.js b/api/lib/domain/models/Examiner.js index 6407aa727b6..d2a11a02980 100644 --- a/api/lib/domain/models/Examiner.js +++ b/api/lib/domain/models/Examiner.js @@ -1,6 +1,6 @@ -const logger = require('../../infrastructure/logger.js'); -const Answer = require('./Answer.js'); -const AnswerStatus = require('./AnswerStatus.js'); +import { logger } from '../../infrastructure/logger.js'; +import { Answer } from './Answer.js'; +import { AnswerStatus } from './AnswerStatus.js'; /** * Traduction: Correcteur @@ -76,4 +76,4 @@ class Examiner { } } -module.exports = Examiner; +export { Examiner }; diff --git a/api/lib/domain/models/FinalizedSession.js b/api/lib/domain/models/FinalizedSession.js index 9d6a860f9c8..8f7ffd41917 100644 --- a/api/lib/domain/models/FinalizedSession.js +++ b/api/lib/domain/models/FinalizedSession.js @@ -1,4 +1,4 @@ -module.exports = class FinalizedSession { +class FinalizedSession { constructor({ sessionId, finalizedAt, @@ -57,7 +57,9 @@ module.exports = class FinalizedSession { this.isPublishable = false; this.assignedCertificationOfficerName = certificationOfficerName; } -}; +} + +export { FinalizedSession }; function _hasNoIssueReportsWithRequiredAction(juryCertificationSummaries) { return !juryCertificationSummaries.some((summary) => summary.isActionRequired()); diff --git a/api/lib/domain/models/FlashAssessmentAlgorithm.js b/api/lib/domain/models/FlashAssessmentAlgorithm.js index 51ef405d5fc..7aebbab7fa6 100644 --- a/api/lib/domain/models/FlashAssessmentAlgorithm.js +++ b/api/lib/domain/models/FlashAssessmentAlgorithm.js @@ -1,5 +1,5 @@ -const { AssessmentEndedError } = require('../errors'); -const { getPossibleNextChallenges } = require('../services/algorithm-methods/flash'); +import { AssessmentEndedError } from '../errors.js'; +import { getPossibleNextChallenges } from '../services/algorithm-methods/flash.js'; class FlashAssessmentAlgorithm { getPossibleNextChallenges({ allAnswers, challenges, estimatedLevel }) { @@ -17,4 +17,4 @@ class FlashAssessmentAlgorithm { } } -module.exports = FlashAssessmentAlgorithm; +export { FlashAssessmentAlgorithm }; diff --git a/api/lib/domain/models/Framework.js b/api/lib/domain/models/Framework.js index b4910711d4d..4649d7e07ba 100644 --- a/api/lib/domain/models/Framework.js +++ b/api/lib/domain/models/Framework.js @@ -6,4 +6,4 @@ class Framework { } } -module.exports = Framework; +export { Framework }; diff --git a/api/lib/domain/models/Group.js b/api/lib/domain/models/Group.js index 99108d6dade..1714852dbeb 100644 --- a/api/lib/domain/models/Group.js +++ b/api/lib/domain/models/Group.js @@ -4,4 +4,4 @@ class Group { } } -module.exports = Group; +export { Group }; diff --git a/api/lib/domain/models/Hint.js b/api/lib/domain/models/Hint.js index 281921a6cb7..5e134de45f3 100644 --- a/api/lib/domain/models/Hint.js +++ b/api/lib/domain/models/Hint.js @@ -5,4 +5,4 @@ class Hint { } } -module.exports = Hint; +export { Hint }; diff --git a/api/lib/domain/models/JuryCertification.js b/api/lib/domain/models/JuryCertification.js index e54bf3f1790..f6793f745db 100644 --- a/api/lib/domain/models/JuryCertification.js +++ b/api/lib/domain/models/JuryCertification.js @@ -1,4 +1,4 @@ -const CompetenceMark = require('./CompetenceMark.js'); +import { CompetenceMark } from './CompetenceMark.js'; class JuryCertification { constructor({ @@ -102,4 +102,4 @@ class JuryCertification { } } -module.exports = JuryCertification; +export { JuryCertification }; diff --git a/api/lib/domain/models/JurySession.js b/api/lib/domain/models/JurySession.js index a52cebda4ff..7b5d890996d 100644 --- a/api/lib/domain/models/JurySession.js +++ b/api/lib/domain/models/JurySession.js @@ -1,4 +1,4 @@ -const { statuses } = require('./Session.js'); +import { statuses } from './Session.js'; class JurySession { constructor({ @@ -63,5 +63,4 @@ class JurySession { } } -module.exports = JurySession; -module.exports.statuses = statuses; +export { JurySession, statuses }; diff --git a/api/lib/domain/models/KnowledgeElement.js b/api/lib/domain/models/KnowledgeElement.js index fb35df6fbc6..1280408fc1b 100644 --- a/api/lib/domain/models/KnowledgeElement.js +++ b/api/lib/domain/models/KnowledgeElement.js @@ -1,6 +1,6 @@ -const Skill = require('../models/Skill.js'); -const _ = require('lodash'); -const moment = require('moment'); +import { Skill } from '../models/Skill.js'; +import _ from 'lodash'; +import moment from 'moment'; const statuses = { VALIDATED: 'validated', @@ -201,4 +201,4 @@ function _createKnowledgeElement({ answer, skill, userId, status, source }) { }); } -module.exports = KnowledgeElement; +export { KnowledgeElement }; diff --git a/api/lib/domain/models/LearningContent.js b/api/lib/domain/models/LearningContent.js index 8467b341e36..8b92043ac2f 100644 --- a/api/lib/domain/models/LearningContent.js +++ b/api/lib/domain/models/LearningContent.js @@ -1,4 +1,4 @@ -module.exports = class LearningContent { +class LearningContent { constructor(frameworks) { this.frameworks = frameworks; } @@ -55,4 +55,6 @@ module.exports = class LearningContent { if (!frameworkId) return ''; return this.findFramework(frameworkId).name; } -}; +} + +export { LearningContent }; diff --git a/api/lib/domain/models/Membership.js b/api/lib/domain/models/Membership.js index 71c18554eef..ade0eafe724 100644 --- a/api/lib/domain/models/Membership.js +++ b/api/lib/domain/models/Membership.js @@ -1,4 +1,4 @@ -const { InvalidMembershipOrganizationRoleError } = require('../errors.js'); +import { InvalidMembershipOrganizationRoleError } from '../errors.js'; const roles = { ADMIN: 'ADMIN', MEMBER: 'MEMBER', @@ -27,4 +27,4 @@ class Membership { Membership.roles = roles; -module.exports = Membership; +export { Membership, roles }; diff --git a/api/lib/domain/models/NeutralizationAttempt.js b/api/lib/domain/models/NeutralizationAttempt.js index d24953d3752..0298c9ef204 100644 --- a/api/lib/domain/models/NeutralizationAttempt.js +++ b/api/lib/domain/models/NeutralizationAttempt.js @@ -1,4 +1,4 @@ -module.exports = class NeutralizationAttempt { +class NeutralizationAttempt { constructor(questionNumber, status) { this.questionNumber = questionNumber; this.status = status; @@ -27,7 +27,9 @@ module.exports = class NeutralizationAttempt { wasSkipped() { return this.status === NeutralizationStatus.SKIPPED; } -}; +} + +export { NeutralizationAttempt }; const NeutralizationStatus = { NEUTRALIZED: 'NEUTRALIZED', diff --git a/api/lib/domain/models/Organization.js b/api/lib/domain/models/Organization.js index b11295b8689..7ba63f23ad2 100644 --- a/api/lib/domain/models/Organization.js +++ b/api/lib/domain/models/Organization.js @@ -1,4 +1,4 @@ -const Tag = require('./Tag.js'); +import { Tag } from './Tag.js'; const types = { SCO: 'SCO', @@ -88,4 +88,4 @@ class Organization { Organization.types = types; Organization.defaultValues = defaultValues; -module.exports = Organization; +export { Organization, types }; diff --git a/api/lib/domain/models/OrganizationInvitation.js b/api/lib/domain/models/OrganizationInvitation.js index 680972ff331..cc38f8c81ed 100644 --- a/api/lib/domain/models/OrganizationInvitation.js +++ b/api/lib/domain/models/OrganizationInvitation.js @@ -1,7 +1,7 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { validateEntity } = require('../validators/entity-validator.js'); +import { validateEntity } from '../validators/entity-validator.js'; const statuses = { PENDING: 'pending', @@ -71,4 +71,4 @@ class OrganizationInvitation { OrganizationInvitation.StatusType = statuses; -module.exports = OrganizationInvitation; +export { OrganizationInvitation, statuses }; diff --git a/api/lib/domain/models/OrganizationInvitedUser.js b/api/lib/domain/models/OrganizationInvitedUser.js index c4d9c1a7a65..e96184a65a7 100644 --- a/api/lib/domain/models/OrganizationInvitedUser.js +++ b/api/lib/domain/models/OrganizationInvitedUser.js @@ -1,7 +1,10 @@ -const { AlreadyExistingMembershipError } = require('../../domain/errors.js'); -const { NotFoundError, AlreadyAcceptedOrCancelledInvitationError } = require('../errors.js'); -const { roles } = require('./Membership.js'); -const OrganizationInvitation = require('./OrganizationInvitation.js'); +import { + AlreadyExistingMembershipError, + NotFoundError, + AlreadyAcceptedOrCancelledInvitationError, +} from '../../domain/errors.js'; +import { roles } from './Membership.js'; +import { OrganizationInvitation } from './OrganizationInvitation.js'; class OrganizationInvitedUser { constructor({ userId, invitation, currentRole, organizationHasMemberships, currentMembershipId, status } = {}) { @@ -42,4 +45,4 @@ class OrganizationInvitedUser { } } -module.exports = OrganizationInvitedUser; +export { OrganizationInvitedUser }; diff --git a/api/lib/domain/models/OrganizationLearner.js b/api/lib/domain/models/OrganizationLearner.js index e409ce7fa27..07db4e0ddd3 100644 --- a/api/lib/domain/models/OrganizationLearner.js +++ b/api/lib/domain/models/OrganizationLearner.js @@ -50,4 +50,4 @@ class OrganizationLearner { OrganizationLearner.STATUS = STATUS; -module.exports = OrganizationLearner; +export { OrganizationLearner }; diff --git a/api/lib/domain/models/OrganizationMemberIdentity.js b/api/lib/domain/models/OrganizationMemberIdentity.js index 3a8ba834c2f..7dba5a746c1 100644 --- a/api/lib/domain/models/OrganizationMemberIdentity.js +++ b/api/lib/domain/models/OrganizationMemberIdentity.js @@ -6,4 +6,4 @@ class OrganizationMemberIdentity { } } -module.exports = OrganizationMemberIdentity; +export { OrganizationMemberIdentity }; diff --git a/api/lib/domain/models/OrganizationPlacesLot.js b/api/lib/domain/models/OrganizationPlacesLot.js index 4fa0c01f986..5e613dafd99 100644 --- a/api/lib/domain/models/OrganizationPlacesLot.js +++ b/api/lib/domain/models/OrganizationPlacesLot.js @@ -1,5 +1,5 @@ -const categories = require('../constants/organization-places-categories.js'); -const validate = require('../validators/organization-places-lot-validator.js'); +import * as categories from '../constants/organization-places-categories.js'; +import { validate } from '../validators/organization-places-lot-validator.js'; const codeByCategories = { [categories.FREE_RATE]: categories.T0, @@ -23,4 +23,4 @@ class OrganizationPlacesLot { OrganizationPlacesLot.categories = categories; -module.exports = OrganizationPlacesLot; +export { OrganizationPlacesLot }; diff --git a/api/lib/domain/models/OrganizationTag.js b/api/lib/domain/models/OrganizationTag.js index 9ac7e483ef8..a63a7a681df 100644 --- a/api/lib/domain/models/OrganizationTag.js +++ b/api/lib/domain/models/OrganizationTag.js @@ -6,4 +6,4 @@ class OrganizationTag { } } -module.exports = OrganizationTag; +export { OrganizationTag }; diff --git a/api/lib/domain/models/OrganizationsToAttachToTargetProfile.js b/api/lib/domain/models/OrganizationsToAttachToTargetProfile.js index 7ce16953495..332e69fb91a 100644 --- a/api/lib/domain/models/OrganizationsToAttachToTargetProfile.js +++ b/api/lib/domain/models/OrganizationsToAttachToTargetProfile.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const { NoOrganizationToAttach } = require('../errors.js'); +import _ from 'lodash'; +import { NoOrganizationToAttach } from '../errors.js'; class OrganizationsToAttachToTargetProfile { constructor({ id }) { @@ -14,4 +14,4 @@ class OrganizationsToAttachToTargetProfile { } } -module.exports = OrganizationsToAttachToTargetProfile; +export { OrganizationsToAttachToTargetProfile }; diff --git a/api/lib/domain/models/ParticipantResultsShared.js b/api/lib/domain/models/ParticipantResultsShared.js index 899d568466f..292c8174796 100644 --- a/api/lib/domain/models/ParticipantResultsShared.js +++ b/api/lib/domain/models/ParticipantResultsShared.js @@ -1,6 +1,6 @@ -const KnowledgeElement = require('./KnowledgeElement.js'); -const { calculatePixScore } = require('../services/scoring/scoring-service.js'); -const { MAX_REACHABLE_PIX_BY_COMPETENCE } = require('../constants.js'); +import { KnowledgeElement } from './KnowledgeElement.js'; +import { calculatePixScore } from '../services/scoring/scoring-service.js'; +import { MAX_REACHABLE_PIX_BY_COMPETENCE } from '../constants.js'; const MAX_PIX_SCORE = MAX_REACHABLE_PIX_BY_COMPETENCE * 16; class ParticipantResultsShared { @@ -29,4 +29,4 @@ function _getValidatedKnowledgeElements(knowledgeElements, skillIds) { return filteredKnowledgeElements; } -module.exports = ParticipantResultsShared; +export { ParticipantResultsShared }; diff --git a/api/lib/domain/models/ParticipationForCampaignManagement.js b/api/lib/domain/models/ParticipationForCampaignManagement.js index 7a44ffdaec8..465d28b63c5 100644 --- a/api/lib/domain/models/ParticipationForCampaignManagement.js +++ b/api/lib/domain/models/ParticipationForCampaignManagement.js @@ -32,4 +32,4 @@ class ParticipationForCampaignManagement { } } -module.exports = ParticipationForCampaignManagement; +export { ParticipationForCampaignManagement }; diff --git a/api/lib/domain/models/PartnerCertificationScoring.js b/api/lib/domain/models/PartnerCertificationScoring.js index efe4de1660e..dd4dea33630 100644 --- a/api/lib/domain/models/PartnerCertificationScoring.js +++ b/api/lib/domain/models/PartnerCertificationScoring.js @@ -1,8 +1,8 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { validateEntity } = require('../validators/entity-validator.js'); -const { NotImplementedError } = require('../errors.js'); +import { validateEntity } from '../validators/entity-validator.js'; +import { NotImplementedError } from '../errors.js'; const SOURCES = { PIX: 'PIX', @@ -29,4 +29,4 @@ class PartnerCertificationScoring { } } -module.exports = PartnerCertificationScoring; +export { PartnerCertificationScoring }; diff --git a/api/lib/domain/models/PlacementProfile.js b/api/lib/domain/models/PlacementProfile.js index f588b412679..0ba7e21cb04 100644 --- a/api/lib/domain/models/PlacementProfile.js +++ b/api/lib/domain/models/PlacementProfile.js @@ -1,5 +1,5 @@ -const { MINIMUM_CERTIFIABLE_COMPETENCES_FOR_CERTIFIABILITY } = require('../constants.js'); -const _ = require('lodash'); +import { MINIMUM_CERTIFIABLE_COMPETENCES_FOR_CERTIFIABILITY } from '../constants.js'; +import _ from 'lodash'; class PlacementProfile { constructor({ profileDate, userId, userCompetences } = {}) { @@ -35,4 +35,4 @@ class PlacementProfile { } } -module.exports = PlacementProfile; +export { PlacementProfile }; diff --git a/api/lib/domain/models/PoleEmploiSending.js b/api/lib/domain/models/PoleEmploiSending.js index 179b421ad5c..8964b01d166 100644 --- a/api/lib/domain/models/PoleEmploiSending.js +++ b/api/lib/domain/models/PoleEmploiSending.js @@ -45,4 +45,4 @@ class PoleEmploiSending { } PoleEmploiSending.TYPES = TYPES; -module.exports = PoleEmploiSending; +export { PoleEmploiSending }; diff --git a/api/lib/domain/models/PrivateCertificate.js b/api/lib/domain/models/PrivateCertificate.js index a8dc187ff14..907913caef1 100644 --- a/api/lib/domain/models/PrivateCertificate.js +++ b/api/lib/domain/models/PrivateCertificate.js @@ -1,4 +1,4 @@ -const { status: assessmentResultStatuses } = require('./AssessmentResult.js'); +import { status as assessmentResultStatuses } from './AssessmentResult.js'; const status = { REJECTED: 'rejected', @@ -104,4 +104,4 @@ function _computeStatus(assessmentResultStatus, isCancelled) { PrivateCertificate.status = status; -module.exports = PrivateCertificate; +export { PrivateCertificate }; diff --git a/api/lib/domain/models/Progression.js b/api/lib/domain/models/Progression.js index 5241c01fd01..cf3af303cfd 100644 --- a/api/lib/domain/models/Progression.js +++ b/api/lib/domain/models/Progression.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; const PROGRESSION_ID_PREFIX = 'progression-'; const ONE_HUNDRED_PERCENT = 1; @@ -38,4 +38,4 @@ class Progression { } } -module.exports = Progression; +export { Progression }; diff --git a/api/lib/domain/models/ReproducibilityRate.js b/api/lib/domain/models/ReproducibilityRate.js index 1ca947b7253..dd30fd5d8e3 100644 --- a/api/lib/domain/models/ReproducibilityRate.js +++ b/api/lib/domain/models/ReproducibilityRate.js @@ -1,4 +1,4 @@ -const { MINIMUM_REPRODUCIBILITY_RATE_TO_BE_CERTIFIED } = require('../constants.js'); +import { MINIMUM_REPRODUCIBILITY_RATE_TO_BE_CERTIFIED } from '../constants.js'; class ReproducibilityRate { constructor(value) { @@ -19,6 +19,4 @@ class ReproducibilityRate { } } -module.exports = { - ReproducibilityRate, -}; +export { ReproducibilityRate }; diff --git a/api/lib/domain/models/ResultCompetence.js b/api/lib/domain/models/ResultCompetence.js index 02358f29f8d..6f774dd6b70 100644 --- a/api/lib/domain/models/ResultCompetence.js +++ b/api/lib/domain/models/ResultCompetence.js @@ -8,4 +8,4 @@ class ResultCompetence { } } -module.exports = ResultCompetence; +export { ResultCompetence }; diff --git a/api/lib/domain/models/ResultCompetenceTree.js b/api/lib/domain/models/ResultCompetenceTree.js index 2491595b503..6dc21a67d96 100644 --- a/api/lib/domain/models/ResultCompetenceTree.js +++ b/api/lib/domain/models/ResultCompetenceTree.js @@ -1,5 +1,5 @@ -const Area = require('./Area.js'); -const ResultCompetence = require('./ResultCompetence.js'); +import { Area } from './Area.js'; +import { ResultCompetence } from './ResultCompetence.js'; const NOT_PASSED_LEVEL = -1; const NOT_PASSED_SCORE = 0; @@ -42,4 +42,4 @@ class ResultCompetenceTree { } } -module.exports = ResultCompetenceTree; +export { ResultCompetenceTree }; diff --git a/api/lib/domain/models/SCOCertificationCandidate.js b/api/lib/domain/models/SCOCertificationCandidate.js index 65120c52251..a3cedf31ecd 100644 --- a/api/lib/domain/models/SCOCertificationCandidate.js +++ b/api/lib/domain/models/SCOCertificationCandidate.js @@ -1,7 +1,7 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { InvalidCertificationCandidate } = require('../errors.js'); +import { InvalidCertificationCandidate } from '../errors.js'; const scoCertificationCandidateValidationJoiSchema = Joi.object({ firstName: Joi.string().required().empty(null), @@ -49,4 +49,4 @@ class SCOCertificationCandidate { } } -module.exports = SCOCertificationCandidate; +export { SCOCertificationCandidate }; diff --git a/api/lib/domain/models/Scorecard.js b/api/lib/domain/models/Scorecard.js index 7186b74bdd8..9e38211592c 100644 --- a/api/lib/domain/models/Scorecard.js +++ b/api/lib/domain/models/Scorecard.js @@ -1,9 +1,14 @@ -const _ = require('lodash'); -const Assessment = require('./Assessment.js'); -const CompetenceEvaluation = require('./CompetenceEvaluation.js'); -const KnowledgeElement = require('./KnowledgeElement.js'); -const { constants } = require('../constants.js'); -const scoringService = require('../services/scoring/scoring-service.js'); +import _ from 'lodash'; +import { Assessment } from './Assessment.js'; +import { CompetenceEvaluation } from './CompetenceEvaluation.js'; +import { KnowledgeElement } from './KnowledgeElement.js'; +import { + MINIMUM_DELAY_IN_DAYS_FOR_RESET, + MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING, + PIX_COUNT_BY_LEVEL, + MAX_REACHABLE_LEVEL, +} from '../constants.js'; +import * as scoringService from '../services/scoring/scoring-service.js'; const statuses = { NOT_STARTED: 'NOT_STARTED', @@ -27,6 +32,7 @@ class Scorecard { remainingDaysBeforeReset, remainingDaysBeforeImproving, tutorials, + maxReachableLevel = MAX_REACHABLE_LEVEL, } = {}) { this.id = id; this.name = name; @@ -42,6 +48,7 @@ class Scorecard { this.remainingDaysBeforeReset = remainingDaysBeforeReset; this.remainingDaysBeforeImproving = remainingDaysBeforeImproving; this.tutorials = tutorials; + this.maxReachableLevel = maxReachableLevel; } static parseId(scorecardId) { @@ -85,16 +92,14 @@ class Scorecard { static computeRemainingDaysBeforeReset(knowledgeElements) { const daysSinceLastKnowledgeElement = KnowledgeElement.computeDaysSinceLastKnowledgeElement(knowledgeElements); - const remainingDaysToWait = Math.ceil(constants.MINIMUM_DELAY_IN_DAYS_FOR_RESET - daysSinceLastKnowledgeElement); + const remainingDaysToWait = Math.ceil(MINIMUM_DELAY_IN_DAYS_FOR_RESET - daysSinceLastKnowledgeElement); return remainingDaysToWait > 0 ? remainingDaysToWait : 0; } static computeRemainingDaysBeforeImproving(knowledgeElements) { const daysSinceLastKnowledgeElement = KnowledgeElement.computeDaysSinceLastKnowledgeElement(knowledgeElements); - const remainingDaysToWait = Math.ceil( - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING - daysSinceLastKnowledgeElement - ); + const remainingDaysToWait = Math.ceil(MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING - daysSinceLastKnowledgeElement); return remainingDaysToWait > 0 ? remainingDaysToWait : 0; } @@ -108,7 +113,7 @@ class Scorecard { } get isMaxLevel() { - return this.level >= constants.MAX_REACHABLE_LEVEL; + return this.level >= this.maxReachableLevel; } get isNotStarted() { @@ -148,11 +153,11 @@ class Scorecard { } get percentageAheadOfNextLevel() { - return (this.pixScoreAheadOfNextLevel / constants.PIX_COUNT_BY_LEVEL) * 100; + return (this.pixScoreAheadOfNextLevel / PIX_COUNT_BY_LEVEL) * 100; } get remainingPixToNextLevel() { - return constants.PIX_COUNT_BY_LEVEL - this.pixScoreAheadOfNextLevel; + return PIX_COUNT_BY_LEVEL - this.pixScoreAheadOfNextLevel; } } @@ -169,4 +174,4 @@ function _getScorecardStatus(competenceEvaluation, knowledgeElements) { Scorecard.statuses = statuses; -module.exports = Scorecard; +export { Scorecard }; diff --git a/api/lib/domain/models/ScoringSimulation.js b/api/lib/domain/models/ScoringSimulation.js index 77dc251943a..368ff0d0c33 100644 --- a/api/lib/domain/models/ScoringSimulation.js +++ b/api/lib/domain/models/ScoringSimulation.js @@ -13,4 +13,4 @@ class ScoringSimulationUser { } } -module.exports = ScoringSimulation; +export { ScoringSimulation }; diff --git a/api/lib/domain/models/ScoringSimulationContext.js b/api/lib/domain/models/ScoringSimulationContext.js index 204882f39a1..4662b15a872 100644 --- a/api/lib/domain/models/ScoringSimulationContext.js +++ b/api/lib/domain/models/ScoringSimulationContext.js @@ -6,4 +6,4 @@ class ScoringSimulationContext { } } -module.exports = ScoringSimulationContext; +export { ScoringSimulationContext }; diff --git a/api/lib/domain/models/ScoringSimulationDataset.js b/api/lib/domain/models/ScoringSimulationDataset.js index 8f110810914..0b92715a68b 100644 --- a/api/lib/domain/models/ScoringSimulationDataset.js +++ b/api/lib/domain/models/ScoringSimulationDataset.js @@ -5,4 +5,4 @@ class ScoringSimulationDataset { } } -module.exports = ScoringSimulationDataset; +export { ScoringSimulationDataset }; diff --git a/api/lib/domain/models/ScoringSimulationResult.js b/api/lib/domain/models/ScoringSimulationResult.js index b093cf1c2db..ff20ca65ebb 100644 --- a/api/lib/domain/models/ScoringSimulationResult.js +++ b/api/lib/domain/models/ScoringSimulationResult.js @@ -17,4 +17,4 @@ class SimulationCompetenceResult { } } -module.exports = ScoringSimulationResult; +export { ScoringSimulationResult }; diff --git a/api/lib/domain/models/Session.js b/api/lib/domain/models/Session.js index d248b916d40..67bd9c16e0d 100644 --- a/api/lib/domain/models/Session.js +++ b/api/lib/domain/models/Session.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const config = require('../../config.js'); +import _ from 'lodash'; +import { config } from '../../config.js'; const CREATED = 'created'; const FINALIZED = 'finalized'; @@ -105,9 +105,9 @@ class Session { } } -module.exports = Session; -module.exports.statuses = statuses; -module.exports.NO_EXAMINER_GLOBAL_COMMENT = NO_EXAMINER_GLOBAL_COMMENT; +Session.statuses = statuses; + +export { Session, statuses, NO_EXAMINER_GLOBAL_COMMENT }; function _randomCharacter() { return _.sample(availableCharactersForPasswordGeneration); diff --git a/api/lib/domain/models/SessionJuryComment.js b/api/lib/domain/models/SessionJuryComment.js index d5aa46029ea..7c5325a3ec5 100644 --- a/api/lib/domain/models/SessionJuryComment.js +++ b/api/lib/domain/models/SessionJuryComment.js @@ -13,4 +13,4 @@ class SessionJuryComment { } } -module.exports = SessionJuryComment; +export { SessionJuryComment }; diff --git a/api/lib/domain/models/SessionMassImportReport.js b/api/lib/domain/models/SessionMassImportReport.js index 7016d57960c..9c2009a805e 100644 --- a/api/lib/domain/models/SessionMassImportReport.js +++ b/api/lib/domain/models/SessionMassImportReport.js @@ -35,4 +35,4 @@ class SessionMassImportReport { } } -module.exports = SessionMassImportReport; +export { SessionMassImportReport }; diff --git a/api/lib/domain/models/SessionPublicationBatchResult.js b/api/lib/domain/models/SessionPublicationBatchResult.js index 8ec06b30e8f..556327d59c0 100644 --- a/api/lib/domain/models/SessionPublicationBatchResult.js +++ b/api/lib/domain/models/SessionPublicationBatchResult.js @@ -13,6 +13,4 @@ class SessionPublicationBatchResult { } } -module.exports = { - SessionPublicationBatchResult, -}; +export { SessionPublicationBatchResult }; diff --git a/api/lib/domain/models/ShareableCertificate.js b/api/lib/domain/models/ShareableCertificate.js index c786dc8aea1..4a357fcdb7b 100644 --- a/api/lib/domain/models/ShareableCertificate.js +++ b/api/lib/domain/models/ShareableCertificate.js @@ -36,4 +36,4 @@ class ShareableCertificate { } } -module.exports = ShareableCertificate; +export { ShareableCertificate }; diff --git a/api/lib/domain/models/Skill.js b/api/lib/domain/models/Skill.js index c336e4409b2..a2ef891991d 100644 --- a/api/lib/domain/models/Skill.js +++ b/api/lib/domain/models/Skill.js @@ -46,4 +46,4 @@ class Skill { } } -module.exports = Skill; +export { Skill }; diff --git a/api/lib/domain/models/SkillSet.js b/api/lib/domain/models/SkillSet.js index 8ec37c61557..158322335c0 100644 --- a/api/lib/domain/models/SkillSet.js +++ b/api/lib/domain/models/SkillSet.js @@ -7,4 +7,4 @@ class SkillSet { } } -module.exports = SkillSet; +export { SkillSet }; diff --git a/api/lib/domain/models/Solution.js b/api/lib/domain/models/Solution.js index 5567366d090..9acee34bfe4 100644 --- a/api/lib/domain/models/Solution.js +++ b/api/lib/domain/models/Solution.js @@ -64,4 +64,4 @@ class Solution { } } -module.exports = Solution; +export { Solution }; diff --git a/api/lib/domain/models/Stage.js b/api/lib/domain/models/Stage.js index 93c62532eaa..27d8a93ef4d 100644 --- a/api/lib/domain/models/Stage.js +++ b/api/lib/domain/models/Stage.js @@ -11,4 +11,4 @@ class Stage { } } -module.exports = Stage; +export { Stage }; diff --git a/api/lib/domain/models/Student.js b/api/lib/domain/models/Student.js index 6ff56fa6e7a..9892862a78c 100644 --- a/api/lib/domain/models/Student.js +++ b/api/lib/domain/models/Student.js @@ -5,4 +5,4 @@ class Student { } } -module.exports = Student; +export { Student }; diff --git a/api/lib/domain/models/SupOrganizationLearner.js b/api/lib/domain/models/SupOrganizationLearner.js index 3caec24f45d..6c843c67af6 100644 --- a/api/lib/domain/models/SupOrganizationLearner.js +++ b/api/lib/domain/models/SupOrganizationLearner.js @@ -1,4 +1,4 @@ -const { checkValidation } = require('../validators/sup-organization-learner-validator.js'); +import { checkValidation } from '../validators/sup-organization-learner-validator.js'; class SupOrganizationLearner { constructor({ @@ -35,4 +35,4 @@ class SupOrganizationLearner { } } -module.exports = SupOrganizationLearner; +export { SupOrganizationLearner }; diff --git a/api/lib/domain/models/SupOrganizationLearnerSet.js b/api/lib/domain/models/SupOrganizationLearnerSet.js index 3d204265fb9..b7d6ef9e942 100644 --- a/api/lib/domain/models/SupOrganizationLearnerSet.js +++ b/api/lib/domain/models/SupOrganizationLearnerSet.js @@ -1,6 +1,6 @@ -const SupOrganizationLearner = require('./SupOrganizationLearner.js'); -const { checkValidation } = require('../validators/sup-organization-learner-set-validator.js'); -const { areTwoStringsCloseEnough } = require('../services/string-comparison-service.js'); +import { SupOrganizationLearner } from './SupOrganizationLearner.js'; +import { checkValidation } from '../validators/sup-organization-learner-set-validator.js'; +import { areTwoStringsCloseEnough } from '../services/string-comparison-service.js'; const RATIO = 0.25; @@ -84,4 +84,4 @@ class SupOrganizationLearnerSet { } } -module.exports = SupOrganizationLearnerSet; +export { SupOrganizationLearnerSet }; diff --git a/api/lib/domain/models/Tag.js b/api/lib/domain/models/Tag.js index 53d0856c1eb..e1dd8927caf 100644 --- a/api/lib/domain/models/Tag.js +++ b/api/lib/domain/models/Tag.js @@ -10,4 +10,4 @@ Tag.MEDIATION_NUMERIQUE = 'MEDNUM'; Tag.CFA = 'CFA'; Tag.AEFE = 'AEFE'; Tag.MLF = 'MLF'; -module.exports = Tag; +export { Tag }; diff --git a/api/lib/domain/models/TargetProfile.js b/api/lib/domain/models/TargetProfile.js index 5d85218e7ec..8f49fd91c1f 100644 --- a/api/lib/domain/models/TargetProfile.js +++ b/api/lib/domain/models/TargetProfile.js @@ -44,4 +44,4 @@ class TargetProfile { TargetProfile.categories = categories; -module.exports = TargetProfile; +export { TargetProfile, categories }; diff --git a/api/lib/domain/models/TargetProfileForAdmin.js b/api/lib/domain/models/TargetProfileForAdmin.js index 60bab45ec87..74a01aad4de 100644 --- a/api/lib/domain/models/TargetProfileForAdmin.js +++ b/api/lib/domain/models/TargetProfileForAdmin.js @@ -188,4 +188,4 @@ class TP_Tube { } } -module.exports = TargetProfileForAdmin; +export { TargetProfileForAdmin }; diff --git a/api/lib/domain/models/TargetProfileForCreation.js b/api/lib/domain/models/TargetProfileForCreation.js index 612726cce0c..f53b67234ed 100644 --- a/api/lib/domain/models/TargetProfileForCreation.js +++ b/api/lib/domain/models/TargetProfileForCreation.js @@ -1,4 +1,4 @@ -const { validate } = require('../validators/target-profile/creation-command-validation.js'); +import { validate } from '../validators/target-profile/creation-command-validation.js'; const DEFAULT_IMAGE_URL = 'https://images.pix.fr/profil-cible/Illu_GEN.svg'; class TargetProfileForCreation { @@ -28,4 +28,4 @@ class TargetProfileForCreation { } } -module.exports = TargetProfileForCreation; +export { TargetProfileForCreation }; diff --git a/api/lib/domain/models/TargetProfileSummaryForAdmin.js b/api/lib/domain/models/TargetProfileSummaryForAdmin.js index d86fce381eb..56eaa71889f 100644 --- a/api/lib/domain/models/TargetProfileSummaryForAdmin.js +++ b/api/lib/domain/models/TargetProfileSummaryForAdmin.js @@ -7,4 +7,4 @@ class TargetProfileSummaryForAdmin { } } -module.exports = TargetProfileSummaryForAdmin; +export { TargetProfileSummaryForAdmin }; diff --git a/api/lib/domain/models/Thematic.js b/api/lib/domain/models/Thematic.js index b6fa04ad4a0..29187284895 100644 --- a/api/lib/domain/models/Thematic.js +++ b/api/lib/domain/models/Thematic.js @@ -8,4 +8,4 @@ class Thematic { } } -module.exports = Thematic; +export { Thematic }; diff --git a/api/lib/domain/models/Training.js b/api/lib/domain/models/Training.js index 08458a4229d..7a82c391830 100644 --- a/api/lib/domain/models/Training.js +++ b/api/lib/domain/models/Training.js @@ -32,4 +32,4 @@ class Training { } } -module.exports = Training; +export { Training }; diff --git a/api/lib/domain/models/TrainingTrigger.js b/api/lib/domain/models/TrainingTrigger.js index fe37f6a7a55..c3fe619ba47 100644 --- a/api/lib/domain/models/TrainingTrigger.js +++ b/api/lib/domain/models/TrainingTrigger.js @@ -47,4 +47,4 @@ function _getValidatedKnowledgeElementsCount({ knowledgeElements }) { return knowledgeElements.filter((knowledgeElement) => knowledgeElement.isValidated).length; } -module.exports = TrainingTrigger; +export { TrainingTrigger }; diff --git a/api/lib/domain/models/TrainingTriggerTube.js b/api/lib/domain/models/TrainingTriggerTube.js index 81e22875e75..486823350d2 100644 --- a/api/lib/domain/models/TrainingTriggerTube.js +++ b/api/lib/domain/models/TrainingTriggerTube.js @@ -10,4 +10,4 @@ class TrainingTriggerTube { } } -module.exports = TrainingTriggerTube; +export { TrainingTriggerTube }; diff --git a/api/lib/domain/models/Tube.js b/api/lib/domain/models/Tube.js index 835cfd10afa..92260562813 100644 --- a/api/lib/domain/models/Tube.js +++ b/api/lib/domain/models/Tube.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; class Tube { constructor({ @@ -59,4 +59,4 @@ class Tube { } } -module.exports = Tube; +export { Tube }; diff --git a/api/lib/domain/models/Tutorial.js b/api/lib/domain/models/Tutorial.js index daba0c4cc25..aa68f3d01aa 100644 --- a/api/lib/domain/models/Tutorial.js +++ b/api/lib/domain/models/Tutorial.js @@ -16,4 +16,4 @@ class Tutorial { Tutorial.TYPES = TYPES; -module.exports = Tutorial; +export { Tutorial }; diff --git a/api/lib/domain/models/TutorialEvaluation.js b/api/lib/domain/models/TutorialEvaluation.js index 6fff84a740e..67c292527dd 100644 --- a/api/lib/domain/models/TutorialEvaluation.js +++ b/api/lib/domain/models/TutorialEvaluation.js @@ -15,4 +15,4 @@ class TutorialEvaluation { TutorialEvaluation.statuses = statuses; -module.exports = TutorialEvaluation; +export { TutorialEvaluation }; diff --git a/api/lib/domain/models/User.js b/api/lib/domain/models/User.js index ddadfc35009..d82f7183143 100644 --- a/api/lib/domain/models/User.js +++ b/api/lib/domain/models/User.js @@ -1,10 +1,12 @@ -const toLower = require('lodash/toLower'); -const isNil = require('lodash/isNil'); -const dayjs = require('dayjs'); +import lodash from 'lodash'; -const config = require('../../config.js'); -const localeService = require('../services/locale-service'); -const AuthenticationMethod = require('./AuthenticationMethod.js'); +const { toLower, isNil } = lodash; + +import dayjs from 'dayjs'; + +import { config } from '../../config.js'; +import * as localeService from '../services/locale-service.js'; +import { AuthenticationMethod } from './AuthenticationMethod.js'; class User { constructor( @@ -126,4 +128,4 @@ class User { } } -module.exports = User; +export { User }; diff --git a/api/lib/domain/models/UserCompetence.js b/api/lib/domain/models/UserCompetence.js index 225fa03600a..aba8b8b158b 100644 --- a/api/lib/domain/models/UserCompetence.js +++ b/api/lib/domain/models/UserCompetence.js @@ -1,6 +1,6 @@ -const { MINIMUM_COMPETENCE_LEVEL_FOR_CERTIFIABILITY } = require('../constants.js'); +import { MINIMUM_COMPETENCE_LEVEL_FOR_CERTIFIABILITY } from '../constants.js'; -const _ = require('lodash'); +import _ from 'lodash'; class UserCompetence { constructor({ id, index, name, areaId, pixScore, estimatedLevel, skills = [] } = {}) { @@ -33,4 +33,4 @@ class UserCompetence { } } -module.exports = UserCompetence; +export { UserCompetence }; diff --git a/api/lib/domain/models/UserDetailsForAdmin.js b/api/lib/domain/models/UserDetailsForAdmin.js index 4f78a230c9e..487aed89bd2 100644 --- a/api/lib/domain/models/UserDetailsForAdmin.js +++ b/api/lib/domain/models/UserDetailsForAdmin.js @@ -1,4 +1,4 @@ -const localeService = require('../services/locale-service'); +import * as localeService from '../services/locale-service.js'; class UserDetailsForAdmin { constructor( @@ -65,4 +65,4 @@ class UserDetailsForAdmin { } } -module.exports = UserDetailsForAdmin; +export { UserDetailsForAdmin }; diff --git a/api/lib/domain/models/UserLogin.js b/api/lib/domain/models/UserLogin.js index 44140fee92a..b494ce0da77 100644 --- a/api/lib/domain/models/UserLogin.js +++ b/api/lib/domain/models/UserLogin.js @@ -1,4 +1,4 @@ -const settings = require('../../config.js'); +import { config } from '../../config.js'; class UserLogin { constructor({ id, userId, failureCount = 0, temporaryBlockedUntil, blockedAt, createdAt, updatedAt } = {}) { @@ -26,12 +26,12 @@ class UserLogin { } shouldMarkUserAsTemporarilyBlocked() { - return this.failureCount % settings.login.temporaryBlockingThresholdFailureCount === 0; + return this.failureCount % config.login.temporaryBlockingThresholdFailureCount === 0; } markUserAsTemporarilyBlocked() { - const commonRatio = Math.pow(2, this.failureCount / settings.login.temporaryBlockingThresholdFailureCount - 1); - this.temporaryBlockedUntil = new Date(Date.now() + settings.login.temporaryBlockingBaseTimeMs * commonRatio); + const commonRatio = Math.pow(2, this.failureCount / config.login.temporaryBlockingThresholdFailureCount - 1); + this.temporaryBlockedUntil = new Date(Date.now() + config.login.temporaryBlockingBaseTimeMs * commonRatio); } hasFailedAtLeastOnce() { @@ -39,7 +39,7 @@ class UserLogin { } shouldMarkUserAsBlocked() { - return this.failureCount >= settings.login.blockingLimitFailureCount; + return this.failureCount >= config.login.blockingLimitFailureCount; } markUserAsBlocked() { @@ -57,4 +57,4 @@ class UserLogin { } } -module.exports = UserLogin; +export { UserLogin }; diff --git a/api/lib/domain/models/UserOrgaSettings.js b/api/lib/domain/models/UserOrgaSettings.js index 33abb66c1ef..3ee81c274df 100644 --- a/api/lib/domain/models/UserOrgaSettings.js +++ b/api/lib/domain/models/UserOrgaSettings.js @@ -6,4 +6,4 @@ class UserOrgaSettings { } } -module.exports = UserOrgaSettings; +export { UserOrgaSettings }; diff --git a/api/lib/domain/models/UserSavedTutorial.js b/api/lib/domain/models/UserSavedTutorial.js index 15b9388c136..071fdf969f4 100644 --- a/api/lib/domain/models/UserSavedTutorial.js +++ b/api/lib/domain/models/UserSavedTutorial.js @@ -8,4 +8,4 @@ class UserSavedTutorial { } } -module.exports = UserSavedTutorial; +export { UserSavedTutorial }; diff --git a/api/lib/domain/models/UserSavedTutorialWithTutorial.js b/api/lib/domain/models/UserSavedTutorialWithTutorial.js index 46db3255e11..79023e226a7 100644 --- a/api/lib/domain/models/UserSavedTutorialWithTutorial.js +++ b/api/lib/domain/models/UserSavedTutorialWithTutorial.js @@ -7,4 +7,4 @@ class UserSavedTutorialWithTutorial { } } -module.exports = UserSavedTutorialWithTutorial; +export { UserSavedTutorialWithTutorial }; diff --git a/api/lib/domain/models/UserToCreate.js b/api/lib/domain/models/UserToCreate.js index 979e06a744c..4208ffb7de8 100644 --- a/api/lib/domain/models/UserToCreate.js +++ b/api/lib/domain/models/UserToCreate.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const localeService = require('../services/locale-service'); +import _ from 'lodash'; +import * as localeService from '../services/locale-service.js'; class UserToCreate { constructor({ @@ -75,4 +75,4 @@ class UserToCreate { } } -module.exports = UserToCreate; +export { UserToCreate }; diff --git a/api/lib/domain/models/Validation.js b/api/lib/domain/models/Validation.js index b571e76f737..12d7cf7ded2 100644 --- a/api/lib/domain/models/Validation.js +++ b/api/lib/domain/models/Validation.js @@ -10,4 +10,4 @@ class Validation { } } -module.exports = Validation; +export { Validation }; diff --git a/api/lib/domain/models/Validator.js b/api/lib/domain/models/Validator.js index 4ee2763e529..51786ccd09b 100644 --- a/api/lib/domain/models/Validator.js +++ b/api/lib/domain/models/Validator.js @@ -1,5 +1,5 @@ -const AnswerStatus = require('./AnswerStatus.js'); -const Validation = require('./Validation.js'); +import { AnswerStatus } from './AnswerStatus.js'; +import { Validation } from './Validation.js'; /** * Traduction: Vérificateur de réponse par défaut @@ -17,4 +17,4 @@ class Validator { } } -module.exports = Validator; +export { Validator }; diff --git a/api/lib/domain/models/ValidatorAlwaysOK.js b/api/lib/domain/models/ValidatorAlwaysOK.js index c42cb83e708..08c4ff7e848 100644 --- a/api/lib/domain/models/ValidatorAlwaysOK.js +++ b/api/lib/domain/models/ValidatorAlwaysOK.js @@ -1,6 +1,6 @@ -const Validation = require('./Validation.js'); -const Validator = require('./Validator.js'); -const AnswerStatus = require('./AnswerStatus.js'); +import { Validation } from './Validation.js'; +import { Validator } from './Validator.js'; +import { AnswerStatus } from './AnswerStatus.js'; class ValidatorAlwaysOK extends Validator { assess() { @@ -11,4 +11,4 @@ class ValidatorAlwaysOK extends Validator { } } -module.exports = ValidatorAlwaysOK; +export { ValidatorAlwaysOK }; diff --git a/api/lib/domain/models/ValidatorQCM.js b/api/lib/domain/models/ValidatorQCM.js index 004fa5de650..92e5df70863 100644 --- a/api/lib/domain/models/ValidatorQCM.js +++ b/api/lib/domain/models/ValidatorQCM.js @@ -1,6 +1,6 @@ -const solutionServiceQCM = require('../services/solution-service-qcm.js'); -const Validation = require('./Validation.js'); -const Validator = require('./Validator.js'); +import * as solutionServiceQCM from '../services/solution-service-qcm.js'; +import { Validation } from './Validation.js'; +import { Validator } from './Validator.js'; /** * Traduction: Vérificateur de réponse pour un QCM @@ -21,4 +21,4 @@ class ValidatorQCM extends Validator { } } -module.exports = ValidatorQCM; +export { ValidatorQCM }; diff --git a/api/lib/domain/models/ValidatorQCU.js b/api/lib/domain/models/ValidatorQCU.js index d175b4b6df2..f7c7d7fbbaa 100644 --- a/api/lib/domain/models/ValidatorQCU.js +++ b/api/lib/domain/models/ValidatorQCU.js @@ -1,6 +1,6 @@ -const solutionServiceQCU = require('../services/solution-service-qcu.js'); -const Validation = require('./Validation.js'); -const Validator = require('./Validator.js'); +import * as solutionServiceQCU from '../services/solution-service-qcu.js'; +import { Validation } from './Validation.js'; +import { Validator } from './Validator.js'; /** * Traduction: Vérificateur de réponse pour un QCU @@ -21,4 +21,4 @@ class ValidatorQCU extends Validator { } } -module.exports = ValidatorQCU; +export { ValidatorQCU }; diff --git a/api/lib/domain/models/ValidatorQROC.js b/api/lib/domain/models/ValidatorQROC.js index 93a1579822c..a7087a03486 100644 --- a/api/lib/domain/models/ValidatorQROC.js +++ b/api/lib/domain/models/ValidatorQROC.js @@ -1,17 +1,23 @@ -const solutionServiceQROC = require('../services/solution-service-qroc.js'); -const Validation = require('./Validation.js'); -const Validator = require('./Validator.js'); +import * as solutionServiceQROC from '../services/solution-service-qroc.js'; +import { Validation } from './Validation.js'; +import { Validator } from './Validator.js'; /** * Traduction: Vérificateur de réponse pour un QROC */ class ValidatorQROC extends Validator { - constructor({ solution } = {}) { + injectedSolutionServiceQROC; + constructor({ solution } = {}, injectedSolutionServiceQROC = solutionServiceQROC) { super({ solution }); + this.injectedSolutionServiceQROC = injectedSolutionServiceQROC; } assess({ answer, challengeFormat }) { - const result = solutionServiceQROC.match({ answer: answer.value, solution: this.solution, challengeFormat }); + const result = this.injectedSolutionServiceQROC.match({ + answer: answer.value, + solution: this.solution, + challengeFormat, + }); return new Validation({ result, @@ -20,4 +26,4 @@ class ValidatorQROC extends Validator { } } -module.exports = ValidatorQROC; +export { ValidatorQROC }; diff --git a/api/lib/domain/models/ValidatorQROCMDep.js b/api/lib/domain/models/ValidatorQROCMDep.js index b8af3f5629d..631cee09718 100644 --- a/api/lib/domain/models/ValidatorQROCMDep.js +++ b/api/lib/domain/models/ValidatorQROCMDep.js @@ -1,6 +1,6 @@ -const solutionServiceQROCMDep = require('../services/solution-service-qrocm-dep.js'); -const Validation = require('./Validation.js'); -const Validator = require('./Validator.js'); +import * as solutionServiceQROCMDep from '../services/solution-service-qrocm-dep.js'; +import { Validation } from './Validation.js'; +import { Validator } from './Validator.js'; /** * Traduction: Vérificateur de réponse pour un QROCM Dep @@ -24,4 +24,4 @@ class ValidatorQROCMDep extends Validator { } } -module.exports = ValidatorQROCMDep; +export { ValidatorQROCMDep }; diff --git a/api/lib/domain/models/ValidatorQROCMInd.js b/api/lib/domain/models/ValidatorQROCMInd.js index 9ec929c8301..32f4c9f6468 100644 --- a/api/lib/domain/models/ValidatorQROCMInd.js +++ b/api/lib/domain/models/ValidatorQROCMInd.js @@ -1,6 +1,6 @@ -const solutionServiceQROCMInd = require('../services/solution-service-qrocm-ind.js'); -const Validation = require('./Validation.js'); -const Validator = require('./Validator.js'); +import * as solutionServiceQROCMInd from '../services/solution-service-qrocm-ind.js'; +import { Validation } from './Validation.js'; +import { Validator } from './Validator.js'; /** * Traduction: Vérificateur de réponse pour un QROCM Ind @@ -24,4 +24,4 @@ class ValidatorQROCMInd extends Validator { } } -module.exports = ValidatorQROCMInd; +export { ValidatorQROCMInd }; diff --git a/api/lib/domain/models/index.js b/api/lib/domain/models/index.js index f9a76601b56..57e160b401b 100644 --- a/api/lib/domain/models/index.js +++ b/api/lib/domain/models/index.js @@ -1,175 +1,155 @@ -// the following list of imports has been generated by the commented code -// const fs = require('fs'); -// const path = require('path'); -// -// fs.readdir(__dirname, { withFileTypes: true }, (err, dirents) => { -// dirents.forEach((dirent) => { -// if (!dirent.isFile() || dirent.name === 'index.js') return; -// const filePath = dirent.name; -// const fileName = path.basename(dirent.name, '.js'); -// console.log(`const ${fileName} = require('./${filePath}');`); -// }); -// -// console.log(`module.exports = {`); -// dirents.forEach((dirent) => { -// if (!dirent.isFile() || dirent.name === 'index.js') return; -// const fileName = path.basename(dirent.name, '.js'); -// console.log(`${fileName},`); -// }); -// console.log(`}`); -// }); -const AccountRecoveryDemand = require('./AccountRecoveryDemand.js'); -const AdminMember = require('./AdminMember.js'); -const Answer = require('./Answer.js'); -const AnswerCollectionForScoring = require('./AnswerCollectionForScoring.js'); -const AnswerStatus = require('./AnswerStatus.js'); -const Area = require('./Area.js'); -const Assessment = require('./Assessment.js'); -const FlashAssessmentAlgorithm = require('./FlashAssessmentAlgorithm.js'); -const AssessmentResult = require('./AssessmentResult.js'); -const Authentication = require('./Authentication.js'); -const AuthenticationMethod = require('./AuthenticationMethod.js'); -const AuthenticationSessionContent = require('./AuthenticationSessionContent.js'); -const Badge = require('./Badge.js'); -const BadgeAcquisition = require('./BadgeAcquisition.js'); -const BadgeCriterion = require('./BadgeCriterion.js'); -const BadgeDetails = require('./BadgeDetails.js'); -const BadgeForCalculation = require('./BadgeForCalculation.js'); -const Campaign = require('./Campaign.js'); -const CampaignCreator = require('./CampaignCreator.js'); -const CampaignForArchiving = require('./CampaignForArchiving.js'); -const CampaignForCreation = require('./CampaignForCreation.js'); -const CampaignLearningContent = require('./CampaignLearningContent.js'); -const CampaignParticipant = require('./CampaignParticipant.js'); -const CampaignParticipation = require('./CampaignParticipation.js'); -const CampaignParticipationBadge = require('./CampaignParticipationBadge.js'); -const CampaignParticipationResult = require('./CampaignParticipationResult.js'); -const CampaignParticipationStatuses = require('./CampaignParticipationStatuses.js'); -const CampaignToStartParticipation = require('./CampaignToStartParticipation.js'); -const CampaignTypes = require('./CampaignTypes.js'); -const CertifiableBadgeAcquisition = require('./CertifiableBadgeAcquisition.js'); -const CertifiableProfileForLearningContent = require('./CertifiableProfileForLearningContent.js'); -const CertificationAnswerStatusChangeAttempt = require('./CertificationAnswerStatusChangeAttempt.js'); -const CertificationAssessment = require('./CertificationAssessment.js'); -const CertificationAssessmentScore = require('./CertificationAssessmentScore.js'); -const CertificationAttestation = require('./CertificationAttestation.js'); -const CertificationCandidate = require('./CertificationCandidate.js'); -const CertificationCandidateForSupervising = require('./CertificationCandidateForSupervising.js'); -const CertificationCenter = require('./CertificationCenter.js'); -const CertificationCenterForAdmin = require('./CertificationCenterForAdmin.js'); -const CertificationCenterInvitation = require('./CertificationCenterInvitation.js'); -const CertificationCenterInvitedUser = require('./CertificationCenterInvitedUser.js'); -const CertificationCenterMembership = require('./CertificationCenterMembership.js'); -const CertificationChallenge = require('./CertificationChallenge.js'); -const CertificationChallengeWithType = require('./CertificationChallengeWithType.js'); -const CertificationContract = require('./CertificationContract.js'); -const CertificationCourse = require('./CertificationCourse.js'); -const CertificationCpfCity = require('./CertificationCpfCity.js'); -const CertificationCpfCountry = require('./CertificationCpfCountry.js'); -const CertificationIssueReport = require('./CertificationIssueReport.js'); -const CertificationIssueReportCategory = require('./CertificationIssueReportCategory.js'); -const CertificationIssueReportResolutionAttempt = require('./CertificationIssueReportResolutionAttempt.js'); -const CertificationIssueReportResolutionStrategies = require('./CertificationIssueReportResolutionStrategies.js'); -const CertificationOfficer = require('./CertificationOfficer.js'); -const CertificationReport = require('./CertificationReport.js'); -const CertificationResult = require('./CertificationResult.js'); -const CertifiedLevel = require('./CertifiedLevel.js'); -const CertifiedScore = require('./CertifiedScore.js'); -const Challenge = require('./Challenge.js'); -const Competence = require('./Competence.js'); -const CompetenceEvaluation = require('./CompetenceEvaluation.js'); -const CompetenceMark = require('./CompetenceMark.js'); -const CompetenceResult = require('./CompetenceResult.js'); -const CompetenceTree = require('./CompetenceTree.js'); -const ComplementaryCertification = require('./ComplementaryCertification.js'); -const ComplementaryCertificationCourse = require('./ComplementaryCertificationCourse.js'); -const ComplementaryCertificationCourseResult = require('./ComplementaryCertificationCourseResult.js'); -const ComplementaryCertificationHabilitation = require('./ComplementaryCertificationHabilitation.js'); -const ComplementaryCertificationScoringCriteria = require('./ComplementaryCertificationScoringCriteria.js'); -const ComplementaryCertificationScoringWithComplementaryReferential = require('./ComplementaryCertificationScoringWithComplementaryReferential.js'); -const ComplementaryCertificationScoringWithoutComplementaryReferential = require('./ComplementaryCertificationScoringWithoutComplementaryReferential.js'); -const Correction = require('./Correction.js'); -const Course = require('./Course.js'); -const DataProtectionOfficer = require('./DataProtectionOfficer.js'); -const Division = require('./Division.js'); -const EmailModificationDemand = require('./EmailModificationDemand.js'); -const EmailingAttempt = require('./EmailingAttempt.js'); -const Examiner = require('./Examiner.js'); -const FinalizedSession = require('./FinalizedSession.js'); -const Framework = require('./Framework.js'); -const Group = require('./Group.js'); -const Hint = require('./Hint.js'); -const JuryCertification = require('./JuryCertification.js'); -const JurySession = require('./JurySession.js'); -const KnowledgeElement = require('./KnowledgeElement.js'); -const LearningContent = require('./LearningContent.js'); -const Membership = require('./Membership.js'); -const NeutralizationAttempt = require('./NeutralizationAttempt.js'); -const Organization = require('./Organization.js'); -const OrganizationForAdmin = require('./organizations-administration/Organization.js'); -const OrganizationInvitation = require('./OrganizationInvitation.js'); -const OrganizationInvitedUser = require('./OrganizationInvitedUser.js'); -const OrganizationLearner = require('./OrganizationLearner.js'); -const OrganizationMemberIdentity = require('./OrganizationMemberIdentity.js'); -const OrganizationPlacesLot = require('./OrganizationPlacesLot.js'); -const OrganizationTag = require('./OrganizationTag.js'); -const OrganizationsToAttachToTargetProfile = require('./OrganizationsToAttachToTargetProfile.js'); -const ParticipantResultsShared = require('./ParticipantResultsShared.js'); -const ParticipationForCampaignManagement = require('./ParticipationForCampaignManagement.js'); -const PartnerCertificationScoring = require('./PartnerCertificationScoring.js'); -const PlacementProfile = require('./PlacementProfile.js'); -const PoleEmploiSending = require('./PoleEmploiSending.js'); -const PrivateCertificate = require('./PrivateCertificate.js'); -const Progression = require('./Progression.js'); -const ReproducibilityRate = require('./ReproducibilityRate.js'); -const ResultCompetence = require('./ResultCompetence.js'); -const ResultCompetenceTree = require('./ResultCompetenceTree.js'); -const SCOCertificationCandidate = require('./SCOCertificationCandidate.js'); -const Scorecard = require('./Scorecard.js'); -const ScoringSimulation = require('./ScoringSimulation.js'); -const ScoringSimulationContext = require('./ScoringSimulationContext.js'); -const ScoringSimulationDataset = require('./ScoringSimulationDataset.js'); -const ScoringSimulationResult = require('./ScoringSimulationResult.js'); -const Session = require('./Session.js'); -const SessionJuryComment = require('./SessionJuryComment.js'); -const SessionPublicationBatchResult = require('./SessionPublicationBatchResult.js'); -const ShareableCertificate = require('./ShareableCertificate.js'); -const Skill = require('./Skill.js'); -const SkillSet = require('./SkillSet.js'); -const Solution = require('./Solution.js'); -const Stage = require('./Stage.js'); -const Student = require('./Student.js'); -const SupOrganizationLearner = require('./SupOrganizationLearner.js'); -const SupOrganizationLearnerSet = require('./SupOrganizationLearnerSet.js'); -const Tag = require('./Tag.js'); -const TargetProfile = require('./TargetProfile.js'); -const TargetProfileForAdmin = require('./TargetProfileForAdmin.js'); -const TargetProfileForCreation = require('./TargetProfileForCreation.js'); -const TargetProfileSummaryForAdmin = require('./TargetProfileSummaryForAdmin.js'); -const Thematic = require('./Thematic.js'); -const Training = require('./Training.js'); -const TrainingTrigger = require('./TrainingTrigger.js'); -const TrainingTriggerTube = require('./TrainingTriggerTube.js'); -const Tube = require('./Tube.js'); -const Tutorial = require('./Tutorial.js'); -const TutorialEvaluation = require('./TutorialEvaluation.js'); -const User = require('./User.js'); -const UserCompetence = require('./UserCompetence.js'); -const UserDetailsForAdmin = require('./UserDetailsForAdmin.js'); -const UserLogin = require('./UserLogin.js'); -const UserOrgaSettings = require('./UserOrgaSettings.js'); -const UserSavedTutorial = require('./UserSavedTutorial.js'); -const UserSavedTutorialWithTutorial = require('./UserSavedTutorialWithTutorial.js'); -const UserToCreate = require('./UserToCreate.js'); -const Validation = require('./Validation.js'); -const Validator = require('./Validator.js'); -const ValidatorAlwaysOK = require('./ValidatorAlwaysOK.js'); -const ValidatorQCM = require('./ValidatorQCM.js'); -const ValidatorQCU = require('./ValidatorQCU.js'); -const ValidatorQROC = require('./ValidatorQROC.js'); -const ValidatorQROCMDep = require('./ValidatorQROCMDep.js'); -const ValidatorQROCMInd = require('./ValidatorQROCMInd.js'); -module.exports = { +import { AccountRecoveryDemand } from './AccountRecoveryDemand.js'; +import { AdminMember } from './AdminMember.js'; +import { Answer } from './Answer.js'; +import { AnswerCollectionForScoring } from './AnswerCollectionForScoring.js'; +import { AnswerStatus } from './AnswerStatus.js'; +import { Area } from './Area.js'; +import { Assessment } from './Assessment.js'; +import { FlashAssessmentAlgorithm } from './FlashAssessmentAlgorithm.js'; +import { AssessmentResult } from './AssessmentResult.js'; +import { Authentication } from './Authentication.js'; +import { AuthenticationMethod } from './AuthenticationMethod.js'; +import { AuthenticationSessionContent } from './AuthenticationSessionContent.js'; +import { Badge } from './Badge.js'; +import { BadgeAcquisition } from './BadgeAcquisition.js'; +import { BadgeCriterion } from './BadgeCriterion.js'; +import { BadgeDetails } from './BadgeDetails.js'; +import { BadgeForCalculation } from './BadgeForCalculation.js'; +import { Campaign } from './Campaign.js'; +import { CampaignCreator } from './CampaignCreator.js'; +import { CampaignForArchiving } from './CampaignForArchiving.js'; +import { CampaignForCreation } from './CampaignForCreation.js'; +import { CampaignLearningContent } from './CampaignLearningContent.js'; +import { CampaignParticipant } from './CampaignParticipant.js'; +import { CampaignParticipation } from './CampaignParticipation.js'; +import { CampaignParticipationBadge } from './CampaignParticipationBadge.js'; +import { CampaignParticipationResult } from './CampaignParticipationResult.js'; +import { CampaignParticipationStatuses } from './CampaignParticipationStatuses.js'; +import { CampaignToStartParticipation } from './CampaignToStartParticipation.js'; +import { CampaignTypes } from './CampaignTypes.js'; +import { CertifiableBadgeAcquisition } from './CertifiableBadgeAcquisition.js'; +import { CertifiableProfileForLearningContent } from './CertifiableProfileForLearningContent.js'; +import { CertificationAnswerStatusChangeAttempt } from './CertificationAnswerStatusChangeAttempt.js'; +import { CertificationAssessment } from './CertificationAssessment.js'; +import { CertificationAssessmentScore } from './CertificationAssessmentScore.js'; +import { CertificationAttestation } from './CertificationAttestation.js'; +import { CertificationCandidate } from './CertificationCandidate.js'; +import { CertificationCandidateForSupervising } from './CertificationCandidateForSupervising.js'; +import { CertificationCenter } from './CertificationCenter.js'; +import { CertificationCenterForAdmin } from './CertificationCenterForAdmin.js'; +import { CertificationCenterInvitation } from './CertificationCenterInvitation.js'; +import { CertificationCenterInvitedUser } from './CertificationCenterInvitedUser.js'; +import { CertificationCenterMembership } from './CertificationCenterMembership.js'; +import { CertificationChallenge } from './CertificationChallenge.js'; +import { CertificationChallengeWithType } from './CertificationChallengeWithType.js'; +import { CertificationContract } from './CertificationContract.js'; +import { CertificationCourse } from './CertificationCourse.js'; +import { CertificationCpfCity } from './CertificationCpfCity.js'; +import { CertificationCpfCountry } from './CertificationCpfCountry.js'; +import { CertificationIssueReport } from './CertificationIssueReport.js'; +import { CertificationIssueReportCategory } from './CertificationIssueReportCategory.js'; +import { CertificationIssueReportResolutionAttempt } from './CertificationIssueReportResolutionAttempt.js'; +import { CertificationIssueReportResolutionStrategies } from './CertificationIssueReportResolutionStrategies.js'; +import { CertificationOfficer } from './CertificationOfficer.js'; +import { CertificationReport } from './CertificationReport.js'; +import { CertificationResult } from './CertificationResult.js'; +import { CertifiedLevel } from './CertifiedLevel.js'; +import { CertifiedScore } from './CertifiedScore.js'; +import { Challenge } from './Challenge.js'; +import { Competence } from './Competence.js'; +import { CompetenceEvaluation } from './CompetenceEvaluation.js'; +import { CompetenceMark } from './CompetenceMark.js'; +import { CompetenceResult } from './CompetenceResult.js'; +import { CompetenceTree } from './CompetenceTree.js'; +import { ComplementaryCertification } from './ComplementaryCertification.js'; +import { ComplementaryCertificationCourse } from './ComplementaryCertificationCourse.js'; +import { ComplementaryCertificationCourseResult } from './ComplementaryCertificationCourseResult.js'; +import { ComplementaryCertificationHabilitation } from './ComplementaryCertificationHabilitation.js'; +import { ComplementaryCertificationScoringCriteria } from './ComplementaryCertificationScoringCriteria.js'; +import { ComplementaryCertificationScoringWithComplementaryReferential } from './ComplementaryCertificationScoringWithComplementaryReferential.js'; +import { ComplementaryCertificationScoringWithoutComplementaryReferential } from './ComplementaryCertificationScoringWithoutComplementaryReferential.js'; +import { Correction } from './Correction.js'; +import { Course } from './Course.js'; +import { DataProtectionOfficer } from './DataProtectionOfficer.js'; +import { Division } from './Division.js'; +import { EmailModificationDemand } from './EmailModificationDemand.js'; +import { EmailingAttempt } from './EmailingAttempt.js'; +import { Examiner } from './Examiner.js'; +import { FinalizedSession } from './FinalizedSession.js'; +import { Framework } from './Framework.js'; +import { Group } from './Group.js'; +import { Hint } from './Hint.js'; +import { JuryCertification } from './JuryCertification.js'; +import { JurySession } from './JurySession.js'; +import { KnowledgeElement } from './KnowledgeElement.js'; +import { LearningContent } from './LearningContent.js'; +import { Membership } from './Membership.js'; +import { NeutralizationAttempt } from './NeutralizationAttempt.js'; +import { Organization } from './Organization.js'; +import { OrganizationForAdmin } from './organizations-administration/Organization.js'; +import { OrganizationInvitation } from './OrganizationInvitation.js'; +import { OrganizationInvitedUser } from './OrganizationInvitedUser.js'; +import { OrganizationLearner } from './OrganizationLearner.js'; +import { OrganizationMemberIdentity } from './OrganizationMemberIdentity.js'; +import { OrganizationPlacesLot } from './OrganizationPlacesLot.js'; +import { OrganizationTag } from './OrganizationTag.js'; +import { OrganizationsToAttachToTargetProfile } from './OrganizationsToAttachToTargetProfile.js'; +import { ParticipantResultsShared } from './ParticipantResultsShared.js'; +import { ParticipationForCampaignManagement } from './ParticipationForCampaignManagement.js'; +import { PartnerCertificationScoring } from './PartnerCertificationScoring.js'; +import { PlacementProfile } from './PlacementProfile.js'; +import { PoleEmploiSending } from './PoleEmploiSending.js'; +import { PrivateCertificate } from './PrivateCertificate.js'; +import { Progression } from './Progression.js'; +import { ReproducibilityRate } from './ReproducibilityRate.js'; +import { ResultCompetence } from './ResultCompetence.js'; +import { ResultCompetenceTree } from './ResultCompetenceTree.js'; +import { SCOCertificationCandidate } from './SCOCertificationCandidate.js'; +import { Scorecard } from './Scorecard.js'; +import { ScoringSimulation } from './ScoringSimulation.js'; +import { ScoringSimulationContext } from './ScoringSimulationContext.js'; +import { ScoringSimulationDataset } from './ScoringSimulationDataset.js'; +import { ScoringSimulationResult } from './ScoringSimulationResult.js'; +import { Session } from './Session.js'; +import { SessionJuryComment } from './SessionJuryComment.js'; +import { SessionPublicationBatchResult } from './SessionPublicationBatchResult.js'; +import { ShareableCertificate } from './ShareableCertificate.js'; +import { Skill } from './Skill.js'; +import { SkillSet } from './SkillSet.js'; +import { Solution } from './Solution.js'; +import { Stage } from './Stage.js'; +import { Student } from './Student.js'; +import { SupOrganizationLearner } from './SupOrganizationLearner.js'; +import { SupOrganizationLearnerSet } from './SupOrganizationLearnerSet.js'; +import { Tag } from './Tag.js'; +import { TargetProfile } from './TargetProfile.js'; +import { TargetProfileForAdmin } from './TargetProfileForAdmin.js'; +import { TargetProfileForCreation } from './TargetProfileForCreation.js'; +import { TargetProfileSummaryForAdmin } from './TargetProfileSummaryForAdmin.js'; +import { Thematic } from './Thematic.js'; +import { Training } from './Training.js'; +import { TrainingTrigger } from './TrainingTrigger.js'; +import { TrainingTriggerTube } from './TrainingTriggerTube.js'; +import { Tube } from './Tube.js'; +import { Tutorial } from './Tutorial.js'; +import { TutorialEvaluation } from './TutorialEvaluation.js'; +import { User } from './User.js'; +import { UserCompetence } from './UserCompetence.js'; +import { UserDetailsForAdmin } from './UserDetailsForAdmin.js'; +import { UserLogin } from './UserLogin.js'; +import { UserOrgaSettings } from './UserOrgaSettings.js'; +import { UserSavedTutorial } from './UserSavedTutorial.js'; +import { UserSavedTutorialWithTutorial } from './UserSavedTutorialWithTutorial.js'; +import { UserToCreate } from './UserToCreate.js'; +import { Validation } from './Validation.js'; +import { Validator } from './Validator.js'; +import { ValidatorAlwaysOK } from './ValidatorAlwaysOK.js'; +import { ValidatorQCM } from './ValidatorQCM.js'; +import { ValidatorQCU } from './ValidatorQCU.js'; +import { ValidatorQROC } from './ValidatorQROC.js'; +import { ValidatorQROCMDep } from './ValidatorQROCMDep.js'; +import { ValidatorQROCMInd } from './ValidatorQROCMInd.js'; +export { AccountRecoveryDemand, AdminMember, Answer, diff --git a/api/lib/domain/models/organizations-administration/Organization.js b/api/lib/domain/models/organizations-administration/Organization.js index 2d658e68205..db91de906a1 100644 --- a/api/lib/domain/models/organizations-administration/Organization.js +++ b/api/lib/domain/models/organizations-administration/Organization.js @@ -66,4 +66,4 @@ class OrganizationForAdmin { } } -module.exports = OrganizationForAdmin; +export { OrganizationForAdmin }; diff --git a/api/lib/domain/models/target-profile-management/StageCollection.js b/api/lib/domain/models/target-profile-management/StageCollection.js index 9bd138b8222..10ea5cf50e3 100644 --- a/api/lib/domain/models/target-profile-management/StageCollection.js +++ b/api/lib/domain/models/target-profile-management/StageCollection.js @@ -49,4 +49,4 @@ class StageCollection { } } -module.exports = StageCollection; +export { StageCollection }; diff --git a/api/lib/domain/models/target-profile-management/StageCollectionUpdate.js b/api/lib/domain/models/target-profile-management/StageCollectionUpdate.js index c7cce3c547c..7b3714c0d08 100644 --- a/api/lib/domain/models/target-profile-management/StageCollectionUpdate.js +++ b/api/lib/domain/models/target-profile-management/StageCollectionUpdate.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const { InvalidStageError } = require('../../errors.js'); +import _ from 'lodash'; +import { InvalidStageError } from '../../errors.js'; const DEFAULT_VALUE_FIRST_SKILL = -1; @@ -142,4 +142,4 @@ function _checkTargetProfileIds(stagesDTO, stageCollection) { } } -module.exports = StageCollectionUpdate; +export { StageCollectionUpdate }; diff --git a/api/lib/domain/models/user-campaign-results/StageCollection.js b/api/lib/domain/models/user-campaign-results/StageCollection.js index 6c7154c5b09..a2680a62ef6 100644 --- a/api/lib/domain/models/user-campaign-results/StageCollection.js +++ b/api/lib/domain/models/user-campaign-results/StageCollection.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; class StageCollection { constructor({ campaignId, stages }) { @@ -184,4 +184,4 @@ class StageCollection { } } -module.exports = StageCollection; +export { StageCollection }; diff --git a/api/lib/domain/read-models/AllowedCertificationCenterAccess.js b/api/lib/domain/read-models/AllowedCertificationCenterAccess.js index f532a852f5c..adf18017999 100644 --- a/api/lib/domain/read-models/AllowedCertificationCenterAccess.js +++ b/api/lib/domain/read-models/AllowedCertificationCenterAccess.js @@ -1,5 +1,5 @@ -const { features } = require('../../config.js'); - +import { config } from '../../config.js'; +const { features } = config; class AllowedCertificationCenterAccess { constructor({ id, @@ -79,4 +79,4 @@ class AllowedCertificationCenterAccess { } } -module.exports = AllowedCertificationCenterAccess; +export { AllowedCertificationCenterAccess }; diff --git a/api/lib/domain/read-models/CampaignAnalysis.js b/api/lib/domain/read-models/CampaignAnalysis.js index 4d8df9e9327..8bb072fb45c 100644 --- a/api/lib/domain/read-models/CampaignAnalysis.js +++ b/api/lib/domain/read-models/CampaignAnalysis.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const recommendationService = require('../services/recommendation-service.js'); +import _ from 'lodash'; +import * as recommendationService from '../services/recommendation-service.js'; class CampaignAnalysis { constructor({ campaignId, campaignLearningContent, tutorials, participantCount = 0 } = {}) { @@ -92,4 +92,4 @@ class CampaignTubeRecommendation { } } -module.exports = CampaignAnalysis; +export { CampaignAnalysis }; diff --git a/api/lib/domain/read-models/CampaignAssessmentParticipation.js b/api/lib/domain/read-models/CampaignAssessmentParticipation.js index e26ae9376ef..4b1270c0364 100644 --- a/api/lib/domain/read-models/CampaignAssessmentParticipation.js +++ b/api/lib/domain/read-models/CampaignAssessmentParticipation.js @@ -1,6 +1,6 @@ -const Assessment = require('../models/Assessment.js'); -const CampaignParticipationStatuses = require('../models/CampaignParticipationStatuses.js'); -const _ = require('lodash'); +import { Assessment } from '../models/Assessment.js'; +import { CampaignParticipationStatuses } from '../models/CampaignParticipationStatuses.js'; +import _ from 'lodash'; const { SHARED } = CampaignParticipationStatuses; @@ -64,4 +64,4 @@ class CampaignAssessmentParticipation { } } -module.exports = CampaignAssessmentParticipation; +export { CampaignAssessmentParticipation }; diff --git a/api/lib/domain/read-models/CampaignAssessmentParticipationCompetenceResult.js b/api/lib/domain/read-models/CampaignAssessmentParticipationCompetenceResult.js index 60ca2681d3a..f07915417d3 100644 --- a/api/lib/domain/read-models/CampaignAssessmentParticipationCompetenceResult.js +++ b/api/lib/domain/read-models/CampaignAssessmentParticipationCompetenceResult.js @@ -14,4 +14,4 @@ class CampaignAssessmentParticipationCompetenceResult { } } -module.exports = CampaignAssessmentParticipationCompetenceResult; +export { CampaignAssessmentParticipationCompetenceResult }; diff --git a/api/lib/domain/read-models/CampaignAssessmentParticipationResult.js b/api/lib/domain/read-models/CampaignAssessmentParticipationResult.js index 13b9437d40d..dfc447d06af 100644 --- a/api/lib/domain/read-models/CampaignAssessmentParticipationResult.js +++ b/api/lib/domain/read-models/CampaignAssessmentParticipationResult.js @@ -1,5 +1,5 @@ -const CampaignParticipationStatuses = require('../models/CampaignParticipationStatuses.js'); -const CampaignAssessmentParticipationCompetenceResult = require('./CampaignAssessmentParticipationCompetenceResult.js'); +import { CampaignParticipationStatuses } from '../models/CampaignParticipationStatuses.js'; +import { CampaignAssessmentParticipationCompetenceResult } from './CampaignAssessmentParticipationCompetenceResult.js'; const { SHARED } = CampaignParticipationStatuses; @@ -32,4 +32,4 @@ class CampaignAssessmentParticipationResult { } } -module.exports = CampaignAssessmentParticipationResult; +export { CampaignAssessmentParticipationResult }; diff --git a/api/lib/domain/read-models/CampaignCollectiveResult.js b/api/lib/domain/read-models/CampaignCollectiveResult.js index 930df6419a2..365a2af9d9d 100644 --- a/api/lib/domain/read-models/CampaignCollectiveResult.js +++ b/api/lib/domain/read-models/CampaignCollectiveResult.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; class CampaignCollectiveResult { constructor({ id, campaignLearningContent } = {}) { @@ -54,4 +54,4 @@ class CampaignCompetenceCollectiveResult { } } -module.exports = CampaignCollectiveResult; +export { CampaignCollectiveResult }; diff --git a/api/lib/domain/read-models/CampaignManagement.js b/api/lib/domain/read-models/CampaignManagement.js index 6505f0bb53a..32acc51f138 100644 --- a/api/lib/domain/read-models/CampaignManagement.js +++ b/api/lib/domain/read-models/CampaignManagement.js @@ -63,4 +63,4 @@ class CampaignManagement { } } -module.exports = CampaignManagement; +export { CampaignManagement }; diff --git a/api/lib/domain/read-models/CampaignParticipantActivity.js b/api/lib/domain/read-models/CampaignParticipantActivity.js index a1c7a659fe5..50d8d4c0932 100644 --- a/api/lib/domain/read-models/CampaignParticipantActivity.js +++ b/api/lib/domain/read-models/CampaignParticipantActivity.js @@ -10,4 +10,4 @@ class CampaignParticipantActivity { } } -module.exports = CampaignParticipantActivity; +export { CampaignParticipantActivity }; diff --git a/api/lib/domain/read-models/CampaignParticipationForUserManagement.js b/api/lib/domain/read-models/CampaignParticipationForUserManagement.js index 3b805dc0b2d..8502fabf69f 100644 --- a/api/lib/domain/read-models/CampaignParticipationForUserManagement.js +++ b/api/lib/domain/read-models/CampaignParticipationForUserManagement.js @@ -30,4 +30,4 @@ class CampaignParticipationForUserManagement { } } -module.exports = CampaignParticipationForUserManagement; +export { CampaignParticipationForUserManagement }; diff --git a/api/lib/domain/read-models/CampaignParticipationInfo.js b/api/lib/domain/read-models/CampaignParticipationInfo.js index f8f5e0cefb6..b74f2a1bad6 100644 --- a/api/lib/domain/read-models/CampaignParticipationInfo.js +++ b/api/lib/domain/read-models/CampaignParticipationInfo.js @@ -1,8 +1,8 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { validateEntity } = require('../validators/entity-validator.js'); -const _ = require('lodash'); +import { validateEntity } from '../validators/entity-validator.js'; +import _ from 'lodash'; const validationSchema = Joi.object({ participantFirstName: Joi.string().required().allow(''), @@ -57,4 +57,4 @@ class CampaignParticipationInfo { } } -module.exports = CampaignParticipationInfo; +export { CampaignParticipationInfo }; diff --git a/api/lib/domain/read-models/CampaignParticipationOverview.js b/api/lib/domain/read-models/CampaignParticipationOverview.js index e498a749f70..f60701ee2df 100644 --- a/api/lib/domain/read-models/CampaignParticipationOverview.js +++ b/api/lib/domain/read-models/CampaignParticipationOverview.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const CampaignParticipationStatuses = require('../models/CampaignParticipationStatuses.js'); +import _ from 'lodash'; +import { CampaignParticipationStatuses } from '../models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; @@ -46,4 +46,4 @@ class CampaignParticipationOverview { } } -module.exports = CampaignParticipationOverview; +export { CampaignParticipationOverview }; diff --git a/api/lib/domain/read-models/CampaignProfile.js b/api/lib/domain/read-models/CampaignProfile.js index b153b2b7a87..0e35e18ad4d 100644 --- a/api/lib/domain/read-models/CampaignProfile.js +++ b/api/lib/domain/read-models/CampaignProfile.js @@ -1,5 +1,5 @@ -const CampaignProfileCompetence = require('./CampaignProfileCompetence.js'); -const CampaignParticipationStatuses = require('../models/CampaignParticipationStatuses.js'); +import { CampaignProfileCompetence } from './CampaignProfileCompetence.js'; +import { CampaignParticipationStatuses } from '../models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; @@ -71,4 +71,4 @@ class CampaignProfile { } } -module.exports = CampaignProfile; +export { CampaignProfile }; diff --git a/api/lib/domain/read-models/CampaignProfileCompetence.js b/api/lib/domain/read-models/CampaignProfileCompetence.js index 9aea11bb9d0..f66351bce18 100644 --- a/api/lib/domain/read-models/CampaignProfileCompetence.js +++ b/api/lib/domain/read-models/CampaignProfileCompetence.js @@ -9,4 +9,4 @@ class CampaignProfileCompetence { } } -module.exports = CampaignProfileCompetence; +export { CampaignProfileCompetence }; diff --git a/api/lib/domain/read-models/CampaignProfilesCollectionParticipationSummary.js b/api/lib/domain/read-models/CampaignProfilesCollectionParticipationSummary.js index dab1f6f29a5..304241c7fb8 100644 --- a/api/lib/domain/read-models/CampaignProfilesCollectionParticipationSummary.js +++ b/api/lib/domain/read-models/CampaignProfilesCollectionParticipationSummary.js @@ -20,4 +20,4 @@ class CampaignProfilesCollectionParticipationSummary { } } -module.exports = CampaignProfilesCollectionParticipationSummary; +export { CampaignProfilesCollectionParticipationSummary }; diff --git a/api/lib/domain/read-models/CampaignReport.js b/api/lib/domain/read-models/CampaignReport.js index 53988211292..4b356ac98b9 100644 --- a/api/lib/domain/read-models/CampaignReport.js +++ b/api/lib/domain/read-models/CampaignReport.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const CampaignTypes = require('../models/CampaignTypes.js'); +import _ from 'lodash'; +import { CampaignTypes } from '../models/CampaignTypes.js'; class CampaignReport { constructor({ @@ -97,4 +97,4 @@ class CampaignReport { } } -module.exports = CampaignReport; +export { CampaignReport }; diff --git a/api/lib/domain/read-models/CampaignToJoin.js b/api/lib/domain/read-models/CampaignToJoin.js index b77584080c9..8b97fda50e2 100644 --- a/api/lib/domain/read-models/CampaignToJoin.js +++ b/api/lib/domain/read-models/CampaignToJoin.js @@ -1,5 +1,5 @@ -const Assessment = require('../models/Assessment.js'); -const CampaignTypes = require('../models/CampaignTypes.js'); +import { Assessment } from '../models/Assessment.js'; +import { CampaignTypes } from '../models/CampaignTypes.js'; class CampaignToJoin { constructor({ @@ -75,4 +75,4 @@ class CampaignToJoin { } } -module.exports = CampaignToJoin; +export { CampaignToJoin }; diff --git a/api/lib/domain/read-models/CertificationCandidateForAttendanceSheet.js b/api/lib/domain/read-models/CertificationCandidateForAttendanceSheet.js index db48456b2c3..4af01d1c572 100644 --- a/api/lib/domain/read-models/CertificationCandidateForAttendanceSheet.js +++ b/api/lib/domain/read-models/CertificationCandidateForAttendanceSheet.js @@ -1,4 +1,6 @@ -const isNil = require('lodash/isNil'); +import lodash from 'lodash'; + +const { isNil } = lodash; class CertificationCandidateForAttendanceSheet { constructor({ lastName, firstName, birthdate, externalId, division, extraTimePercentage }) { @@ -11,4 +13,4 @@ class CertificationCandidateForAttendanceSheet { } } -module.exports = CertificationCandidateForAttendanceSheet; +export { CertificationCandidateForAttendanceSheet }; diff --git a/api/lib/domain/read-models/CertificationCandidateSubscription.js b/api/lib/domain/read-models/CertificationCandidateSubscription.js index 8d5510b7b75..24dd4c7542a 100644 --- a/api/lib/domain/read-models/CertificationCandidateSubscription.js +++ b/api/lib/domain/read-models/CertificationCandidateSubscription.js @@ -1,8 +1,10 @@ -module.exports = class CertificationCandidateSubscription { +class CertificationCandidateSubscription { constructor({ id, sessionId, eligibleSubscriptions, nonEligibleSubscriptions }) { this.id = id; this.sessionId = sessionId; this.eligibleSubscriptions = eligibleSubscriptions; this.nonEligibleSubscriptions = nonEligibleSubscriptions; } -}; +} + +export { CertificationCandidateSubscription }; diff --git a/api/lib/domain/read-models/CertificationDetails.js b/api/lib/domain/read-models/CertificationDetails.js index 085dfc8e077..aa6084e63f3 100644 --- a/api/lib/domain/read-models/CertificationDetails.js +++ b/api/lib/domain/read-models/CertificationDetails.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); -const AnswerCollectionForScoring = require('../models/AnswerCollectionForScoring.js'); -const { ReproducibilityRate } = require('../models/ReproducibilityRate.js'); +import _ from 'lodash'; +import { AnswerCollectionForScoring } from '../models/AnswerCollectionForScoring.js'; +import { ReproducibilityRate } from '../models/ReproducibilityRate.js'; class CertificationDetails { constructor({ @@ -150,4 +150,4 @@ function _getCompetenceIndexForChallenge(certificationChallenge, competencesWith return competenceWithMark ? competenceWithMark.index : ''; } -module.exports = CertificationDetails; +export { CertificationDetails }; diff --git a/api/lib/domain/read-models/CertificationEligibility.js b/api/lib/domain/read-models/CertificationEligibility.js index e89ac9521f6..d830631efd9 100644 --- a/api/lib/domain/read-models/CertificationEligibility.js +++ b/api/lib/domain/read-models/CertificationEligibility.js @@ -10,4 +10,4 @@ class CertificationEligibility { } } -module.exports = CertificationEligibility; +export { CertificationEligibility }; diff --git a/api/lib/domain/read-models/CertificationPointOfContact.js b/api/lib/domain/read-models/CertificationPointOfContact.js index a52d642f5dc..46725d0394c 100644 --- a/api/lib/domain/read-models/CertificationPointOfContact.js +++ b/api/lib/domain/read-models/CertificationPointOfContact.js @@ -18,4 +18,4 @@ class CertificationPointOfContact { } } -module.exports = CertificationPointOfContact; +export { CertificationPointOfContact }; diff --git a/api/lib/domain/read-models/CertifiedBadge.js b/api/lib/domain/read-models/CertifiedBadge.js index 059deff065b..4c4c2d730d9 100644 --- a/api/lib/domain/read-models/CertifiedBadge.js +++ b/api/lib/domain/read-models/CertifiedBadge.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; class CertifiedBadge { constructor({ partnerKey, label, imageUrl, stickerUrl, isTemporaryBadge, message }) { @@ -83,4 +83,4 @@ function _getAcquiredCertifiedBadgesDTOWithExternalJury(complementaryCertificati } } -module.exports = CertifiedBadge; +export { CertifiedBadge }; diff --git a/api/lib/domain/read-models/CertifiedProfile.js b/api/lib/domain/read-models/CertifiedProfile.js index 23fbcfcafa2..8fd67aab512 100644 --- a/api/lib/domain/read-models/CertifiedProfile.js +++ b/api/lib/domain/read-models/CertifiedProfile.js @@ -44,10 +44,4 @@ class CertifiedProfile { } } -module.exports = { - CertifiedProfile, - CertifiedArea, - CertifiedCompetence, - CertifiedTube, - CertifiedSkill, -}; +export { CertifiedProfile, CertifiedArea, CertifiedCompetence, CertifiedTube, CertifiedSkill }; diff --git a/api/lib/domain/read-models/ChallengeForPixAutoAnswer.js b/api/lib/domain/read-models/ChallengeForPixAutoAnswer.js index 8984c8432fa..1372bececd4 100644 --- a/api/lib/domain/read-models/ChallengeForPixAutoAnswer.js +++ b/api/lib/domain/read-models/ChallengeForPixAutoAnswer.js @@ -25,4 +25,4 @@ class ChallengeForPixAutoAnswer { ChallengeForPixAutoAnswer.Type = ChallengeType; -module.exports = ChallengeForPixAutoAnswer; +export { ChallengeForPixAutoAnswer }; diff --git a/api/lib/domain/read-models/CleaCertifiedCandidate.js b/api/lib/domain/read-models/CleaCertifiedCandidate.js index 78a6f785824..fd151d6dea8 100644 --- a/api/lib/domain/read-models/CleaCertifiedCandidate.js +++ b/api/lib/domain/read-models/CleaCertifiedCandidate.js @@ -47,4 +47,4 @@ class CleaCertifiedCandidate { } } -module.exports = CleaCertifiedCandidate; +export { CleaCertifiedCandidate }; diff --git a/api/lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification.js b/api/lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification.js index 211e44d78e6..6f521676da4 100644 --- a/api/lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification.js +++ b/api/lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification.js @@ -22,4 +22,4 @@ class ComplementaryCertificationCourseResultsForJuryCertification { ComplementaryCertificationCourseResultsForJuryCertification.statuses = complementaryCertificationStatus; -module.exports = ComplementaryCertificationCourseResultsForJuryCertification; +export { ComplementaryCertificationCourseResultsForJuryCertification }; diff --git a/api/lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal.js b/api/lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal.js index c7ab55f822c..458fb881d01 100644 --- a/api/lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal.js +++ b/api/lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal.js @@ -1,5 +1,10 @@ -const minBy = require('lodash/minBy'); -const { EXTERNAL, PIX } = require('../models/ComplementaryCertificationCourseResult.js').sources; +import lodash from 'lodash'; + +const { minBy } = lodash; + +import { sources } from '../models/ComplementaryCertificationCourseResult.js'; + +const { EXTERNAL, PIX } = sources; class ComplementaryCertificationCourseResultsForJuryCertificationWithExternal { constructor({ @@ -98,4 +103,4 @@ class Section { } } -module.exports = ComplementaryCertificationCourseResultsForJuryCertificationWithExternal; +export { ComplementaryCertificationCourseResultsForJuryCertificationWithExternal }; diff --git a/api/lib/domain/read-models/Country.js b/api/lib/domain/read-models/Country.js index 443bed6860e..29fcbfff640 100644 --- a/api/lib/domain/read-models/Country.js +++ b/api/lib/domain/read-models/Country.js @@ -6,6 +6,4 @@ class Country { } } -module.exports = { - Country, -}; +export { Country }; diff --git a/api/lib/domain/read-models/CpfCertificationResult.js b/api/lib/domain/read-models/CpfCertificationResult.js index 2f394d45c54..f89b863fd38 100644 --- a/api/lib/domain/read-models/CpfCertificationResult.js +++ b/api/lib/domain/read-models/CpfCertificationResult.js @@ -1,4 +1,4 @@ -const EuropeanNumericLevelFactory = require('./EuropeanNumericLevelFactory.js'); +import { EuropeanNumericLevelFactory } from './EuropeanNumericLevelFactory.js'; class CpfCertificationResult { constructor({ @@ -52,4 +52,4 @@ class CpfCertificationResult { } } -module.exports = CpfCertificationResult; +export { CpfCertificationResult }; diff --git a/api/lib/domain/read-models/EuropeanNumericLevel.js b/api/lib/domain/read-models/EuropeanNumericLevel.js index be0fab05101..8f0614e84b8 100644 --- a/api/lib/domain/read-models/EuropeanNumericLevel.js +++ b/api/lib/domain/read-models/EuropeanNumericLevel.js @@ -11,4 +11,4 @@ class EuropeanNumericLevel { } } -module.exports = EuropeanNumericLevel; +export { EuropeanNumericLevel }; diff --git a/api/lib/domain/read-models/EuropeanNumericLevelFactory.js b/api/lib/domain/read-models/EuropeanNumericLevelFactory.js index f31a85557d7..49eab555c97 100644 --- a/api/lib/domain/read-models/EuropeanNumericLevelFactory.js +++ b/api/lib/domain/read-models/EuropeanNumericLevelFactory.js @@ -1,6 +1,8 @@ -const uniqBy = require('lodash/uniqBy'); -const remove = require('lodash/remove'); -const EuropeanNumericLevel = require('./EuropeanNumericLevel.js'); +import lodash from 'lodash'; + +const { remove, uniqBy } = lodash; + +import { EuropeanNumericLevel } from './EuropeanNumericLevel.js'; class EuropeanNumericLevelFactory { static buildFromCompetenceMarks(competenceMarks) { @@ -94,4 +96,4 @@ function _areAtLeastOneCompetenceByDomain(competenceMarks) { return uniqBy(competenceMarks, 'areaCode').length === 5; } -module.exports = EuropeanNumericLevelFactory; +export { EuropeanNumericLevelFactory }; diff --git a/api/lib/domain/read-models/GeneralCertificationInformation.js b/api/lib/domain/read-models/GeneralCertificationInformation.js index c6947ce01cc..903d1a5e2cc 100644 --- a/api/lib/domain/read-models/GeneralCertificationInformation.js +++ b/api/lib/domain/read-models/GeneralCertificationInformation.js @@ -42,4 +42,4 @@ class GeneralCertificationInformation { } } -module.exports = GeneralCertificationInformation; +export { GeneralCertificationInformation }; diff --git a/api/lib/domain/read-models/JuryCertificationSummary.js b/api/lib/domain/read-models/JuryCertificationSummary.js index fd1b081b133..efac25cc24b 100644 --- a/api/lib/domain/read-models/JuryCertificationSummary.js +++ b/api/lib/domain/read-models/JuryCertificationSummary.js @@ -1,4 +1,4 @@ -const { status: assessmentResultStatuses } = require('../models/AssessmentResult.js'); +import { status as assessmentResultStatuses } from '../models/AssessmentResult.js'; const STARTED = 'started'; const ENDED_BY_SUPERVISOR = 'endedBySupervisor'; @@ -58,6 +58,8 @@ function _getStatus({ status, isEndedBySupervisor }) { return status; } +const statuses = { ...assessmentResultStatuses, STARTED, ENDED_BY_SUPERVISOR }; -module.exports = JuryCertificationSummary; -module.exports.statuses = { ...assessmentResultStatuses, STARTED, ENDED_BY_SUPERVISOR }; +JuryCertificationSummary.statuses = statuses; + +export { JuryCertificationSummary, statuses }; diff --git a/api/lib/domain/read-models/OrganizationLearnerActivity.js b/api/lib/domain/read-models/OrganizationLearnerActivity.js index 3cea4e9bf70..af7e32224d4 100644 --- a/api/lib/domain/read-models/OrganizationLearnerActivity.js +++ b/api/lib/domain/read-models/OrganizationLearnerActivity.js @@ -1,5 +1,7 @@ -const CampaignTypes = require('../models/CampaignTypes.js'); -const countBy = require('lodash/countBy'); +import { CampaignTypes } from '../models/CampaignTypes.js'; +import lodash from 'lodash'; + +const { countBy } = lodash; class OrganizationLearnerActivity { constructor({ organizationLearnerId, participations }) { @@ -36,4 +38,4 @@ function _statistics(participations) { return Object.values(CampaignTypes).map((campaignType) => _getStatisticsForType(participations, campaignType)); } -module.exports = OrganizationLearnerActivity; +export { OrganizationLearnerActivity }; diff --git a/api/lib/domain/read-models/OrganizationLearnerForAdmin.js b/api/lib/domain/read-models/OrganizationLearnerForAdmin.js index 0a47bbadd28..045dd180aa1 100644 --- a/api/lib/domain/read-models/OrganizationLearnerForAdmin.js +++ b/api/lib/domain/read-models/OrganizationLearnerForAdmin.js @@ -1,7 +1,7 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { validateEntity } = require('../validators/entity-validator.js'); +import { validateEntity } from '../validators/entity-validator.js'; const validationSchema = Joi.object({ id: Joi.number().integer().required(), @@ -50,4 +50,4 @@ class OrganizationLearnerForAdmin { } } -module.exports = OrganizationLearnerForAdmin; +export { OrganizationLearnerForAdmin }; diff --git a/api/lib/domain/read-models/OrganizationLearnerParticipation.js b/api/lib/domain/read-models/OrganizationLearnerParticipation.js index 90f5df48687..5995df51eb5 100644 --- a/api/lib/domain/read-models/OrganizationLearnerParticipation.js +++ b/api/lib/domain/read-models/OrganizationLearnerParticipation.js @@ -10,4 +10,4 @@ class OrganizationLearnerParticipation { } } -module.exports = OrganizationLearnerParticipation; +export { OrganizationLearnerParticipation }; diff --git a/api/lib/domain/read-models/OrganizationParticipant.js b/api/lib/domain/read-models/OrganizationParticipant.js index 8d3c6a3c7eb..b9920fd9b76 100644 --- a/api/lib/domain/read-models/OrganizationParticipant.js +++ b/api/lib/domain/read-models/OrganizationParticipant.js @@ -24,4 +24,4 @@ class OrganizationParticipant { } } -module.exports = OrganizationParticipant; +export { OrganizationParticipant }; diff --git a/api/lib/domain/read-models/OrganizationPlacesCapacity.js b/api/lib/domain/read-models/OrganizationPlacesCapacity.js index 31bee5b3aa5..6cbb015e19b 100644 --- a/api/lib/domain/read-models/OrganizationPlacesCapacity.js +++ b/api/lib/domain/read-models/OrganizationPlacesCapacity.js @@ -1,5 +1,8 @@ -const sumBy = require('lodash/sumBy'); -const categories = require('../constants/organization-places-categories.js'); +import lodash from 'lodash'; + +const { sumBy } = lodash; + +import * as categories from '../constants/organization-places-categories.js'; const categoriesByCode = { [categories.T0]: categories.FREE_RATE, @@ -29,4 +32,4 @@ class OrganizationPlacesCapacity { } } -module.exports = OrganizationPlacesCapacity; +export { OrganizationPlacesCapacity }; diff --git a/api/lib/domain/read-models/OrganizationPlacesLotManagement.js b/api/lib/domain/read-models/OrganizationPlacesLotManagement.js index c7901b4f7a2..b86c7b31212 100644 --- a/api/lib/domain/read-models/OrganizationPlacesLotManagement.js +++ b/api/lib/domain/read-models/OrganizationPlacesLotManagement.js @@ -1,4 +1,4 @@ -const categories = require('../constants/organization-places-categories.js'); +import * as categories from '../constants/organization-places-categories.js'; const statuses = { ACTIVE: 'ACTIVE', @@ -53,4 +53,4 @@ function _setStatus(activationDate, expirationDate) { OrganizationPlacesLotManagement.statuses = statuses; OrganizationPlacesLotManagement.categories = categoriesByCode; -module.exports = OrganizationPlacesLotManagement; +export { OrganizationPlacesLotManagement }; diff --git a/api/lib/domain/read-models/Prescriber.js b/api/lib/domain/read-models/Prescriber.js index 8455b9ee689..0193723e99c 100644 --- a/api/lib/domain/read-models/Prescriber.js +++ b/api/lib/domain/read-models/Prescriber.js @@ -24,4 +24,4 @@ class Prescriber { } } -module.exports = Prescriber; +export { Prescriber }; diff --git a/api/lib/domain/read-models/ScoOrganizationParticipant.js b/api/lib/domain/read-models/ScoOrganizationParticipant.js index 22387cbf22d..117a36eb83b 100644 --- a/api/lib/domain/read-models/ScoOrganizationParticipant.js +++ b/api/lib/domain/read-models/ScoOrganizationParticipant.js @@ -36,4 +36,4 @@ class ScoOrganizationParticipant { } } -module.exports = ScoOrganizationParticipant; +export { ScoOrganizationParticipant }; diff --git a/api/lib/domain/read-models/SessionForAttendanceSheet.js b/api/lib/domain/read-models/SessionForAttendanceSheet.js index bea68377bd4..0726c3d8d6a 100644 --- a/api/lib/domain/read-models/SessionForAttendanceSheet.js +++ b/api/lib/domain/read-models/SessionForAttendanceSheet.js @@ -24,4 +24,4 @@ class SessionForAttendanceSheet { } } -module.exports = SessionForAttendanceSheet; +export { SessionForAttendanceSheet }; diff --git a/api/lib/domain/read-models/SessionForSupervising.js b/api/lib/domain/read-models/SessionForSupervising.js index 1370bf17660..cbf0491d5e7 100644 --- a/api/lib/domain/read-models/SessionForSupervising.js +++ b/api/lib/domain/read-models/SessionForSupervising.js @@ -11,4 +11,4 @@ class SessionForSupervising { } } -module.exports = SessionForSupervising; +export { SessionForSupervising }; diff --git a/api/lib/domain/read-models/SessionForSupervisorKit.js b/api/lib/domain/read-models/SessionForSupervisorKit.js index 9e0cffdbe09..16c04a59ec0 100644 --- a/api/lib/domain/read-models/SessionForSupervisorKit.js +++ b/api/lib/domain/read-models/SessionForSupervisorKit.js @@ -11,4 +11,4 @@ class SessionForSupervisorKit { } } -module.exports = SessionForSupervisorKit; +export { SessionForSupervisorKit }; diff --git a/api/lib/domain/read-models/SessionSummary.js b/api/lib/domain/read-models/SessionSummary.js index 36692e13312..edbf7094a55 100644 --- a/api/lib/domain/read-models/SessionSummary.js +++ b/api/lib/domain/read-models/SessionSummary.js @@ -1,4 +1,4 @@ -const { statuses } = require('../models/Session.js'); +import { statuses } from '../models/Session.js'; class SessionSummary { constructor({ @@ -70,4 +70,4 @@ SessionSummary.statuses = { PROCESSED: statuses.PROCESSED, }; -module.exports = SessionSummary; +export { SessionSummary }; diff --git a/api/lib/domain/read-models/SharedProfileForCampaign.js b/api/lib/domain/read-models/SharedProfileForCampaign.js index e2b08d847bf..3690d8fd484 100644 --- a/api/lib/domain/read-models/SharedProfileForCampaign.js +++ b/api/lib/domain/read-models/SharedProfileForCampaign.js @@ -1,6 +1,8 @@ -const map = require('lodash/map'); -const isEmpty = require('lodash/isEmpty'); -const Scorecard = require('../models/Scorecard.js'); +import lodash from 'lodash'; + +const { map, isEmpty } = lodash; + +import { Scorecard } from '../models/Scorecard.js'; class SharedProfileForCampaign { constructor({ @@ -49,4 +51,4 @@ class SharedProfileForCampaign { } } -module.exports = SharedProfileForCampaign; +export { SharedProfileForCampaign }; diff --git a/api/lib/domain/read-models/StudentForEnrolment.js b/api/lib/domain/read-models/StudentForEnrolment.js index daa279de63e..292bb7fed25 100644 --- a/api/lib/domain/read-models/StudentForEnrolment.js +++ b/api/lib/domain/read-models/StudentForEnrolment.js @@ -22,4 +22,4 @@ class StudentForEnrolment { } } -module.exports = StudentForEnrolment; +export { StudentForEnrolment }; diff --git a/api/lib/domain/read-models/StudentInformationForAccountRecovery.js b/api/lib/domain/read-models/StudentInformationForAccountRecovery.js index 89b55d96ff8..17e73c728fe 100644 --- a/api/lib/domain/read-models/StudentInformationForAccountRecovery.js +++ b/api/lib/domain/read-models/StudentInformationForAccountRecovery.js @@ -8,4 +8,4 @@ class StudentInformationForAccountRecovery { } } -module.exports = StudentInformationForAccountRecovery; +export { StudentInformationForAccountRecovery }; diff --git a/api/lib/domain/read-models/SupOrganizationParticipant.js b/api/lib/domain/read-models/SupOrganizationParticipant.js index 511977aebda..bb6a719e929 100644 --- a/api/lib/domain/read-models/SupOrganizationParticipant.js +++ b/api/lib/domain/read-models/SupOrganizationParticipant.js @@ -30,4 +30,4 @@ class SupOrganizationParticipant { } } -module.exports = SupOrganizationParticipant; +export { SupOrganizationParticipant }; diff --git a/api/lib/domain/read-models/TrainingForAdmin.js b/api/lib/domain/read-models/TrainingForAdmin.js index 028fad947e7..7af8eb255b0 100644 --- a/api/lib/domain/read-models/TrainingForAdmin.js +++ b/api/lib/domain/read-models/TrainingForAdmin.js @@ -28,4 +28,4 @@ class TrainingForAdmin { } } -module.exports = TrainingForAdmin; +export { TrainingForAdmin }; diff --git a/api/lib/domain/read-models/TrainingSummary.js b/api/lib/domain/read-models/TrainingSummary.js index ca3dc4936eb..e4b9c0a09b2 100644 --- a/api/lib/domain/read-models/TrainingSummary.js +++ b/api/lib/domain/read-models/TrainingSummary.js @@ -6,4 +6,4 @@ class TrainingSummary { } } -module.exports = TrainingSummary; +export { TrainingSummary }; diff --git a/api/lib/domain/read-models/TrainingTriggerForAdmin.js b/api/lib/domain/read-models/TrainingTriggerForAdmin.js index 1d9ed51e532..1cbab7c6d71 100644 --- a/api/lib/domain/read-models/TrainingTriggerForAdmin.js +++ b/api/lib/domain/read-models/TrainingTriggerForAdmin.js @@ -1,4 +1,6 @@ -const types = require('../models/TrainingTrigger.js').types; +import { TrainingTrigger } from '../models/TrainingTrigger.js'; + +const { types } = TrainingTrigger; class TrainingTriggerForAdmin { constructor({ id, trainingId, triggerTubes, type, threshold, areas = [], competences = [], thematics = [] } = {}) { @@ -14,7 +16,7 @@ class TrainingTriggerForAdmin { } } -TrainingTriggerForAdmin.types = types; +TrainingTriggerForAdmin.types = TrainingTrigger.types; class _Area { constructor({ id, title, code, color, competences = [], thematics = [], triggerTubes = [] } = {}) { @@ -51,4 +53,4 @@ class _Thematic { } } -module.exports = TrainingTriggerForAdmin; +export { TrainingTriggerForAdmin }; diff --git a/api/lib/domain/read-models/TutorialForUser.js b/api/lib/domain/read-models/TutorialForUser.js index 75d4db053d9..b886f8e0ba4 100644 --- a/api/lib/domain/read-models/TutorialForUser.js +++ b/api/lib/domain/read-models/TutorialForUser.js @@ -1,4 +1,4 @@ -const Tutorial = require('../models/Tutorial.js'); +import { Tutorial } from '../models/Tutorial.js'; class TutorialForUser extends Tutorial { constructor({ userSavedTutorial, tutorialEvaluation, skillId, ...tutorial }) { @@ -9,4 +9,4 @@ class TutorialForUser extends Tutorial { } } -module.exports = TutorialForUser; +export { TutorialForUser }; diff --git a/api/lib/domain/read-models/UserOrganizationForAdmin.js b/api/lib/domain/read-models/UserOrganizationForAdmin.js index 8b83ffa7336..a9266a4d176 100644 --- a/api/lib/domain/read-models/UserOrganizationForAdmin.js +++ b/api/lib/domain/read-models/UserOrganizationForAdmin.js @@ -18,4 +18,4 @@ class UserOrganizationForAdmin { } } -module.exports = UserOrganizationForAdmin; +export { UserOrganizationForAdmin }; diff --git a/api/lib/domain/read-models/UserRecommendedTraining.js b/api/lib/domain/read-models/UserRecommendedTraining.js index 8a12e7a8a81..44460f529ec 100644 --- a/api/lib/domain/read-models/UserRecommendedTraining.js +++ b/api/lib/domain/read-models/UserRecommendedTraining.js @@ -11,4 +11,4 @@ class UserRecommendedTraining { } } -module.exports = UserRecommendedTraining; +export { UserRecommendedTraining }; diff --git a/api/lib/domain/read-models/UserWithActivity.js b/api/lib/domain/read-models/UserWithActivity.js index 1ce461e4541..f7c6d5f9ae5 100644 --- a/api/lib/domain/read-models/UserWithActivity.js +++ b/api/lib/domain/read-models/UserWithActivity.js @@ -14,4 +14,4 @@ class UserWithActivity { } } -module.exports = UserWithActivity; +export { UserWithActivity }; diff --git a/api/lib/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal.js b/api/lib/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal.js index 132a8ce4dd7..873d9ad715b 100644 --- a/api/lib/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal.js +++ b/api/lib/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; class CampaignAssessmentParticipationResultMinimal { constructor({ @@ -28,4 +28,4 @@ class CampaignAssessmentParticipationResultMinimal { } } -module.exports = CampaignAssessmentParticipationResultMinimal; +export { CampaignAssessmentParticipationResultMinimal }; diff --git a/api/lib/domain/read-models/campaign/TargetProfileForSpecifier.js b/api/lib/domain/read-models/campaign/TargetProfileForSpecifier.js index 57e89705060..ea9dcca3a44 100644 --- a/api/lib/domain/read-models/campaign/TargetProfileForSpecifier.js +++ b/api/lib/domain/read-models/campaign/TargetProfileForSpecifier.js @@ -10,4 +10,4 @@ class TargetProfileForSpecifier { } } -module.exports = TargetProfileForSpecifier; +export { TargetProfileForSpecifier }; diff --git a/api/lib/domain/read-models/livret-scolaire/Area.js b/api/lib/domain/read-models/livret-scolaire/Area.js index 82c198249df..11c5c334fe1 100644 --- a/api/lib/domain/read-models/livret-scolaire/Area.js +++ b/api/lib/domain/read-models/livret-scolaire/Area.js @@ -7,4 +7,4 @@ class Area { } } -module.exports = Area; +export { Area }; diff --git a/api/lib/domain/read-models/livret-scolaire/Certificate.js b/api/lib/domain/read-models/livret-scolaire/Certificate.js index 8df6064caa7..664db487718 100644 --- a/api/lib/domain/read-models/livret-scolaire/Certificate.js +++ b/api/lib/domain/read-models/livret-scolaire/Certificate.js @@ -1,4 +1,4 @@ -const { VALIDATED, PENDING } = require('./CertificateStatus.js'); +import { VALIDATED, PENDING } from './CertificateStatus.js'; class Certificate { constructor({ @@ -76,7 +76,7 @@ class Certificate { } } -module.exports = Certificate; +export { Certificate }; function _isValidated(status) { return status === VALIDATED; diff --git a/api/lib/domain/read-models/livret-scolaire/CertificateStatus.js b/api/lib/domain/read-models/livret-scolaire/CertificateStatus.js index 18d85f6528d..5a829a2cc40 100644 --- a/api/lib/domain/read-models/livret-scolaire/CertificateStatus.js +++ b/api/lib/domain/read-models/livret-scolaire/CertificateStatus.js @@ -1,7 +1,11 @@ +const REJECTED = 'rejected'; +const VALIDATED = 'validated'; +const PENDING = 'pending'; + const status = { - REJECTED: 'rejected', - VALIDATED: 'validated', - PENDING: 'pending', + REJECTED, + VALIDATED, + PENDING, }; -module.exports = status; +export { status, REJECTED, VALIDATED, PENDING }; diff --git a/api/lib/domain/read-models/livret-scolaire/CertificationsResults.js b/api/lib/domain/read-models/livret-scolaire/CertificationsResults.js index d23780ecc92..c237be0fdf8 100644 --- a/api/lib/domain/read-models/livret-scolaire/CertificationsResults.js +++ b/api/lib/domain/read-models/livret-scolaire/CertificationsResults.js @@ -5,4 +5,4 @@ class CertificationsResults { } } -module.exports = CertificationsResults; +export { CertificationsResults }; diff --git a/api/lib/domain/read-models/livret-scolaire/Competence.js b/api/lib/domain/read-models/livret-scolaire/Competence.js index 6f536548c2b..106332acfd3 100644 --- a/api/lib/domain/read-models/livret-scolaire/Competence.js +++ b/api/lib/domain/read-models/livret-scolaire/Competence.js @@ -6,4 +6,4 @@ class Competence { } } -module.exports = Competence; +export { Competence }; diff --git a/api/lib/domain/read-models/livret-scolaire/CompetenceResults.js b/api/lib/domain/read-models/livret-scolaire/CompetenceResults.js index be66ab45cac..36df026e602 100644 --- a/api/lib/domain/read-models/livret-scolaire/CompetenceResults.js +++ b/api/lib/domain/read-models/livret-scolaire/CompetenceResults.js @@ -4,4 +4,4 @@ class CompetenceResults { } } -module.exports = CompetenceResults; +export { CompetenceResults }; diff --git a/api/lib/domain/read-models/organization-learner-follow-up/OrganizationLearner.js b/api/lib/domain/read-models/organization-learner-follow-up/OrganizationLearner.js index e761769d6f1..5df1b60fe82 100644 --- a/api/lib/domain/read-models/organization-learner-follow-up/OrganizationLearner.js +++ b/api/lib/domain/read-models/organization-learner-follow-up/OrganizationLearner.js @@ -24,4 +24,4 @@ class OrganizationLearner { } } -module.exports = OrganizationLearner; +export { OrganizationLearner }; diff --git a/api/lib/domain/read-models/participant-results/AssessmentResult.js b/api/lib/domain/read-models/participant-results/AssessmentResult.js index 09d4125a634..36de457c5a9 100644 --- a/api/lib/domain/read-models/participant-results/AssessmentResult.js +++ b/api/lib/domain/read-models/participant-results/AssessmentResult.js @@ -1,7 +1,11 @@ -const BadgeResult = require('./BadgeResult.js'); -const CompetenceResult = require('./CompetenceResult.js'); -const { constants } = require('../../constants.js'); -const moment = require('moment'); +import { BadgeResult } from './BadgeResult.js'; +import { CompetenceResult } from './CompetenceResult.js'; +import { + MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING, + MAX_MASTERY_RATE, + MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING, +} from '../../constants.js'; +import moment from 'moment'; class AssessmentResult { constructor({ @@ -98,7 +102,7 @@ class AssessmentResult { knowledgeElements.filter((knowledgeElement) => { const isOldEnoughToBeImproved = moment(assessmentCreatedAt).diff(knowledgeElement.createdAt, 'days', true) >= - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING; + MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING; return knowledgeElement.isInvalidated && isOldEnoughToBeImproved; }).length > 0; return isImprovementPossible && !isShared; @@ -108,7 +112,7 @@ class AssessmentResult { return ( isCampaignMultipleSendings && this._timeBeforeRetryingPassed(sharedAt) && - masteryRate < constants.MAX_MASTERY_RATE && + masteryRate < MAX_MASTERY_RATE && isOrganizationLearnerActive && !isDisabled ); @@ -121,7 +125,7 @@ class AssessmentResult { _timeBeforeRetryingPassed(sharedAt) { const isShared = Boolean(sharedAt); if (!isShared) return false; - return sharedAt && moment().diff(sharedAt, 'days', true) >= constants.MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING; + return sharedAt && moment().diff(sharedAt, 'days', true) >= MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING; } } @@ -143,4 +147,4 @@ function _buildCompetenceResult({ }); } -module.exports = AssessmentResult; +export { AssessmentResult }; diff --git a/api/lib/domain/read-models/participant-results/BadgeResult.js b/api/lib/domain/read-models/participant-results/BadgeResult.js index 486482175c2..52dd687790b 100644 --- a/api/lib/domain/read-models/participant-results/BadgeResult.js +++ b/api/lib/domain/read-models/participant-results/BadgeResult.js @@ -1,4 +1,4 @@ -const SkillSetResult = require('./SkillSetResult.js'); +import { SkillSetResult } from './SkillSetResult.js'; class BadgeResult { constructor(badge, participationResults) { @@ -27,4 +27,4 @@ function _buildSkillSetResult(badgeCompetence, knowledgeElements) { return new SkillSetResult(badgeCompetence, competenceKnowledgeElements); } -module.exports = BadgeResult; +export { BadgeResult }; diff --git a/api/lib/domain/read-models/participant-results/CompetenceResult.js b/api/lib/domain/read-models/participant-results/CompetenceResult.js index 9d9d8986af5..9b56c2eb3c7 100644 --- a/api/lib/domain/read-models/participant-results/CompetenceResult.js +++ b/api/lib/domain/read-models/participant-results/CompetenceResult.js @@ -25,4 +25,4 @@ class CompetenceResult { } } -module.exports = CompetenceResult; +export { CompetenceResult }; diff --git a/api/lib/domain/read-models/participant-results/SkillSetResult.js b/api/lib/domain/read-models/participant-results/SkillSetResult.js index a72a71913f8..21f1a06de57 100644 --- a/api/lib/domain/read-models/participant-results/SkillSetResult.js +++ b/api/lib/domain/read-models/participant-results/SkillSetResult.js @@ -12,4 +12,4 @@ class SkillSetResult { } } -module.exports = SkillSetResult; +export { SkillSetResult }; diff --git a/api/lib/domain/services/algorithm-methods/cat-algorithm.js b/api/lib/domain/services/algorithm-methods/cat-algorithm.js index ab5cc6ca4a6..219bba06869 100644 --- a/api/lib/domain/services/algorithm-methods/cat-algorithm.js +++ b/api/lib/domain/services/algorithm-methods/cat-algorithm.js @@ -1,15 +1,9 @@ -const KnowledgeElement = require('../../models/KnowledgeElement.js'); -const _ = require('lodash'); -const { pipe } = require('lodash/fp'); - -// This file implements methods useful for a CAT algorithm -// https://en.wikipedia.org/wiki/Computerized_adaptive_testing -// https://en.wikipedia.org/wiki/Item_response_theory - -module.exports = { - findMaxRewardingSkills, - getPredictedLevel, -}; +import { KnowledgeElement } from '../../models/KnowledgeElement.js'; +import _ from 'lodash'; +import fp from 'lodash/fp.js'; + +const { pipe } = fp; +export { findMaxRewardingSkills, getPredictedLevel }; function getPredictedLevel(knowledgeElements, skills) { return _.maxBy(_enumerateCatLevels(), (level) => diff --git a/api/lib/domain/services/algorithm-methods/data-fetcher.js b/api/lib/domain/services/algorithm-methods/data-fetcher.js index 553dbaf2435..22cc5d0eda9 100644 --- a/api/lib/domain/services/algorithm-methods/data-fetcher.js +++ b/api/lib/domain/services/algorithm-methods/data-fetcher.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; async function fetchForCampaigns({ assessment, @@ -115,9 +115,4 @@ async function fetchForFlashLevelEstimation({ assessment, answerRepository, chal }; } -module.exports = { - fetchForCampaigns, - fetchForCompetenceEvaluations, - fetchForFlashCampaigns, - fetchForFlashLevelEstimation, -}; +export { fetchForCampaigns, fetchForCompetenceEvaluations, fetchForFlashCampaigns, fetchForFlashLevelEstimation }; diff --git a/api/lib/domain/services/algorithm-methods/flash.js b/api/lib/domain/services/algorithm-methods/flash.js index 29185c428c9..c94c1b2df07 100644 --- a/api/lib/domain/services/algorithm-methods/flash.js +++ b/api/lib/domain/services/algorithm-methods/flash.js @@ -1,6 +1,8 @@ -const { orderBy, range, sortBy, sortedUniqBy, sumBy } = require('lodash'); +import lodash from 'lodash'; -const config = require('../../../config.js'); +const { orderBy, range, sortBy, sortedUniqBy, sumBy } = lodash; + +import { config } from '../../../config.js'; const DEFAULT_ESTIMATED_LEVEL = 0; const START_OF_SAMPLES = -9; @@ -11,7 +13,7 @@ const DEFAULT_PROBABILITY_TO_ANSWER = 1; const DEFAULT_ERROR_RATE = 5; const ERROR_RATE_CLASS_INTERVAL = 9 / 80; -module.exports = { +export { getPossibleNextChallenges, getEstimatedLevelAndErrorRate, getChallengesForNonAnsweredSkills, diff --git a/api/lib/domain/services/algorithm-methods/skills-filter.js b/api/lib/domain/services/algorithm-methods/skills-filter.js index c6f215a1379..0c658d352e4 100644 --- a/api/lib/domain/services/algorithm-methods/skills-filter.js +++ b/api/lib/domain/services/algorithm-methods/skills-filter.js @@ -1,11 +1,15 @@ -const _ = require('lodash'); -const { pipe } = require('lodash/fp'); -const { constants } = require('../../constants.js'); +import _ from 'lodash'; -module.exports = { - getFilteredSkillsForFirstChallenge, - getFilteredSkillsForNextChallenge, -}; +import fp from 'lodash/fp.js'; + +const { pipe } = fp; +import { + MAX_LEVEL_TO_BE_AN_EASY_TUBE, + MAX_DIFF_BETWEEN_USER_LEVEL_AND_SKILL_LEVEL, + DEFAULT_LEVEL_FOR_FIRST_CHALLENGE, +} from '../../constants.js'; + +export { getFilteredSkillsForFirstChallenge, getFilteredSkillsForNextChallenge }; function getFilteredSkillsForFirstChallenge({ knowledgeElements, tubes, targetSkills }) { return pipe( @@ -55,7 +59,7 @@ function _keepSkillsFromEasyTubes(tubes, targetSkills) { } function _getEasyTubes(tubes) { - return _.filter(tubes, (tube) => tube.getHardestSkill().difficulty <= constants.MAX_LEVEL_TO_BE_AN_EASY_TUBE); + return _.filter(tubes, (tube) => tube.getHardestSkill().difficulty <= MAX_LEVEL_TO_BE_AN_EASY_TUBE); } function _getSkillsFromTubes(tubes) { @@ -83,7 +87,7 @@ function _focusOnDefaultLevel(targetSkills) { } const remapDifficulty = (difficulty) => - difficulty == constants.DEFAULT_LEVEL_FOR_FIRST_CHALLENGE ? Number.MIN_VALUE : difficulty; + difficulty == DEFAULT_LEVEL_FOR_FIRST_CHALLENGE ? Number.MIN_VALUE : difficulty; const [, potentialFirstSkills] = _(targetSkills) .groupBy('difficulty') .entries() @@ -97,5 +101,5 @@ function _removeTooDifficultSkills(predictedLevel, targetSkills) { } function _isSkillTooHard(skill, predictedLevel) { - return skill.difficulty - predictedLevel > constants.MAX_DIFF_BETWEEN_USER_LEVEL_AND_SKILL_LEVEL; + return skill.difficulty - predictedLevel > MAX_DIFF_BETWEEN_USER_LEVEL_AND_SKILL_LEVEL; } diff --git a/api/lib/domain/services/algorithm-methods/smart-random.js b/api/lib/domain/services/algorithm-methods/smart-random.js index 4237360da6b..3d4b7869232 100644 --- a/api/lib/domain/services/algorithm-methods/smart-random.js +++ b/api/lib/domain/services/algorithm-methods/smart-random.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const catAlgorithm = require('./cat-algorithm.js'); -const { getFilteredSkillsForNextChallenge, getFilteredSkillsForFirstChallenge } = require('./skills-filter.js'); -const { computeTubesFromSkills } = require('./../tube-service.js'); +import _ from 'lodash'; +import * as catAlgorithm from './cat-algorithm.js'; +import { getFilteredSkillsForNextChallenge, getFilteredSkillsForFirstChallenge } from './skills-filter.js'; +import { computeTubesFromSkills } from './../tube-service.js'; -module.exports = { getPossibleSkillsForNextChallenge }; +export { getPossibleSkillsForNextChallenge }; function getPossibleSkillsForNextChallenge({ knowledgeElements, diff --git a/api/lib/domain/services/assessment-result-service.js b/api/lib/domain/services/assessment-result-service.js index c2f3bfce0fa..061f02a06c5 100644 --- a/api/lib/domain/services/assessment-result-service.js +++ b/api/lib/domain/services/assessment-result-service.js @@ -1,7 +1,7 @@ -const assessmentResultRepository = require('../../infrastructure/repositories/assessment-result-repository.js'); -const competenceMarkRepository = require('../../infrastructure/repositories/competence-mark-repository.js'); -const CompetenceMark = require('../models/CompetenceMark.js'); -const bluebird = require('bluebird'); +import * as assessmentResultRepository from '../../infrastructure/repositories/assessment-result-repository.js'; +import * as competenceMarkRepository from '../../infrastructure/repositories/competence-mark-repository.js'; +import { CompetenceMark } from '../models/CompetenceMark.js'; +import bluebird from 'bluebird'; async function _validatedDataForAllCompetenceMark(competenceMarks) { for (const competenceMark of competenceMarks) { @@ -28,6 +28,4 @@ async function save({ ); } -module.exports = { - save, -}; +export { save }; diff --git a/api/lib/domain/services/authentication/authentication-service-registry.js b/api/lib/domain/services/authentication/authentication-service-registry.js index ace133df8aa..d57a3a915b1 100644 --- a/api/lib/domain/services/authentication/authentication-service-registry.js +++ b/api/lib/domain/services/authentication/authentication-service-registry.js @@ -1,5 +1,5 @@ -const OidcIdentityProviders = require('../../constants/oidc-identity-providers.js'); -const { InvalidIdentityProviderError } = require('../../errors.js'); +import * as OidcIdentityProviders from '../../constants/oidc-identity-providers.js'; +import { InvalidIdentityProviderError } from '../../errors.js'; function lookupAuthenticationService(identityProvider) { const identityProviderService = Object.values(OidcIdentityProviders).find( @@ -11,6 +11,4 @@ function lookupAuthenticationService(identityProvider) { return identityProviderService.service; } -module.exports = { - lookupAuthenticationService, -}; +export { lookupAuthenticationService }; diff --git a/api/lib/domain/services/authentication/authentication-session-service.js b/api/lib/domain/services/authentication/authentication-session-service.js index 1412c3af672..741aa1552ee 100644 --- a/api/lib/domain/services/authentication/authentication-session-service.js +++ b/api/lib/domain/services/authentication/authentication-session-service.js @@ -1,22 +1,22 @@ -const settings = require('../../../config.js'); -const { temporaryStorage } = require('../../../infrastructure/temporary-storage/index.js'); +import { config } from '../../../config.js'; +import { temporaryStorage } from '../../../infrastructure/temporary-storage/index.js'; const authenticationSessionTemporaryStorage = temporaryStorage.withPrefix('authentication-session:'); -const EXPIRATION_DELAY_SECONDS = settings.authenticationSession.temporaryStorage.expirationDelaySeconds; +const EXPIRATION_DELAY_SECONDS = config.authenticationSession.temporaryStorage.expirationDelaySeconds; -module.exports = { - getByKey(key) { - return authenticationSessionTemporaryStorage.get(key); - }, +const getByKey = function (key) { + return authenticationSessionTemporaryStorage.get(key); +}; - save(authenticationContent) { - return authenticationSessionTemporaryStorage.save({ - value: authenticationContent, - expirationDelaySeconds: EXPIRATION_DELAY_SECONDS, - }); - }, +const save = function (authenticationContent) { + return authenticationSessionTemporaryStorage.save({ + value: authenticationContent, + expirationDelaySeconds: EXPIRATION_DELAY_SECONDS, + }); +}; - update(key, value) { - authenticationSessionTemporaryStorage.update(key, value); - }, +const update = function (key, value) { + authenticationSessionTemporaryStorage.update(key, value); }; + +export { getByKey, save, update }; diff --git a/api/lib/domain/services/authentication/cnav-oidc-authentication-service.js b/api/lib/domain/services/authentication/cnav-oidc-authentication-service.js index d61ba906f65..5e07f23507b 100644 --- a/api/lib/domain/services/authentication/cnav-oidc-authentication-service.js +++ b/api/lib/domain/services/authentication/cnav-oidc-authentication-service.js @@ -1,5 +1,5 @@ -const settings = require('../../../config.js'); -const OidcAuthenticationService = require('./oidc-authentication-service.js'); +import { config } from '../../../config.js'; +import { OidcAuthenticationService } from './oidc-authentication-service.js'; class CnavOidcAuthenticationService extends OidcAuthenticationService { constructor() { @@ -9,15 +9,15 @@ class CnavOidcAuthenticationService extends OidcAuthenticationService { slug: 'cnav', organizationName: 'CNAV', hasLogoutUrl: false, - jwtOptions: { expiresIn: settings.cnav.accessTokenLifespanMs / 1000 }, - clientSecret: settings.cnav.clientSecret, - clientId: settings.cnav.clientId, - tokenUrl: settings.cnav.tokenUrl, - authenticationUrl: settings.cnav.authenticationUrl, + jwtOptions: { expiresIn: config.cnav.accessTokenLifespanMs / 1000 }, + clientSecret: config.cnav.clientSecret, + clientId: config.cnav.clientId, + tokenUrl: config.cnav.tokenUrl, + authenticationUrl: config.cnav.authenticationUrl, authenticationUrlParameters: [{ key: 'scope', value: 'openid profile' }], - userInfoUrl: settings.cnav.userInfoUrl, + userInfoUrl: config.cnav.userInfoUrl, }); } } -module.exports = CnavOidcAuthenticationService; +export { CnavOidcAuthenticationService }; diff --git a/api/lib/domain/services/authentication/fwb-oidc-authentication-service.js b/api/lib/domain/services/authentication/fwb-oidc-authentication-service.js index 6bf3e25042f..1771f2fe878 100644 --- a/api/lib/domain/services/authentication/fwb-oidc-authentication-service.js +++ b/api/lib/domain/services/authentication/fwb-oidc-authentication-service.js @@ -1,7 +1,7 @@ -const { v4: uuidv4 } = require('uuid'); -const settings = require('../../../config.js'); -const OidcAuthenticationService = require('./oidc-authentication-service.js'); -const { temporaryStorage } = require('../../../infrastructure/temporary-storage/index.js'); +import { v4 as uuidv4 } from 'uuid'; +import { config } from '../../../config.js'; +import { OidcAuthenticationService } from './oidc-authentication-service.js'; +import { temporaryStorage } from '../../../infrastructure/temporary-storage/index.js'; const logoutUrlTemporaryStorage = temporaryStorage.withPrefix('logout-url:'); @@ -13,17 +13,17 @@ class FwbOidcAuthenticationService extends OidcAuthenticationService { slug: 'fwb', organizationName: 'Fédération Wallonie-Bruxelles', hasLogoutUrl: true, - jwtOptions: { expiresIn: settings.fwb.accessTokenLifespanMs / 1000 }, - clientSecret: settings.fwb.clientSecret, - clientId: settings.fwb.clientId, - tokenUrl: settings.fwb.tokenUrl, - authenticationUrl: settings.fwb.authenticationUrl, + jwtOptions: { expiresIn: config.fwb.accessTokenLifespanMs / 1000 }, + clientSecret: config.fwb.clientSecret, + clientId: config.fwb.clientId, + tokenUrl: config.fwb.tokenUrl, + authenticationUrl: config.fwb.authenticationUrl, authenticationUrlParameters: [{ key: 'scope', value: 'openid profile' }], - userInfoUrl: settings.fwb.userInfoUrl, + userInfoUrl: config.fwb.userInfoUrl, }); - this.logoutUrl = settings.fwb.logoutUrl; - this.temporaryStorage = settings.fwb.temporaryStorage; + this.logoutUrl = config.fwb.logoutUrl; + this.temporaryStorage = config.fwb.temporaryStorage; } async getRedirectLogoutUrl({ userId, logoutUrlUUID }) { @@ -53,4 +53,4 @@ class FwbOidcAuthenticationService extends OidcAuthenticationService { } } -module.exports = FwbOidcAuthenticationService; +export { FwbOidcAuthenticationService }; diff --git a/api/lib/domain/services/authentication/oidc-authentication-service.js b/api/lib/domain/services/authentication/oidc-authentication-service.js index 6973a5e1f18..5e64b027c98 100644 --- a/api/lib/domain/services/authentication/oidc-authentication-service.js +++ b/api/lib/domain/services/authentication/oidc-authentication-service.js @@ -1,21 +1,22 @@ -const jsonwebtoken = require('jsonwebtoken'); -const querystring = require('querystring'); -const { v4: uuidv4 } = require('uuid'); +import jsonwebtoken from 'jsonwebtoken'; +import querystring from 'querystring'; +import { v4 as uuidv4 } from 'uuid'; -const { +import { InvalidExternalAPIResponseError, OidcInvokingTokenEndpointError, OidcMissingFieldsError, OidcUserInfoFormatError, -} = require('../../errors.js'); -const AuthenticationMethod = require('../../models/AuthenticationMethod.js'); -const AuthenticationSessionContent = require('../../models/AuthenticationSessionContent.js'); -const settings = require('../../../config.js'); -const httpAgent = require('../../../infrastructure/http/http-agent.js'); -const httpErrorsHelper = require('../../../infrastructure/http/errors-helper.js'); -const DomainTransaction = require('../../../infrastructure/DomainTransaction.js'); -const monitoringTools = require('../../../infrastructure/monitoring-tools.js'); -const { OIDC_ERRORS } = require('../../constants.js'); +} from '../../errors.js'; + +import { AuthenticationMethod } from '../../models/AuthenticationMethod.js'; +import { AuthenticationSessionContent } from '../../models/AuthenticationSessionContent.js'; +import { config } from '../../../config.js'; +import { httpAgent } from '../../../infrastructure/http/http-agent.js'; +import * as httpErrorsHelper from '../../../infrastructure/http/errors-helper.js'; +import { DomainTransaction } from '../../../infrastructure/DomainTransaction.js'; +import { monitoringTools } from '../../../infrastructure/monitoring-tools.js'; +import { OIDC_ERRORS } from '../../constants.js'; class OidcAuthenticationService { constructor({ @@ -51,7 +52,7 @@ class OidcAuthenticationService { } createAccessToken(userId) { - return jsonwebtoken.sign({ user_id: userId }, settings.authentication.secret, this.jwtOptions); + return jsonwebtoken.sign({ user_id: userId }, config.authentication.secret, this.jwtOptions); } createAuthenticationComplement() { @@ -75,7 +76,7 @@ class OidcAuthenticationService { url: this.tokenUrl, payload: querystring.stringify(data), headers: { 'content-type': 'application/x-www-form-urlencoded' }, - timeout: settings.partner.fetchTimeOut, + timeout: config.partner.fetchTimeOut, }); if (!httpResponse.isSuccessful) { @@ -116,7 +117,7 @@ class OidcAuthenticationService { const httpResponse = await httpAgent.get({ url: userInfoUrl, headers: { Authorization: `Bearer ${accessToken}` }, - timeout: settings.partner.fetchTimeOut, + timeout: config.partner.fetchTimeOut, }); if (!httpResponse.isSuccessful) { @@ -223,4 +224,4 @@ class OidcAuthenticationService { } } -module.exports = OidcAuthenticationService; +export { OidcAuthenticationService }; diff --git a/api/lib/domain/services/authentication/pix-authentication-service.js b/api/lib/domain/services/authentication/pix-authentication-service.js index 4ca6eb5d22b..5e38d95cca4 100644 --- a/api/lib/domain/services/authentication/pix-authentication-service.js +++ b/api/lib/domain/services/authentication/pix-authentication-service.js @@ -1,6 +1,6 @@ -const { PasswordNotMatching } = require('../../errors.js'); -const encryptionService = require('../encryption-service.js'); -const userLoginRepository = require('../../../infrastructure/repositories/user-login-repository.js'); +import { PasswordNotMatching } from '../../errors.js'; +import * as encryptionService from '../encryption-service.js'; +import * as userLoginRepository from '../../../infrastructure/repositories/user-login-repository.js'; async function getUserByUsernameAndPassword({ username, @@ -45,6 +45,4 @@ async function getUserByUsernameAndPassword({ return foundUser; } -module.exports = { - getUserByUsernameAndPassword, -}; +export { getUserByUsernameAndPassword }; diff --git a/api/lib/domain/services/authentication/pole-emploi-oidc-authentication-service.js b/api/lib/domain/services/authentication/pole-emploi-oidc-authentication-service.js index cbb61202a33..2309ebec511 100644 --- a/api/lib/domain/services/authentication/pole-emploi-oidc-authentication-service.js +++ b/api/lib/domain/services/authentication/pole-emploi-oidc-authentication-service.js @@ -1,15 +1,16 @@ -const settings = require('../../../config.js'); -const OidcAuthenticationService = require('./oidc-authentication-service.js'); -const DomainTransaction = require('../../../infrastructure/DomainTransaction.js'); -const AuthenticationMethod = require('../../models/AuthenticationMethod.js'); -const dayjs = require('dayjs'); -const { v4: uuidv4 } = require('uuid'); -const { temporaryStorage } = require('../../../infrastructure/temporary-storage/index.js'); +import { config } from '../../../config.js'; +import { OidcAuthenticationService } from './oidc-authentication-service.js'; +import { DomainTransaction } from '../../../infrastructure/DomainTransaction.js'; +import { AuthenticationMethod } from '../../models/AuthenticationMethod.js'; +import dayjs from 'dayjs'; +import { v4 as uuidv4 } from 'uuid'; +import { temporaryStorage } from '../../../infrastructure/temporary-storage/index.js'; + const logoutUrlTemporaryStorage = temporaryStorage.withPrefix('logout-url:'); class PoleEmploiOidcAuthenticationService extends OidcAuthenticationService { constructor() { - const clientId = settings.poleEmploi.clientId; + const clientId = config.poleEmploi.clientId; // Attention, les scopes serviceDigitauxExposition api_peconnect-servicesdigitauxv1 ne sont pas présents dans la documentation de Pole Emploi mais ils sont nécessaires à l'envoi des résultats const authenticationUrlParameters = [ { key: 'realm', value: '/individu' }, @@ -25,18 +26,18 @@ class PoleEmploiOidcAuthenticationService extends OidcAuthenticationService { slug: 'pole-emploi', organizationName: 'Pôle Emploi', hasLogoutUrl: true, - jwtOptions: { expiresIn: settings.poleEmploi.accessTokenLifespanMs / 1000 }, - clientSecret: settings.poleEmploi.clientSecret, + jwtOptions: { expiresIn: config.poleEmploi.accessTokenLifespanMs / 1000 }, + clientSecret: config.poleEmploi.clientSecret, clientId: clientId, - tokenUrl: settings.poleEmploi.tokenUrl, - authenticationUrl: settings.poleEmploi.authenticationUrl, + tokenUrl: config.poleEmploi.tokenUrl, + authenticationUrl: config.poleEmploi.authenticationUrl, authenticationUrlParameters, - userInfoUrl: settings.poleEmploi.userInfoUrl, + userInfoUrl: config.poleEmploi.userInfoUrl, }); - this.logoutUrl = settings.poleEmploi.logoutUrl; - this.afterLogoutUrl = settings.poleEmploi.afterLogoutUrl; - this.temporaryStorage = settings.poleEmploi.temporaryStorage; + this.logoutUrl = config.poleEmploi.logoutUrl; + this.afterLogoutUrl = config.poleEmploi.afterLogoutUrl; + this.temporaryStorage = config.poleEmploi.temporaryStorage; } // Override because we need idToken to send results after a campaign @@ -103,4 +104,4 @@ class PoleEmploiOidcAuthenticationService extends OidcAuthenticationService { } } -module.exports = PoleEmploiOidcAuthenticationService; +export { PoleEmploiOidcAuthenticationService }; diff --git a/api/lib/domain/services/campaign-csv-export-service.js b/api/lib/domain/services/campaign-csv-export-service.js index c05e9960ca8..8f8cfd2ef73 100644 --- a/api/lib/domain/services/campaign-csv-export-service.js +++ b/api/lib/domain/services/campaign-csv-export-service.js @@ -1,10 +1,8 @@ -const CampaignAssessmentCsvLine = require('../../infrastructure/utils/CampaignAssessmentCsvLine.js'); -const csvSerializer = require('../../infrastructure/serializers/csv/csv-serializer.js'); -const campaignParticipationService = require('../services/campaign-participation-service.js'); +import { CampaignAssessmentCsvLine } from '../../infrastructure/utils/CampaignAssessmentCsvLine.js'; +import * as csvSerializer from '../../infrastructure/serializers/csv/csv-serializer.js'; +import * as campaignParticipationService from '../services/campaign-participation-service.js'; -module.exports = { - createOneCsvLine, -}; +export { createOneCsvLine }; function createOneCsvLine({ organization, diff --git a/api/lib/domain/services/campaign-participation-service.js b/api/lib/domain/services/campaign-participation-service.js index 43cdd1e3b4c..9cbcf2de65e 100644 --- a/api/lib/domain/services/campaign-participation-service.js +++ b/api/lib/domain/services/campaign-participation-service.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; function progress(campaignParticipationCompleted, numberOfKnowledgeElements, numberOfSkillsInTargetProfile) { if (campaignParticipationCompleted) { @@ -7,6 +7,4 @@ function progress(campaignParticipationCompleted, numberOfKnowledgeElements, num return _.round(numberOfKnowledgeElements / numberOfSkillsInTargetProfile, 3); } -module.exports = { - progress, -}; +export { progress }; diff --git a/api/lib/domain/services/campaigns/campaign-code-generator.js b/api/lib/domain/services/campaigns/campaign-code-generator.js index 1ad8f4b856e..51df6de8462 100644 --- a/api/lib/domain/services/campaigns/campaign-code-generator.js +++ b/api/lib/domain/services/campaigns/campaign-code-generator.js @@ -1,4 +1,4 @@ -const randomString = require('randomstring'); +import randomString from 'randomstring'; function generate(campaignRepository, pendingList = []) { const letters = randomString.generate({ @@ -23,6 +23,4 @@ function generate(campaignRepository, pendingList = []) { }); } -module.exports = { - generate, -}; +export { generate }; diff --git a/api/lib/domain/services/certification-badges-service.js b/api/lib/domain/services/certification-badges-service.js index d624c3b537f..df4061eabcc 100644 --- a/api/lib/domain/services/certification-badges-service.js +++ b/api/lib/domain/services/certification-badges-service.js @@ -1,38 +1,38 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const certifiableBadgeAcquisitionRepository = require('../../infrastructure/repositories/certifiable-badge-acquisition-repository.js'); -const knowledgeElementRepository = require('../../infrastructure/repositories/knowledge-element-repository.js'); -const badgeForCalculationRepository = require('../../infrastructure/repositories/badge-for-calculation-repository.js'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import * as certifiableBadgeAcquisitionRepository from '../../infrastructure/repositories/certifiable-badge-acquisition-repository.js'; +import * as knowledgeElementRepository from '../../infrastructure/repositories/knowledge-element-repository.js'; +import * as badgeForCalculationRepository from '../../infrastructure/repositories/badge-for-calculation-repository.js'; -module.exports = { - async findStillValidBadgeAcquisitions({ - userId, - domainTransaction, - dependencies = { certifiableBadgeAcquisitionRepository, knowledgeElementRepository, badgeForCalculationRepository }, - }) { - const highestCertifiableBadgeAcquisitions = - await dependencies.certifiableBadgeAcquisitionRepository.findHighestCertifiable({ - userId, - domainTransaction, - }); - - const knowledgeElements = await dependencies.knowledgeElementRepository.findUniqByUserId({ +const findStillValidBadgeAcquisitions = async function ({ + userId, + domainTransaction, + dependencies = { certifiableBadgeAcquisitionRepository, knowledgeElementRepository, badgeForCalculationRepository }, +}) { + const highestCertifiableBadgeAcquisitions = + await dependencies.certifiableBadgeAcquisitionRepository.findHighestCertifiable({ userId, domainTransaction, }); - const badgeAcquisitions = await bluebird.mapSeries( - highestCertifiableBadgeAcquisitions, - async (certifiableBadgeAcquisition) => { - const badgeForCalculation = await dependencies.badgeForCalculationRepository.getByCertifiableBadgeAcquisition({ - certifiableBadgeAcquisition, - }); - if (!badgeForCalculation) return null; - const isBadgeValid = badgeForCalculation.shouldBeObtained(knowledgeElements); - return isBadgeValid ? certifiableBadgeAcquisition : null; - } - ); + const knowledgeElements = await dependencies.knowledgeElementRepository.findUniqByUserId({ + userId, + domainTransaction, + }); + + const badgeAcquisitions = await bluebird.mapSeries( + highestCertifiableBadgeAcquisitions, + async (certifiableBadgeAcquisition) => { + const badgeForCalculation = await dependencies.badgeForCalculationRepository.getByCertifiableBadgeAcquisition({ + certifiableBadgeAcquisition, + }); + if (!badgeForCalculation) return null; + const isBadgeValid = badgeForCalculation.shouldBeObtained(knowledgeElements); + return isBadgeValid ? certifiableBadgeAcquisition : null; + } + ); - return _.compact(badgeAcquisitions); - }, + return _.compact(badgeAcquisitions); }; + +export { findStillValidBadgeAcquisitions }; diff --git a/api/lib/domain/services/certification-candidates-ods-service.js b/api/lib/domain/services/certification-candidates-ods-service.js index f74bb6cb1a1..5588f9b45c5 100644 --- a/api/lib/domain/services/certification-candidates-ods-service.js +++ b/api/lib/domain/services/certification-candidates-ods-service.js @@ -1,21 +1,17 @@ -const readOdsUtils = require('../../infrastructure/utils/ods/read-ods-utils.js'); -const { - getTransformationStructsForPixCertifCandidatesImport, -} = require('../../infrastructure/files/candidates-import/candidates-import-transformation-structures.js'); -const CertificationCandidate = require('../models/CertificationCandidate.js'); -const { +import * as readOdsUtils from '../../infrastructure/utils/ods/read-ods-utils.js'; +import { getTransformationStructsForPixCertifCandidatesImport } from '../../infrastructure/files/candidates-import/candidates-import-transformation-structures.js'; +import { CertificationCandidate } from '../models/CertificationCandidate.js'; +import { CLEA, PIX_PLUS_DROIT, PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE, -} = require('../models/ComplementaryCertification.js'); -const { CertificationCandidatesImportError } = require('../errors.js'); -const _ = require('lodash'); -const bluebird = require('bluebird'); - -module.exports = { - extractCertificationCandidatesFromCandidatesImportSheet, -}; +} from '../models/ComplementaryCertification.js'; +import { CertificationCandidatesImportError } from '../errors.js'; +import _ from 'lodash'; +import bluebird from 'bluebird'; + +export { extractCertificationCandidatesFromCandidatesImportSheet }; async function extractCertificationCandidatesFromCandidatesImportSheet({ i18n, diff --git a/api/lib/domain/services/certification-challenges-service.js b/api/lib/domain/services/certification-challenges-service.js index 39956a185bd..6bcaa24bc7b 100644 --- a/api/lib/domain/services/certification-challenges-service.js +++ b/api/lib/domain/services/certification-challenges-service.js @@ -1,81 +1,81 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const CertificationChallenge = require('../models/CertificationChallenge.js'); +import { CertificationChallenge } from '../models/CertificationChallenge.js'; -const { +import { MAX_CHALLENGES_PER_COMPETENCE_FOR_CERTIFICATION, MAX_CHALLENGES_PER_AREA_FOR_CERTIFICATION_PLUS, PIX_ORIGIN, -} = require('../constants.js'); - -const KnowledgeElement = require('../models/KnowledgeElement.js'); -const Challenge = require('../models/Challenge.js'); - -const challengeRepository = require('../../infrastructure/repositories/challenge-repository.js'); -const answerRepository = require('../../infrastructure/repositories/answer-repository.js'); -const knowledgeElementRepository = require('../../infrastructure/repositories/knowledge-element-repository.js'); -const learningContentRepository = require('../../infrastructure/repositories/learning-content-repository.js'); -const certifiableProfileForLearningContentRepository = require('../../infrastructure/repositories/certifiable-profile-for-learning-content-repository.js'); - -module.exports = { - async pickCertificationChallenges( - placementProfile, - locale, - injectedKnowledgeElementRepository = knowledgeElementRepository, - injectedAnswerRepository = answerRepository, - injectedChallengeRepository = challengeRepository - ) { - const certifiableUserCompetences = placementProfile.getCertifiableUserCompetences(); - - const alreadyAnsweredChallengeIds = await _getAlreadyAnsweredChallengeIds( - injectedKnowledgeElementRepository, - injectedAnswerRepository, - placementProfile.userId, - placementProfile.profileDate - ); +} from '../constants.js'; - const allOperativeChallengesForLocale = await injectedChallengeRepository.findOperativeHavingLocale(locale); +import { KnowledgeElement } from '../models/KnowledgeElement.js'; +import { Challenge } from '../models/Challenge.js'; - return _pickCertificationChallengesForCertifiableCompetences( - certifiableUserCompetences, - alreadyAnsweredChallengeIds, - allOperativeChallengesForLocale - ); - }, +import * as challengeRepository from '../../infrastructure/repositories/challenge-repository.js'; +import * as answerRepository from '../../infrastructure/repositories/answer-repository.js'; +import * as knowledgeElementRepository from '../../infrastructure/repositories/knowledge-element-repository.js'; +import * as learningContentRepository from '../../infrastructure/repositories/learning-content-repository.js'; +import * as certifiableProfileForLearningContentRepository from '../../infrastructure/repositories/certifiable-profile-for-learning-content-repository.js'; - async pickCertificationChallengesForPixPlus( - campaignId, - badgeKey, - userId, - locale, - injectedLearningContentRepository = learningContentRepository, - injectedCertifiableProfileForLearningContentRepository = certifiableProfileForLearningContentRepository, - injectedChallengeRepository = challengeRepository - ) { - const learningContent = await injectedLearningContentRepository.findByCampaignId(campaignId, locale); - const certifiableProfile = await injectedCertifiableProfileForLearningContentRepository.get({ - id: userId, - profileDate: new Date(), - learningContent, - }); +const pickCertificationChallenges = async function ( + placementProfile, + locale, + injectedKnowledgeElementRepository = knowledgeElementRepository, + injectedAnswerRepository = answerRepository, + injectedChallengeRepository = challengeRepository +) { + const certifiableUserCompetences = placementProfile.getCertifiableUserCompetences(); - const excludedOrigins = [PIX_ORIGIN]; - const skillIdsByDecreasingDifficultyGroupedByArea = - certifiableProfile.getOrderedCertifiableSkillsByDecreasingDifficultyGroupedByAreaId(excludedOrigins); + const alreadyAnsweredChallengeIds = await _getAlreadyAnsweredChallengeIds( + injectedKnowledgeElementRepository, + injectedAnswerRepository, + placementProfile.userId, + placementProfile.profileDate + ); - const alreadyAnsweredChallengeIds = certifiableProfile.getAlreadyAnsweredChallengeIds(); + const allOperativeChallengesForLocale = await injectedChallengeRepository.findOperativeHavingLocale(locale); - const allOperativeChallengesForLocale = await injectedChallengeRepository.findOperativeHavingLocale(locale); - return _pickCertificationChallengesForAllAreas( - skillIdsByDecreasingDifficultyGroupedByArea, - alreadyAnsweredChallengeIds, - allOperativeChallengesForLocale, - learningContent, - badgeKey - ); - }, + return _pickCertificationChallengesForCertifiableCompetences( + certifiableUserCompetences, + alreadyAnsweredChallengeIds, + allOperativeChallengesForLocale + ); +}; + +const pickCertificationChallengesForPixPlus = async function ( + campaignId, + badgeKey, + userId, + locale, + injectedLearningContentRepository = learningContentRepository, + injectedCertifiableProfileForLearningContentRepository = certifiableProfileForLearningContentRepository, + injectedChallengeRepository = challengeRepository +) { + const learningContent = await injectedLearningContentRepository.findByCampaignId(campaignId, locale); + const certifiableProfile = await injectedCertifiableProfileForLearningContentRepository.get({ + id: userId, + profileDate: new Date(), + learningContent, + }); + + const excludedOrigins = [PIX_ORIGIN]; + const skillIdsByDecreasingDifficultyGroupedByArea = + certifiableProfile.getOrderedCertifiableSkillsByDecreasingDifficultyGroupedByAreaId(excludedOrigins); + + const alreadyAnsweredChallengeIds = certifiableProfile.getAlreadyAnsweredChallengeIds(); + + const allOperativeChallengesForLocale = await injectedChallengeRepository.findOperativeHavingLocale(locale); + return _pickCertificationChallengesForAllAreas( + skillIdsByDecreasingDifficultyGroupedByArea, + alreadyAnsweredChallengeIds, + allOperativeChallengesForLocale, + learningContent, + badgeKey + ); }; +export { pickCertificationChallenges, pickCertificationChallengesForPixPlus }; + async function _getAlreadyAnsweredChallengeIds( injectedKnowledgeElementRepository = knowledgeElementRepository, injectedAnswerRepository = answerRepository, diff --git a/api/lib/domain/services/certification-cpf-service.js b/api/lib/domain/services/certification-cpf-service.js index 53f30503711..479964ca763 100644 --- a/api/lib/domain/services/certification-cpf-service.js +++ b/api/lib/domain/services/certification-cpf-service.js @@ -1,6 +1,9 @@ -const { normalizeAndSortChars } = require('../../infrastructure/utils/string-utils.js'); -const isEmpty = require('lodash/isEmpty'); -const { CERTIFICATION_CANDIDATES_ERRORS } = require('../constants/certification-candidates-errors'); +import { normalizeAndSortChars } from '../../infrastructure/utils/string-utils.js'; +import lodash from 'lodash'; + +const { isEmpty } = lodash; + +import { CERTIFICATION_CANDIDATES_ERRORS } from '../constants/certification-candidates-errors.js'; const CpfValidationStatus = { FAILURE: 'FAILURE', @@ -238,8 +241,4 @@ function _getActualCity(cities) { return actualCity.name; } -module.exports = { - getBirthInformation, - CpfBirthInformationValidation, - CpfValidationStatus, -}; +export { getBirthInformation, CpfBirthInformationValidation, CpfValidationStatus }; diff --git a/api/lib/domain/services/course-service.js b/api/lib/domain/services/course-service.js index f93f788cd4a..397c77546e0 100644 --- a/api/lib/domain/services/course-service.js +++ b/api/lib/domain/services/course-service.js @@ -1,21 +1,21 @@ -const _ = require('lodash'); -const Course = require('../models/Course.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import _ from 'lodash'; +import { Course } from '../models/Course.js'; +import { NotFoundError } from '../../domain/errors.js'; -const courseRepository = require('../../infrastructure/repositories/course-repository.js'); +import * as courseRepository from '../../infrastructure/repositories/course-repository.js'; -module.exports = { - async getCourse({ courseId, dependencies = { courseRepository } }) { - // TODO: delete when campaign assessment does not have courses anymore - if (_.startsWith(courseId, '[NOT USED] Campaign')) { - return Promise.resolve(new Course({ id: courseId })); - } +const getCourse = async function ({ courseId, dependencies = { courseRepository } }) { + // TODO: delete when campaign assessment does not have courses anymore + if (_.startsWith(courseId, '[NOT USED] Campaign')) { + return Promise.resolve(new Course({ id: courseId })); + } - // TODO This repo switch should not be here because we make a technical discrimination on the course id - if (_.startsWith(courseId, 'rec')) { - return dependencies.courseRepository.get(courseId); - } + // TODO This repo switch should not be here because we make a technical discrimination on the course id + if (_.startsWith(courseId, 'rec')) { + return dependencies.courseRepository.get(courseId); + } - throw new NotFoundError(); - }, + throw new NotFoundError(); }; + +export { getCourse }; diff --git a/api/lib/domain/services/cpf-certification-xml-export-service.js b/api/lib/domain/services/cpf-certification-xml-export-service.js index 00b350c9617..ef2c444d1d5 100644 --- a/api/lib/domain/services/cpf-certification-xml-export-service.js +++ b/api/lib/domain/services/cpf-certification-xml-export-service.js @@ -1,16 +1,18 @@ -const { cpf } = require('../../config.js'); -const { create, fragment } = require('xmlbuilder2'); -const { v4: uuidv4 } = require('uuid'); -const dayjs = require('dayjs'); -const utc = require('dayjs/plugin/utc'); -const timezone = require('dayjs/plugin/timezone'); +import { config } from '../../config.js'; +import xmlbuilder2 from 'xmlbuilder2'; + +const { create, fragment } = xmlbuilder2; + +import dayjs from 'dayjs'; +import utc from 'dayjs/plugin/utc.js'; +import timezone from 'dayjs/plugin/timezone.js'; dayjs.extend(utc); dayjs.extend(timezone); const schemaVersion = '1.0.0'; - +const { cpf } = config; // prettier-ignore -async function buildXmlExport({ cpfCertificationResults, writableStream, opts = {}}) { +async function buildXmlExport({ cpfCertificationResults, writableStream, opts = {}, uuidService}) { const overrideOpts = { allowEmptyTags: true, }; const PLACEHOLDER = 'PLACEHOLDER'; const formatedDate = dayjs().tz('Europe/Paris').format('YYYY-MM-DDThh:mm:ss') + '+01:00'; @@ -19,7 +21,7 @@ async function buildXmlExport({ cpfCertificationResults, writableStream, opts = 'xmlns:cpf': `urn:cdc:cpf:pc5:schema:${schemaVersion}`, 'xmlns:xsi': 'http://www.w3.org/2001/XMLSchema-instance', }) - .ele('cpf:idFlux').txt(uuidv4()).up() + .ele('cpf:idFlux').txt(uuidService.v4()).up() .ele('cpf:horodatage').txt(formatedDate).up() .ele('cpf:emetteur') .ele('cpf:idClient').txt(cpf.idClient).up() @@ -143,7 +145,7 @@ async function buildXmlExport({ cpfCertificationResults, writableStream, opts = } communeNaissance .up() - + details .ele('cpf:libelleCommuneNaissance').txt(birthplace) .up() @@ -161,14 +163,12 @@ async function buildXmlExport({ cpfCertificationResults, writableStream, opts = .up(); await _write(writableStream, line.end({ ...opts, ...overrideOpts, })); } - + await _write(writableStream, headerClosingTag); writableStream.end(); } -module.exports = { - buildXmlExport, -}; +export { buildXmlExport }; function _write(writableStream, data) { return new Promise((resolve) => { diff --git a/api/lib/domain/services/email-validator.js b/api/lib/domain/services/email-validator.js index 1fba6868ad8..af652ba9981 100644 --- a/api/lib/domain/services/email-validator.js +++ b/api/lib/domain/services/email-validator.js @@ -1,12 +1,12 @@ -module.exports = { - emailIsValid(email) { - if (!email) { - return false; - } - // Source: http://stackoverflow.com/a/46181/5430854 - const pattern = - /^(([^<>()[\].,;:\s@"]+(\.[^<>()[\].,;:\s@"]+)*)|(".+"))@(([^<>()[\].,;:\s@"]+\.)+[^<>()[\].,;:\s@"]{2,})$/i; +const emailIsValid = function (email) { + if (!email) { + return false; + } + // Source: http://stackoverflow.com/a/46181/5430854 + const pattern = + /^(([^<>()[\].,;:\s@"]+(\.[^<>()[\].,;:\s@"]+)*)|(".+"))@(([^<>()[\].,;:\s@"]+\.)+[^<>()[\].,;:\s@"]{2,})$/i; - return pattern.test(email.trim()); - }, + return pattern.test(email.trim()); }; + +export { emailIsValid }; diff --git a/api/lib/domain/services/encryption-service.js b/api/lib/domain/services/encryption-service.js index f9df77c3cae..842fdf7dfb8 100644 --- a/api/lib/domain/services/encryption-service.js +++ b/api/lib/domain/services/encryption-service.js @@ -1,7 +1,7 @@ -const bcrypt = require('bcrypt'); -const { bcryptNumberOfSaltRounds } = require('../../config.js'); -const PasswordNotMatching = require('../errors.js').PasswordNotMatching; - +import bcrypt from 'bcrypt'; +import { config } from '../../config.js'; +import { PasswordNotMatching } from '../errors.js'; +const { bcryptNumberOfSaltRounds } = config; const hashPassword = function (password) { return bcrypt.hash(password, bcryptNumberOfSaltRounds); }; @@ -18,8 +18,4 @@ const checkPassword = async function ({ password, passwordHash }) { } }; -module.exports = { - hashPassword, - hashPasswordSync, - checkPassword, -}; +export { hashPassword, hashPasswordSync, checkPassword }; diff --git a/api/lib/domain/services/get-competence-level.js b/api/lib/domain/services/get-competence-level.js index 06c235198bc..2dc7a86c904 100644 --- a/api/lib/domain/services/get-competence-level.js +++ b/api/lib/domain/services/get-competence-level.js @@ -1,10 +1,11 @@ -const knowledgeElementRepository = require('../../infrastructure/repositories/knowledge-element-repository.js'); -const scoringService = require('./scoring/scoring-service.js'); +import * as knowledgeElementRepository from '../../infrastructure/repositories/knowledge-element-repository.js'; +import * as scoringService from './scoring/scoring-service.js'; -module.exports = async function getCompetenceLevel({ +const getCompetenceLevel = async function ({ userId, competenceId, domainTransaction, + dependencies = { knowledgeElementRepository, scoringService, @@ -18,3 +19,5 @@ module.exports = async function getCompetenceLevel({ const { currentLevel } = dependencies.scoringService.calculateScoringInformationForCompetence({ knowledgeElements }); return currentLevel; }; + +export { getCompetenceLevel }; diff --git a/api/lib/domain/services/get-translated-text.js b/api/lib/domain/services/get-translated-text.js index 1cb9de69001..e5db442d177 100644 --- a/api/lib/domain/services/get-translated-text.js +++ b/api/lib/domain/services/get-translated-text.js @@ -1,7 +1,9 @@ -const { FRENCH_SPOKEN } = require('../../domain/constants.js').LOCALE; +import { LOCALE } from '../../domain/constants.js'; + +const { FRENCH_SPOKEN } = LOCALE; function getTranslatedKey(key, locale) { return key?.[locale] || key?.[FRENCH_SPOKEN]; } -module.exports = { getTranslatedKey }; +export { getTranslatedKey }; diff --git a/api/lib/domain/services/improvement-service.js b/api/lib/domain/services/improvement-service.js index 276af826862..fd7bc4775c2 100644 --- a/api/lib/domain/services/improvement-service.js +++ b/api/lib/domain/services/improvement-service.js @@ -1,5 +1,5 @@ -const { constants } = require('../constants.js'); -const moment = require('moment'); +import { constants } from '../constants.js'; +import moment from 'moment'; function _keepKnowledgeElementsRecentOrValidated({ currentUserKnowledgeElements, assessment, minimumDelayInDays }) { const startedDateOfAssessment = assessment.createdAt; @@ -26,6 +26,4 @@ function filterKnowledgeElementsIfImproving({ knowledgeElements, assessment, isR return knowledgeElements; } -module.exports = { - filterKnowledgeElementsIfImproving, -}; +export { filterKnowledgeElementsIfImproving }; diff --git a/api/lib/domain/services/learning-content/learning-content-conversion-service.js b/api/lib/domain/services/learning-content/learning-content-conversion-service.js index 08484dfd002..d03ebe5d875 100644 --- a/api/lib/domain/services/learning-content/learning-content-conversion-service.js +++ b/api/lib/domain/services/learning-content/learning-content-conversion-service.js @@ -1,4 +1,4 @@ -const skillRepository = require('../../../infrastructure/repositories/skill-repository.js'); +import * as skillRepository from '../../../infrastructure/repositories/skill-repository.js'; async function findActiveSkillsForCappedTubes(cappedTubes, dependencies = { skillRepository }) { const skills = []; @@ -10,6 +10,4 @@ async function findActiveSkillsForCappedTubes(cappedTubes, dependencies = { skil return skills; } -module.exports = { - findActiveSkillsForCappedTubes, -}; +export { findActiveSkillsForCappedTubes }; diff --git a/api/lib/domain/services/locale-service.js b/api/lib/domain/services/locale-service.js index ed7074b62f2..ae361a1f34b 100644 --- a/api/lib/domain/services/locale-service.js +++ b/api/lib/domain/services/locale-service.js @@ -1,26 +1,26 @@ -const { LocaleFormatError, LocaleNotSupportedError } = require('../errors'); -const { SUPPORTED_LOCALES } = require('../constants'); +import { LocaleFormatError, LocaleNotSupportedError } from '../errors.js'; +import { SUPPORTED_LOCALES } from '../constants.js'; -module.exports = { - getCanonicalLocale(locale) { - let canonicalLocale; +const getCanonicalLocale = function (locale) { + let canonicalLocale; - try { - canonicalLocale = Intl.getCanonicalLocales(locale)[0]; - } catch (error) { - throw new LocaleFormatError(locale); - } + try { + canonicalLocale = Intl.getCanonicalLocales(locale)[0]; + } catch (error) { + throw new LocaleFormatError(locale); + } - // Pix site uses en-GB as international English locale instead of en - // TODO remove this code after handling en as international English locale on Pix site - if (canonicalLocale === 'en-GB') { - canonicalLocale = 'en'; - } + // Pix site uses en-GB as international English locale instead of en + // TODO remove this code after handling en as international English locale on Pix site + if (canonicalLocale === 'en-GB') { + canonicalLocale = 'en'; + } - if (!SUPPORTED_LOCALES.includes(canonicalLocale)) { - throw new LocaleNotSupportedError(canonicalLocale); - } + if (!SUPPORTED_LOCALES.includes(canonicalLocale)) { + throw new LocaleNotSupportedError(canonicalLocale); + } - return canonicalLocale; - }, + return canonicalLocale; }; + +export { getCanonicalLocale }; diff --git a/api/lib/domain/services/mail-service.js b/api/lib/domain/services/mail-service.js index 6eb1f27fe91..b6efe81a69f 100644 --- a/api/lib/domain/services/mail-service.js +++ b/api/lib/domain/services/mail-service.js @@ -1,13 +1,15 @@ -const dayjs = require('dayjs'); +import dayjs from 'dayjs'; -const tokenService = require('./token-service.js'); -const { mailer } = require('../../infrastructure/mailers/mailer.js'); -const settings = require('../../config.js'); +import { tokenService } from './token-service.js'; +import { mailer } from '../../infrastructure/mailers/mailer.js'; +import { config } from '../../config.js'; -const frTranslations = require('../../../translations/fr.json'); -const enTranslations = require('../../../translations/en.json'); +import frTranslations from '../../../translations/fr.json' assert { type: 'json' }; +import enTranslations from '../../../translations/en.json' assert { type: 'json' }; -const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = require('../../domain/constants.js').LOCALE; +import { LOCALE } from '../../domain/constants.js'; + +const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = LOCALE; const EMAIL_ADDRESS_NO_RESPONSE = 'ne-pas-repondre@pix.fr'; const PIX_ORGA_NAME_FR = 'Pix Orga - Ne pas répondre'; @@ -19,10 +21,10 @@ const PIX_NAME_EN = 'PIX - Noreply'; const HELPDESK_FRENCH_FRANCE = 'https://support.pix.fr'; const HELPDESK_ENGLISH_SPOKEN = 'https://support.pix.org/en/support/home'; const HELPDESK_FRENCH_SPOKEN = 'https://support.pix.org'; -const PIX_HOME_NAME_INTERNATIONAL = `pix${settings.domain.tldOrg}`; -const PIX_HOME_NAME_FRENCH_FRANCE = `pix${settings.domain.tldFr}`; -const PIX_HOME_URL_ENGLISH_SPOKEN = `${settings.domain.pix + settings.domain.tldOrg}/en-gb`; -const PIX_HOME_URL_FRENCH_FRANCE = `${settings.domain.pix + settings.domain.tldFr}`; +const PIX_HOME_NAME_INTERNATIONAL = `pix${config.domain.tldOrg}`; +const PIX_HOME_NAME_FRENCH_FRANCE = `pix${config.domain.tldFr}`; +const PIX_HOME_URL_ENGLISH_SPOKEN = `${config.domain.pix + config.domain.tldOrg}/en-gb`; +const PIX_HOME_URL_FRENCH_FRANCE = `${config.domain.pix + config.domain.tldFr}`; const EMAIL_VERIFICATION_CODE_TAG = 'EMAIL_VERIFICATION_CODE'; const SCO_ACCOUNT_RECOVERY_TAG = 'SCO_ACCOUNT_RECOVERY'; @@ -34,9 +36,9 @@ function sendAccountCreationEmail(email, locale, redirectionUrl) { if (locale === FRENCH_SPOKEN) { variables = { - homeName: `pix${settings.domain.tldOrg}`, - homeUrl: `${settings.domain.pix + settings.domain.tldOrg}/fr/`, - redirectionUrl: redirectionUrl || `${settings.domain.pixApp + settings.domain.tldOrg}/connexion/?lang=fr`, + homeName: `pix${config.domain.tldOrg}`, + homeUrl: `${config.domain.pix + config.domain.tldOrg}/fr/`, + redirectionUrl: redirectionUrl || `${config.domain.pixApp + config.domain.tldOrg}/connexion/?lang=fr`, helpdeskUrl: HELPDESK_FRENCH_SPOKEN, displayNationalLogo: false, ...frTranslations['pix-account-creation-email'].params, @@ -46,9 +48,9 @@ function sendAccountCreationEmail(email, locale, redirectionUrl) { accountCreationEmailSubject = frTranslations['pix-account-creation-email'].subject; } else if (locale === ENGLISH_SPOKEN) { variables = { - homeName: `pix${settings.domain.tldOrg}`, - homeUrl: `${settings.domain.pix + settings.domain.tldOrg}/en-gb/`, - redirectionUrl: redirectionUrl || `${settings.domain.pixApp + settings.domain.tldOrg}/connexion/?lang=en`, + homeName: `pix${config.domain.tldOrg}`, + homeUrl: `${config.domain.pix + config.domain.tldOrg}/en-gb/`, + redirectionUrl: redirectionUrl || `${config.domain.pixApp + config.domain.tldOrg}/connexion/?lang=en`, helpdeskUrl: HELPDESK_ENGLISH_SPOKEN, displayNationalLogo: false, ...enTranslations['pix-account-creation-email'].params, @@ -58,9 +60,9 @@ function sendAccountCreationEmail(email, locale, redirectionUrl) { accountCreationEmailSubject = enTranslations['pix-account-creation-email'].subject; } else { variables = { - homeName: `pix${settings.domain.tldFr}`, - homeUrl: `${settings.domain.pix + settings.domain.tldFr}`, - redirectionUrl: redirectionUrl || `${settings.domain.pixApp + settings.domain.tldFr}/connexion`, + homeName: `pix${config.domain.tldFr}`, + homeUrl: `${config.domain.pix + config.domain.tldFr}`, + redirectionUrl: redirectionUrl || `${config.domain.pixApp + config.domain.tldFr}/connexion`, helpdeskUrl: HELPDESK_FRENCH_FRANCE, displayNationalLogo: true, ...frTranslations['pix-account-creation-email'].params, @@ -94,7 +96,7 @@ function sendCertificationResultEmail({ resultRecipientEmail, daysBeforeExpiration, }); - const link = `${settings.domain.pixApp + settings.domain.tldOrg}/api/sessions/download-results/${token}`; + const link = `${config.domain.pixApp + config.domain.tldOrg}/api/sessions/download-results/${token}`; const formattedSessionDate = dayjs(sessionDate).locale('fr').format('DD/MM/YYYY'); @@ -135,18 +137,18 @@ function sendResetPasswordDemandEmail({ email, locale, temporaryKey }) { let templateParams = { locale: localeParam, ...frTranslations['reset-password-demand-email'].params, - homeName: `pix${settings.domain.tldFr}`, - homeUrl: `${settings.domain.pix + settings.domain.tldFr}`, - resetUrl: `${settings.domain.pixApp + settings.domain.tldFr}/changer-mot-de-passe/${temporaryKey}`, + homeName: `pix${config.domain.tldFr}`, + homeUrl: `${config.domain.pix + config.domain.tldFr}`, + resetUrl: `${config.domain.pixApp + config.domain.tldFr}/changer-mot-de-passe/${temporaryKey}`, helpdeskURL: HELPDESK_FRENCH_FRANCE, }; if (localeParam === FRENCH_SPOKEN) { templateParams = { ...templateParams, - homeName: `pix${settings.domain.tldOrg}`, - homeUrl: `${settings.domain.pix + settings.domain.tldOrg}/fr/`, - resetUrl: `${settings.domain.pixApp + settings.domain.tldOrg}/changer-mot-de-passe/${temporaryKey}/?lang=fr`, + homeName: `pix${config.domain.tldOrg}`, + homeUrl: `${config.domain.pix + config.domain.tldOrg}/fr/`, + resetUrl: `${config.domain.pixApp + config.domain.tldOrg}/changer-mot-de-passe/${temporaryKey}/?lang=fr`, helpdeskURL: HELPDESK_FRENCH_SPOKEN, }; } @@ -155,9 +157,9 @@ function sendResetPasswordDemandEmail({ email, locale, temporaryKey }) { templateParams = { locale: localeParam, ...enTranslations['reset-password-demand-email'].params, - homeName: `pix${settings.domain.tldOrg}`, - homeUrl: `${settings.domain.pix + settings.domain.tldOrg}/en-gb/`, - resetUrl: `${settings.domain.pixApp + settings.domain.tldOrg}/changer-mot-de-passe/${temporaryKey}/?lang=en`, + homeName: `pix${config.domain.tldOrg}`, + homeUrl: `${config.domain.pix + config.domain.tldOrg}/en-gb/`, + resetUrl: `${config.domain.pixApp + config.domain.tldOrg}/changer-mot-de-passe/${temporaryKey}/?lang=en`, helpdeskURL: HELPDESK_ENGLISH_SPOKEN, }; @@ -182,11 +184,11 @@ function sendOrganizationInvitationEmail({ email, organizationName, organization let templateParams = { organizationName, - pixHomeName: `pix${settings.domain.tldFr}`, - pixHomeUrl: `${settings.domain.pix + settings.domain.tldFr}`, - pixOrgaHomeUrl: `${settings.domain.pixOrga + settings.domain.tldFr}`, + pixHomeName: `pix${config.domain.tldFr}`, + pixHomeUrl: `${config.domain.pix + config.domain.tldFr}`, + pixOrgaHomeUrl: `${config.domain.pixOrga + config.domain.tldFr}`, redirectionUrl: `${ - settings.domain.pixOrga + settings.domain.tldFr + config.domain.pixOrga + config.domain.tldFr }/rejoindre?invitationId=${organizationInvitationId}&code=${code}`, supportUrl: HELPDESK_FRENCH_FRANCE, ...frTranslations['organization-invitation-email'].params, @@ -195,11 +197,11 @@ function sendOrganizationInvitationEmail({ email, organizationName, organization if (locale === FRENCH_SPOKEN) { templateParams = { organizationName, - pixHomeName: `pix${settings.domain.tldOrg}`, - pixHomeUrl: `${settings.domain.pix + settings.domain.tldOrg}`, - pixOrgaHomeUrl: `${settings.domain.pixOrga + settings.domain.tldOrg}`, + pixHomeName: `pix${config.domain.tldOrg}`, + pixHomeUrl: `${config.domain.pix + config.domain.tldOrg}`, + pixOrgaHomeUrl: `${config.domain.pixOrga + config.domain.tldOrg}`, redirectionUrl: `${ - settings.domain.pixOrga + settings.domain.tldOrg + config.domain.pixOrga + config.domain.tldOrg }/rejoindre?invitationId=${organizationInvitationId}&code=${code}`, supportUrl: HELPDESK_FRENCH_SPOKEN, ...frTranslations['organization-invitation-email'].params, @@ -209,11 +211,11 @@ function sendOrganizationInvitationEmail({ email, organizationName, organization if (locale === ENGLISH_SPOKEN) { templateParams = { organizationName, - pixHomeName: `pix${settings.domain.tldOrg}`, - pixHomeUrl: `${settings.domain.pix + settings.domain.tldOrg}/en-gb/`, - pixOrgaHomeUrl: `${settings.domain.pixOrga + settings.domain.tldOrg}?lang=en`, + pixHomeName: `pix${config.domain.tldOrg}`, + pixHomeUrl: `${config.domain.pix + config.domain.tldOrg}/en-gb/`, + pixOrgaHomeUrl: `${config.domain.pixOrga + config.domain.tldOrg}?lang=en`, redirectionUrl: `${ - settings.domain.pixOrga + settings.domain.tldOrg + config.domain.pixOrga + config.domain.tldOrg }/rejoindre?invitationId=${organizationInvitationId}&code=${code}&lang=en`, supportUrl: HELPDESK_ENGLISH_SPOKEN, ...enTranslations['organization-invitation-email'].params, @@ -249,11 +251,11 @@ function sendScoOrganizationInvitationEmail({ organizationName, firstName, lastName, - pixHomeName: `pix${settings.domain.tldFr}`, - pixHomeUrl: `${settings.domain.pix + settings.domain.tldFr}`, - pixOrgaHomeUrl: `${settings.domain.pixOrga + settings.domain.tldFr}`, + pixHomeName: `pix${config.domain.tldFr}`, + pixHomeUrl: `${config.domain.pix + config.domain.tldFr}`, + pixOrgaHomeUrl: `${config.domain.pixOrga + config.domain.tldFr}`, redirectionUrl: `${ - settings.domain.pixOrga + settings.domain.tldFr + config.domain.pixOrga + config.domain.tldFr }/rejoindre?invitationId=${organizationInvitationId}&code=${code}`, locale, }; @@ -263,11 +265,11 @@ function sendScoOrganizationInvitationEmail({ organizationName, firstName, lastName, - pixHomeName: `pix${settings.domain.tldOrg}`, - pixHomeUrl: `${settings.domain.pix + settings.domain.tldOrg}`, - pixOrgaHomeUrl: `${settings.domain.pixOrga + settings.domain.tldOrg}`, + pixHomeName: `pix${config.domain.tldOrg}`, + pixHomeUrl: `${config.domain.pix + config.domain.tldOrg}`, + pixOrgaHomeUrl: `${config.domain.pixOrga + config.domain.tldOrg}`, redirectionUrl: `${ - settings.domain.pixOrga + settings.domain.tldOrg + config.domain.pixOrga + config.domain.tldOrg }/rejoindre?invitationId=${organizationInvitationId}&code=${code}`, locale, }; @@ -294,33 +296,33 @@ function sendCertificationCenterInvitationEmail({ let templateParams, fromName, subject; const frenchFranceTemplateParams = { certificationCenterName, - pixHomeName: `pix${settings.domain.tldFr}`, - pixHomeUrl: `${settings.domain.pix + settings.domain.tldFr}`, - pixCertifHomeUrl: `${settings.domain.pixCertif + settings.domain.tldFr}`, + pixHomeName: `pix${config.domain.tldFr}`, + pixHomeUrl: `${config.domain.pix + config.domain.tldFr}`, + pixCertifHomeUrl: `${config.domain.pixCertif + config.domain.tldFr}`, redirectionUrl: `${ - settings.domain.pixCertif + settings.domain.tldFr + config.domain.pixCertif + config.domain.tldFr }/rejoindre?invitationId=${certificationCenterInvitationId}&code=${code}`, supportUrl: HELPDESK_FRENCH_FRANCE, ...frTranslations['certification-center-invitation-email'].params, }; const frenchSpokenTemplateParams = { certificationCenterName, - pixHomeName: `pix${settings.domain.tldOrg}`, - pixHomeUrl: `${settings.domain.pix + settings.domain.tldOrg}`, - pixCertifHomeUrl: `${settings.domain.pixCertif + settings.domain.tldOrg}`, + pixHomeName: `pix${config.domain.tldOrg}`, + pixHomeUrl: `${config.domain.pix + config.domain.tldOrg}`, + pixCertifHomeUrl: `${config.domain.pixCertif + config.domain.tldOrg}`, redirectionUrl: `${ - settings.domain.pixCertif + settings.domain.tldOrg + config.domain.pixCertif + config.domain.tldOrg }/rejoindre?invitationId=${certificationCenterInvitationId}&code=${code}`, supportUrl: HELPDESK_FRENCH_SPOKEN, ...frTranslations['certification-center-invitation-email'].params, }; const englishSpokenTemplateParams = { certificationCenterName, - pixHomeName: `pix${settings.domain.tldOrg}`, - pixHomeUrl: `${settings.domain.pix + settings.domain.tldOrg}/en-gb/`, - pixCertifHomeUrl: `${settings.domain.pixCertif + settings.domain.tldOrg}?lang=en`, + pixHomeName: `pix${config.domain.tldOrg}`, + pixHomeUrl: `${config.domain.pix + config.domain.tldOrg}/en-gb/`, + pixCertifHomeUrl: `${config.domain.pixCertif + config.domain.tldOrg}?lang=en`, redirectionUrl: `${ - settings.domain.pixCertif + settings.domain.tldOrg + config.domain.pixCertif + config.domain.tldOrg }/rejoindre?invitationId=${certificationCenterInvitationId}&code=${code}&lang=en`, supportUrl: HELPDESK_ENGLISH_SPOKEN, ...enTranslations['certification-center-invitation-email'].params, @@ -358,11 +360,11 @@ function sendCertificationCenterInvitationEmail({ function sendAccountRecoveryEmail({ email, firstName, temporaryKey }) { const pixName = PIX_NAME_FR; - const redirectionUrl = `${settings.domain.pixApp + settings.domain.tldFr}/recuperer-mon-compte/${temporaryKey}`; + const redirectionUrl = `${config.domain.pixApp + config.domain.tldFr}/recuperer-mon-compte/${temporaryKey}`; const variables = { firstName, redirectionUrl, - homeName: `pix${settings.domain.tldFr}`, + homeName: `pix${config.domain.tldFr}`, ...frTranslations['account-recovery-email'].params, }; @@ -391,8 +393,8 @@ function sendVerificationCodeEmail({ code, email, locale, translate }) { options.variables = { code, - homeName: `pix${settings.domain.tldOrg}`, - homeUrl: `${settings.domain.pix + settings.domain.tldOrg}/fr/`, + homeName: `pix${config.domain.tldOrg}`, + homeUrl: `${config.domain.pix + config.domain.tldOrg}/fr/`, displayNationalLogo: false, ...frTranslations['verification-code-email'].body, }; @@ -401,8 +403,8 @@ function sendVerificationCodeEmail({ code, email, locale, translate }) { options.variables = { code, - homeName: `pix${settings.domain.tldFr}`, - homeUrl: `${settings.domain.pix + settings.domain.tldFr}`, + homeName: `pix${config.domain.tldFr}`, + homeUrl: `${config.domain.pix + config.domain.tldFr}`, displayNationalLogo: true, ...frTranslations['verification-code-email'].body, }; @@ -411,8 +413,8 @@ function sendVerificationCodeEmail({ code, email, locale, translate }) { options.variables = { code, - homeName: `pix${settings.domain.tldOrg}`, - homeUrl: `${settings.domain.pix + settings.domain.tldOrg}/en-gb/`, + homeName: `pix${config.domain.tldOrg}`, + homeUrl: `${config.domain.pix + config.domain.tldOrg}/en-gb/`, displayNationalLogo: false, ...enTranslations['verification-code-email'].body, }; @@ -447,7 +449,19 @@ function sendNotificationToCertificationCenterRefererForCleaResults({ email, ses return mailer.sendEmail(options); } -module.exports = { +const mailService = { + sendAccountCreationEmail, + sendAccountRecoveryEmail, + sendCertificationResultEmail, + sendOrganizationInvitationEmail, + sendScoOrganizationInvitationEmail, + sendCertificationCenterInvitationEmail, + sendResetPasswordDemandEmail, + sendVerificationCodeEmail, + sendCpfEmail, + sendNotificationToCertificationCenterRefererForCleaResults, +}; +export { sendAccountCreationEmail, sendAccountRecoveryEmail, sendCertificationResultEmail, @@ -458,4 +472,5 @@ module.exports = { sendVerificationCodeEmail, sendCpfEmail, sendNotificationToCertificationCenterRefererForCleaResults, + mailService, }; diff --git a/api/lib/domain/services/obfuscation-service.js b/api/lib/domain/services/obfuscation-service.js index 75954da46b4..cab08ea2b96 100644 --- a/api/lib/domain/services/obfuscation-service.js +++ b/api/lib/domain/services/obfuscation-service.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const authenticationMethodRepository = require('../../infrastructure/repositories/authentication-method-repository.js'); -const AuthenticationMethod = require('../models/AuthenticationMethod.js'); -const { NotFoundError } = require('../errors.js'); +import _ from 'lodash'; +import * as authenticationMethodRepository from '../../infrastructure/repositories/authentication-method-repository.js'; +import { AuthenticationMethod } from '../models/AuthenticationMethod.js'; +import { NotFoundError } from '../errors.js'; const CONNEXION_TYPES = { username: 'username', @@ -46,8 +46,4 @@ function usernameObfuscation(username) { )}${ASTERISK_OBFUSCATION}${_.last(name)}`; } -module.exports = { - usernameObfuscation, - emailObfuscation, - getUserAuthenticationMethodWithObfuscation, -}; +export { usernameObfuscation, emailObfuscation, getUserAuthenticationMethodWithObfuscation }; diff --git a/api/lib/domain/services/organization-invitation-service.js b/api/lib/domain/services/organization-invitation-service.js index d27404cb7f6..eae62e1341d 100644 --- a/api/lib/domain/services/organization-invitation-service.js +++ b/api/lib/domain/services/organization-invitation-service.js @@ -1,11 +1,12 @@ -const randomString = require('randomstring'); -const Membership = require('../models/Membership.js'); -const mailService = require('../../domain/services/mail-service.js'); -const { +import randomString from 'randomstring'; +import { Membership } from '../models/Membership.js'; +import * as mailService from '../../domain/services/mail-service.js'; + +import { SendingEmailError, SendingEmailToInvalidDomainError, SendingEmailToInvalidEmailAddressError, -} = require('../errors.js'); +} from '../errors.js'; const _generateCode = () => { return randomString.generate({ length: 10, capitalization: 'uppercase' }); @@ -135,8 +136,4 @@ const createScoOrganizationInvitation = async ({ return organizationInvitation; }; -module.exports = { - createOrUpdateOrganizationInvitation, - createScoOrganizationInvitation, - createProOrganizationInvitation, -}; +export { createOrUpdateOrganizationInvitation, createScoOrganizationInvitation, createProOrganizationInvitation }; diff --git a/api/lib/domain/services/organization-learners-csv-service.js b/api/lib/domain/services/organization-learners-csv-service.js index b65b89eeb87..a2040e3ae0a 100644 --- a/api/lib/domain/services/organization-learners-csv-service.js +++ b/api/lib/domain/services/organization-learners-csv-service.js @@ -1,9 +1,8 @@ -const fs = require('fs').promises; -const OrganizationLearnerParser = require('../../infrastructure/serializers/csv/organization-learner-parser.js'); +import * as fs from 'fs/promises'; -module.exports = { - extractOrganizationLearnersInformation, -}; +import { OrganizationLearnerParser } from '../../infrastructure/serializers/csv/organization-learner-parser.js'; + +export { extractOrganizationLearnersInformation }; async function extractOrganizationLearnersInformation(path, organization, i18n) { const buffer = await fs.readFile(path); diff --git a/api/lib/domain/services/organization-learners-xml-service.js b/api/lib/domain/services/organization-learners-xml-service.js index 5ca8839f866..3a4fdba31c5 100644 --- a/api/lib/domain/services/organization-learners-xml-service.js +++ b/api/lib/domain/services/organization-learners-xml-service.js @@ -1,8 +1,6 @@ -const SiecleParser = require('../../infrastructure/serializers/xml/siecle-parser.js'); +import { SiecleParser } from '../../infrastructure/serializers/xml/siecle-parser.js'; -module.exports = { - extractOrganizationLearnersInformationFromSIECLE, -}; +export { extractOrganizationLearnersInformationFromSIECLE }; async function extractOrganizationLearnersInformationFromSIECLE(path, organization) { const parser = new SiecleParser(organization, path); diff --git a/api/lib/domain/services/password-generator.js b/api/lib/domain/services/password-generator.js index 402ebfa9ec0..c2a304660f2 100644 --- a/api/lib/domain/services/password-generator.js +++ b/api/lib/domain/services/password-generator.js @@ -1,21 +1,21 @@ -const randomString = require('randomstring'); -const _ = require('lodash'); +import randomString from 'randomstring'; +import _ from 'lodash'; -module.exports = { - generateSimplePassword() { - const letterPart = randomString.generate({ - length: 6, - charset: 'abcdefghjkmnpqrstuvwxyz', - capitalization: 'lowercase', - }); - const numberPart = _.padStart(_.random(99), 2, '0'); - return `${letterPart}${numberPart}`; - }, +const generateSimplePassword = function () { + const letterPart = randomString.generate({ + length: 6, + charset: 'abcdefghjkmnpqrstuvwxyz', + capitalization: 'lowercase', + }); + const numberPart = _.padStart(_.random(99), 2, '0'); + return `${letterPart}${numberPart}`; +}; - generateComplexPassword() { - return randomString.generate({ - length: 32, - charset: 'alphanumeric', - }); - }, +const generateComplexPassword = function () { + return randomString.generate({ + length: 32, + charset: 'alphanumeric', + }); }; + +export { generateSimplePassword, generateComplexPassword }; diff --git a/api/lib/domain/services/pick-challenge-service.js b/api/lib/domain/services/pick-challenge-service.js index 2d03da18b46..6cea6d57501 100644 --- a/api/lib/domain/services/pick-challenge-service.js +++ b/api/lib/domain/services/pick-challenge-service.js @@ -1,31 +1,31 @@ -const _ = require('lodash'); -const hashInt = require('hash-int'); -const pseudoRandom = require('../../infrastructure/utils/pseudo-random'); +import _ from 'lodash'; +import hashInt from 'hash-int'; +import * as pseudoRandom from '../../infrastructure/utils/pseudo-random.js'; const NON_EXISTING_ITEM = null; const VALIDATED_STATUS = 'validé'; -module.exports = { - pickChallenge({ skills, randomSeed, locale }) { - if (skills.length === 0) { - return NON_EXISTING_ITEM; - } - const keyForSkill = Math.abs(hashInt(randomSeed)); - const keyForChallenge = Math.abs(hashInt(randomSeed + 1)); - const chosenSkill = skills[keyForSkill % skills.length]; +const pickChallenge = function ({ skills, randomSeed, locale }) { + if (skills.length === 0) { + return NON_EXISTING_ITEM; + } + const keyForSkill = Math.abs(hashInt(randomSeed)); + const keyForChallenge = Math.abs(hashInt(randomSeed + 1)); + const chosenSkill = skills[keyForSkill % skills.length]; - return _pickLocaleChallengeAtIndex(chosenSkill.challenges, locale, keyForChallenge); - }, + return _pickLocaleChallengeAtIndex(chosenSkill.challenges, locale, keyForChallenge); +}; - chooseNextChallenge({ possibleChallenges, assessmentId }) { - const PROBABILITY_TO_BE_PICKED = 51; - const pseudoRandomContext = pseudoRandom.create(assessmentId); +const chooseNextChallenge = function ({ possibleChallenges, assessmentId }) { + const PROBABILITY_TO_BE_PICKED = 51; + const pseudoRandomContext = pseudoRandom.create(assessmentId); - const challengeIndex = pseudoRandomContext.binaryTreeRandom(PROBABILITY_TO_BE_PICKED, possibleChallenges.length); + const challengeIndex = pseudoRandomContext.binaryTreeRandom(PROBABILITY_TO_BE_PICKED, possibleChallenges.length); - return possibleChallenges[challengeIndex]; - }, + return possibleChallenges[challengeIndex]; }; +export { pickChallenge, chooseNextChallenge }; + function _pickLocaleChallengeAtIndex(challenges, locale, index) { const localeChallenges = _.filter(challenges, (challenge) => _.includes(challenge.locales, locale)); const possibleChallenges = _findPreferablyValidatedChallenges(localeChallenges); diff --git a/api/lib/domain/services/placement-profile-service.js b/api/lib/domain/services/placement-profile-service.js index 29a05839b2d..0dda2f2efef 100644 --- a/api/lib/domain/services/placement-profile-service.js +++ b/api/lib/domain/services/placement-profile-service.js @@ -1,14 +1,14 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); - -const UserCompetence = require('../models/UserCompetence.js'); -const PlacementProfile = require('../models/PlacementProfile.js'); -const assessmentRepository = require('../../infrastructure/repositories/assessment-repository.js'); -const skillRepository = require('../../infrastructure/repositories/skill-repository.js'); -const assessmentResultRepository = require('../../infrastructure/repositories/assessment-result-repository.js'); -const knowledgeElementRepository = require('../../infrastructure/repositories/knowledge-element-repository.js'); -const competenceRepository = require('../../infrastructure/repositories/competence-repository.js'); -const scoringService = require('./scoring/scoring-service.js'); +import _ from 'lodash'; +import bluebird from 'bluebird'; + +import { UserCompetence } from '../models/UserCompetence.js'; +import { PlacementProfile } from '../models/PlacementProfile.js'; +import * as assessmentRepository from '../../infrastructure/repositories/assessment-repository.js'; +import * as skillRepository from '../../infrastructure/repositories/skill-repository.js'; +import * as assessmentResultRepository from '../../infrastructure/repositories/assessment-result-repository.js'; +import * as knowledgeElementRepository from '../../infrastructure/repositories/knowledge-element-repository.js'; +import * as competenceRepository from '../../infrastructure/repositories/competence-repository.js'; +import * as scoringService from './scoring/scoring-service.js'; async function getPlacementProfile({ userId, @@ -181,8 +181,4 @@ function _matchingDirectlyValidatedSkillsForCompetence(knowledgeElementsForCompe return _.compact(competenceSkills); } -module.exports = { - getPlacementProfile, - getPlacementProfilesWithSnapshotting, - getPlacementProfileWithSnapshotting, -}; +export { getPlacementProfile, getPlacementProfilesWithSnapshotting, getPlacementProfileWithSnapshotting }; diff --git a/api/lib/domain/services/pole-emploi-service.js b/api/lib/domain/services/pole-emploi-service.js index 6a353f6f477..b89c0a45dd7 100644 --- a/api/lib/domain/services/pole-emploi-service.js +++ b/api/lib/domain/services/pole-emploi-service.js @@ -1,7 +1,7 @@ -const settings = require('../../config.js'); +import { config } from '../../config.js'; function generateLink(sending, filters = {}) { - const host = settings.apiManager.url; + const host = config.apiManager.url; const { dateEnvoi, idEnvoi } = sending; const cursor = generateCursor({ idEnvoi, dateEnvoi }); let link = `${host}/pole-emploi/envois?curseur=${cursor}`; @@ -25,4 +25,4 @@ function decodeCursor(strbase64) { return JSON.parse(string); } -module.exports = { generateLink, generateCursor, decodeCursor }; +export { generateLink, generateCursor, decodeCursor }; diff --git a/api/lib/domain/services/recommendation-service.js b/api/lib/domain/services/recommendation-service.js index a63d80a0dbb..9c9ab415247 100644 --- a/api/lib/domain/services/recommendation-service.js +++ b/api/lib/domain/services/recommendation-service.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; const REACH_LEVEL_POINTS = 40; const DIFFICULTY_POINTS = 30; @@ -66,6 +66,4 @@ function _isSkillValidated(validatedKnowledgeElements) { return (skill) => _.map(validatedKnowledgeElements, 'skillId').includes(skill.id); } -module.exports = { - computeRecommendationScore, -}; +export { computeRecommendationScore }; diff --git a/api/lib/domain/services/refresh-token-service.js b/api/lib/domain/services/refresh-token-service.js index 98f9b112816..1f972bb9e7f 100644 --- a/api/lib/domain/services/refresh-token-service.js +++ b/api/lib/domain/services/refresh-token-service.js @@ -1,9 +1,10 @@ -const bluebird = require('bluebird'); -const { v4: uuidv4 } = require('uuid'); -const settings = require('../../config.js'); -const tokenService = require('./token-service.js'); -const { UnauthorizedError } = require('../../application/http-errors.js'); -const { temporaryStorage } = require('../../infrastructure/temporary-storage/index.js'); +import bluebird from 'bluebird'; +import { v4 as uuidv4 } from 'uuid'; +import { tokenService } from './token-service.js'; + +import { config } from '../../config.js'; +import { UnauthorizedError } from '../../application/http-errors.js'; +import { temporaryStorage } from '../../infrastructure/temporary-storage/index.js'; const refreshTokenTemporaryStorage = temporaryStorage.withPrefix('refresh-tokens:'); const userRefreshTokensTemporaryStorage = temporaryStorage.withPrefix('user-refresh-tokens:'); @@ -15,7 +16,7 @@ function _prefixForUser(userId) { } async function createRefreshTokenFromUserId({ userId, source, uuidGenerator = uuidv4 }) { - const expirationDelaySeconds = settings.authentication.refreshTokenLifespanMs / 1000; + const expirationDelaySeconds = config.authentication.refreshTokenLifespanMs / 1000; const refreshToken = `${_prefixForUser(userId)}${uuidGenerator()}`; await refreshTokenTemporaryStorage.save({ @@ -53,12 +54,11 @@ async function revokeRefreshTokensForUserId({ userId }) { }); } -module.exports = { +export { createRefreshTokenFromUserId, createAccessTokenFromRefreshToken, revokeRefreshToken, revokeRefreshTokensForUserId, - - refreshTokenTemporaryStorageForTests: refreshTokenTemporaryStorage, - userRefreshTokensTemporaryStorageForTests: userRefreshTokensTemporaryStorage, + refreshTokenTemporaryStorage, + userRefreshTokensTemporaryStorage, }; diff --git a/api/lib/domain/services/reset-password-service.js b/api/lib/domain/services/reset-password-service.js index 076c1dc2e36..358c4d41edd 100644 --- a/api/lib/domain/services/reset-password-service.js +++ b/api/lib/domain/services/reset-password-service.js @@ -1,34 +1,35 @@ -const jsonwebtoken = require('jsonwebtoken'); -const settings = require('../../config.js'); -const passwordResetDemandRepository = require('../../infrastructure/repositories/reset-password-demands-repository.js'); -const crypto = require('crypto'); +import jsonwebtoken from 'jsonwebtoken'; +import { config } from '../../config.js'; +import * as passwordResetDemandRepository from '../../infrastructure/repositories/reset-password-demands-repository.js'; +import crypto from 'crypto'; -module.exports = { - generateTemporaryKey() { - return jsonwebtoken.sign( - { - data: crypto.randomBytes(16).toString('base64'), - }, - settings.temporaryKey.secret, - { expiresIn: settings.temporaryKey.tokenLifespan } - ); - }, +const generateTemporaryKey = function () { + return jsonwebtoken.sign( + { + data: crypto.randomBytes(16).toString('base64'), + }, + config.temporaryKey.secret, + { expiresIn: config.temporaryKey.tokenLifespan } + ); +}; - invalidateOldResetPasswordDemand(userEmail, resetPasswordDemandRepository = passwordResetDemandRepository) { - return resetPasswordDemandRepository.markAsBeingUsed(userEmail); - }, +const invalidateOldResetPasswordDemand = function ( + userEmail, + resetPasswordDemandRepository = passwordResetDemandRepository +) { + return resetPasswordDemandRepository.markAsBeingUsed(userEmail); +}; - verifyDemand(temporaryKey, resetPasswordDemandRepository = passwordResetDemandRepository) { - return resetPasswordDemandRepository - .findByTemporaryKey(temporaryKey) - .then((fetchedDemand) => fetchedDemand.toJSON()); - }, +const verifyDemand = function (temporaryKey, resetPasswordDemandRepository = passwordResetDemandRepository) { + return resetPasswordDemandRepository.findByTemporaryKey(temporaryKey).then((fetchedDemand) => fetchedDemand.toJSON()); +}; - hasUserAPasswordResetDemandInProgress( - email, - temporaryKey, - resetPasswordDemandRepository = passwordResetDemandRepository - ) { - return resetPasswordDemandRepository.findByUserEmail(email, temporaryKey); - }, +const hasUserAPasswordResetDemandInProgress = function ( + email, + temporaryKey, + resetPasswordDemandRepository = passwordResetDemandRepository +) { + return resetPasswordDemandRepository.findByUserEmail(email, temporaryKey); }; + +export { generateTemporaryKey, invalidateOldResetPasswordDemand, verifyDemand, hasUserAPasswordResetDemandInProgress }; diff --git a/api/lib/domain/services/sco-account-recovery-service.js b/api/lib/domain/services/sco-account-recovery-service.js index a40ca886e5e..88c5e8ee035 100644 --- a/api/lib/domain/services/sco-account-recovery-service.js +++ b/api/lib/domain/services/sco-account-recovery-service.js @@ -1,11 +1,17 @@ -const { features } = require('../../config.js'); -const { +import { config } from '../../config.js'; + +import { AccountRecoveryDemandExpired, MultipleOrganizationLearnersWithDifferentNationalStudentIdError, UserNotFoundError, UserHasAlreadyLeftSCO, -} = require('../errors.js'); -const { uniqBy } = require('lodash'); +} from '../errors.js'; + +import lodash from 'lodash'; + +const { uniqBy } = lodash; + +const { features } = config; async function retrieveOrganizationLearner({ accountRecoveryDemandRepository, @@ -100,7 +106,4 @@ async function _checkIfThereAreMultipleUserForTheSameAccount({ userId, organizat } } -module.exports = { - retrieveOrganizationLearner, - retrieveAndValidateAccountRecoveryDemand, -}; +export { retrieveOrganizationLearner, retrieveAndValidateAccountRecoveryDemand }; diff --git a/api/lib/domain/services/scorecard-service.js b/api/lib/domain/services/scorecard-service.js index d809ab9e2c9..42df54c12bf 100644 --- a/api/lib/domain/services/scorecard-service.js +++ b/api/lib/domain/services/scorecard-service.js @@ -1,8 +1,8 @@ -const Assessment = require('../models/Assessment.js'); -const CompetenceEvaluation = require('../models/CompetenceEvaluation.js'); -const KnowledgeElement = require('../models/KnowledgeElement.js'); -const Scorecard = require('../models/Scorecard.js'); -const _ = require('lodash'); +import { Assessment } from '../models/Assessment.js'; +import { CompetenceEvaluation } from '../models/CompetenceEvaluation.js'; +import { KnowledgeElement } from '../models/KnowledgeElement.js'; +import { Scorecard } from '../models/Scorecard.js'; +import _ from 'lodash'; async function computeScorecard({ userId, @@ -160,8 +160,4 @@ function _computeResetSkillsNotIncludedInCampaign({ skillIds, resetSkillIds }) { return _(skillIds).intersection(resetSkillIds).isEmpty(); } -module.exports = { - resetScorecard, - computeScorecard, - _computeResetSkillsNotIncludedInCampaign, -}; +export { resetScorecard, computeScorecard, _computeResetSkillsNotIncludedInCampaign }; diff --git a/api/lib/domain/services/scoring/scoring-certification-service.js b/api/lib/domain/services/scoring/scoring-certification-service.js index 8d46ef93b19..8f2fdb06e2a 100644 --- a/api/lib/domain/services/scoring/scoring-certification-service.js +++ b/api/lib/domain/services/scoring/scoring-certification-service.js @@ -1,14 +1,14 @@ -const _ = require('lodash'); -const CertificationContract = require('../../models/CertificationContract.js'); -const scoringService = require('./scoring-service.js'); -const placementProfileService = require('../placement-profile-service.js'); -const { CertifiedLevel } = require('../../models/CertifiedLevel.js'); -const { CertifiedScore } = require('../../models/CertifiedScore.js'); -const { ReproducibilityRate } = require('../../models/ReproducibilityRate.js'); -const CompetenceMark = require('../../models/CompetenceMark.js'); -const CertificationAssessmentScore = require('../../models/CertificationAssessmentScore.js'); -const AnswerCollectionForScoring = require('../../models/AnswerCollectionForScoring.js'); -const areaRepository = require('../../../infrastructure/repositories/area-repository.js'); +import _ from 'lodash'; +import { CertificationContract } from '../../models/CertificationContract.js'; +import * as scoringService from './scoring-service.js'; +import * as placementProfileService from '../placement-profile-service.js'; +import { CertifiedLevel } from '../../models/CertifiedLevel.js'; +import { CertifiedScore } from '../../models/CertifiedScore.js'; +import { ReproducibilityRate } from '../../models/ReproducibilityRate.js'; +import { CompetenceMark } from '../../models/CompetenceMark.js'; +import { CertificationAssessmentScore } from '../../models/CertificationAssessmentScore.js'; +import { AnswerCollectionForScoring } from '../../models/AnswerCollectionForScoring.js'; +import * as areaRepository from '../../../infrastructure/repositories/area-repository.js'; function _selectAnswersMatchingCertificationChallenges(answers, certificationChallenges) { return answers.filter(({ challengeId }) => _.some(certificationChallenges, { challengeId })); @@ -129,36 +129,37 @@ async function _getTestedCompetences({ userId, limitDate, isV2Certification, pla .value(); } -module.exports = { - async calculateCertificationAssessmentScore({ - certificationAssessment, - continueOnError, - dependencies = { - areaRepository, - placementProfileService, - }, - }) { - // userService.getPlacementProfile() + filter level > 0 => avec allCompetence (bug) - const testedCompetences = await _getTestedCompetences({ - userId: certificationAssessment.userId, - limitDate: certificationAssessment.createdAt, - isV2Certification: certificationAssessment.isV2Certification, - placementProfileService: dependencies.placementProfileService, - }); +const calculateCertificationAssessmentScore = async function ({ + certificationAssessment, + continueOnError, - // map sur challenges filtre sur competence Id - S'assurer qu'on ne travaille que sur les compétences certifiables - const matchingCertificationChallenges = _selectChallengesMatchingCompetences( - certificationAssessment.certificationChallenges, - testedCompetences - ); + dependencies = { + areaRepository, + placementProfileService, + }, +}) { + // userService.getPlacementProfile() + filter level > 0 => avec allCompetence (bug) + const testedCompetences = await _getTestedCompetences({ + userId: certificationAssessment.userId, + limitDate: certificationAssessment.createdAt, + isV2Certification: certificationAssessment.isV2Certification, + placementProfileService: dependencies.placementProfileService, + }); - // map sur challenges filtre sur challenge Id - const matchingAnswers = _selectAnswersMatchingCertificationChallenges( - certificationAssessment.certificationAnswersByDate, - matchingCertificationChallenges - ); + // map sur challenges filtre sur competence Id - S'assurer qu'on ne travaille que sur les compétences certifiables + const matchingCertificationChallenges = _selectChallengesMatchingCompetences( + certificationAssessment.certificationChallenges, + testedCompetences + ); - const allAreas = await dependencies.areaRepository.list(); - return _getResult(matchingAnswers, matchingCertificationChallenges, testedCompetences, allAreas, continueOnError); - }, + // map sur challenges filtre sur challenge Id + const matchingAnswers = _selectAnswersMatchingCertificationChallenges( + certificationAssessment.certificationAnswersByDate, + matchingCertificationChallenges + ); + + const allAreas = await dependencies.areaRepository.list(); + return _getResult(matchingAnswers, matchingCertificationChallenges, testedCompetences, allAreas, continueOnError); }; + +export { calculateCertificationAssessmentScore }; diff --git a/api/lib/domain/services/scoring/scoring-service.js b/api/lib/domain/services/scoring/scoring-service.js index d75afaf9dc4..9f0c04b3802 100644 --- a/api/lib/domain/services/scoring/scoring-service.js +++ b/api/lib/domain/services/scoring/scoring-service.js @@ -1,6 +1,6 @@ -const { PIX_COUNT_BY_LEVEL, MAX_REACHABLE_LEVEL, MAX_REACHABLE_PIX_BY_COMPETENCE } = require('../../constants.js'); +import { PIX_COUNT_BY_LEVEL, MAX_REACHABLE_LEVEL, MAX_REACHABLE_PIX_BY_COMPETENCE } from '../../constants.js'; -const _ = require('lodash'); +import _ from 'lodash'; function calculateScoringInformationForCompetence({ knowledgeElements, @@ -55,9 +55,4 @@ function calculatePixScore(knowledgeElements) { .sumBy('pixScoreForCompetence'); } -module.exports = { - calculateScoringInformationForCompetence, - getBlockedLevel, - getBlockedPixScore, - calculatePixScore, -}; +export { calculateScoringInformationForCompetence, getBlockedLevel, getBlockedPixScore, calculatePixScore }; diff --git a/api/lib/domain/services/services-utils.js b/api/lib/domain/services/services-utils.js index 2e6f686e40f..6a5efa8ed63 100644 --- a/api/lib/domain/services/services-utils.js +++ b/api/lib/domain/services/services-utils.js @@ -1,5 +1,5 @@ -const { ALL_TREATMENTS } = require('../constants.js'); -const _ = require('../../infrastructure/utils/lodash-utils.js'); +import { ALL_TREATMENTS } from '../constants.js'; +import { _ } from '../../infrastructure/utils/lodash-utils.js'; function getEnabledTreatments(shouldApplyTreatments, deactivations) { return shouldApplyTreatments ? ALL_TREATMENTS.filter((treatment) => !deactivations[treatment]) : []; @@ -9,7 +9,4 @@ function useLevenshteinRatio(enabledTreatments) { return _.includes(enabledTreatments, 't3'); } -module.exports = { - getEnabledTreatments, - useLevenshteinRatio, -}; +export { getEnabledTreatments, useLevenshteinRatio }; diff --git a/api/lib/domain/services/session-code-service.js b/api/lib/domain/services/session-code-service.js index 0dedeaf28e2..a68de2862d8 100644 --- a/api/lib/domain/services/session-code-service.js +++ b/api/lib/domain/services/session-code-service.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const config = require('../../config.js'); +import _ from 'lodash'; +import { config } from '../../config.js'; function _randomLetter() { const letters = config.availableCharacterForCode.letters.split(''); @@ -23,8 +23,8 @@ function _generateSessionCode() { return code; } -module.exports = { - getNewSessionCode() { - return _generateSessionCode(); - }, +const getNewSessionCode = function () { + return _generateSessionCode(); }; + +export { getNewSessionCode }; diff --git a/api/lib/domain/services/session-publication-service.js b/api/lib/domain/services/session-publication-service.js index de82566f552..c64808340ac 100644 --- a/api/lib/domain/services/session-publication-service.js +++ b/api/lib/domain/services/session-publication-service.js @@ -1,9 +1,14 @@ -const { SendingEmailToResultRecipientError, SessionAlreadyPublishedError } = require('../../domain/errors.js'); -const mailService = require('../../domain/services/mail-service.js'); -const uniqBy = require('lodash/uniqBy'); -const some = require('lodash/some'); -const { SendingEmailToRefererError } = require('../errors.js'); -const logger = require('../../infrastructure/logger.js'); +import { + SendingEmailToResultRecipientError, + SessionAlreadyPublishedError, + SendingEmailToRefererError, +} from '../../domain/errors.js'; +import * as mailService from '../../domain/services/mail-service.js'; +import lodash from 'lodash'; + +const { some, uniqBy } = lodash; + +import { logger } from '../../infrastructure/logger.js'; async function publishSession({ i18n, @@ -116,6 +121,4 @@ async function _updateFinalizedSession(finalizedSessionRepository, sessionId, pu await finalizedSessionRepository.save(finalizedSession); } -module.exports = { - publishSession, -}; +export { publishSession }; diff --git a/api/lib/domain/services/session-results-link-service.js b/api/lib/domain/services/session-results-link-service.js index ffc98a23c28..db242734003 100644 --- a/api/lib/domain/services/session-results-link-service.js +++ b/api/lib/domain/services/session-results-link-service.js @@ -1,13 +1,13 @@ -const tokenService = require('./token-service.js'); -const settings = require('../../config.js'); +import { tokenService } from './token-service.js'; +import { config } from '../../config.js'; -module.exports = { - generateResultsLink(sessionId) { - const daysBeforeExpiration = 30; +const generateResultsLink = function (sessionId) { + const daysBeforeExpiration = 30; - const token = tokenService.createCertificationResultsLinkToken({ sessionId, daysBeforeExpiration }); - const link = `${settings.domain.pixApp + settings.domain.tldOrg}/api/sessions/download-all-results/${token}`; + const token = tokenService.createCertificationResultsLinkToken({ sessionId, daysBeforeExpiration }); + const link = `${config.domain.pixApp + config.domain.tldOrg}/api/sessions/download-all-results/${token}`; - return link; - }, + return link; }; + +export { generateResultsLink }; diff --git a/api/lib/domain/services/session-xml-service.js b/api/lib/domain/services/session-xml-service.js index bc217d8e54c..b89a975bd56 100644 --- a/api/lib/domain/services/session-xml-service.js +++ b/api/lib/domain/services/session-xml-service.js @@ -1,4 +1,4 @@ -const writeOdsUtils = require('../../infrastructure/utils/ods/write-ods-utils.js'); +import * as writeOdsUtils from '../../infrastructure/utils/ods/write-ods-utils.js'; // Placeholder in the template ODS file that helps us find the template candidate row in the file. const CANDIDATE_ROW_MARKER_PLACEHOLDER = 'COUNT'; @@ -19,7 +19,4 @@ function getUpdatedXmlWithCertificationCandidatesData({ stringifiedXml, candidat }); } -module.exports = { - getUpdatedXmlWithSessionData, - getUpdatedXmlWithCertificationCandidatesData, -}; +export { getUpdatedXmlWithSessionData, getUpdatedXmlWithCertificationCandidatesData }; diff --git a/api/lib/domain/services/sessions-mass-import/sessions-import-validation-service.js b/api/lib/domain/services/sessions-mass-import/sessions-import-validation-service.js index 99d0143ea65..06c2d87354d 100644 --- a/api/lib/domain/services/sessions-mass-import/sessions-import-validation-service.js +++ b/api/lib/domain/services/sessions-mass-import/sessions-import-validation-service.js @@ -1,169 +1,175 @@ -const sessionValidator = require('../../validators/session-validator.js'); -const certificationCpfService = require('../certification-cpf-service.js'); -const { CERTIFICATION_SESSIONS_ERRORS } = require('../../constants/sessions-errors'); -const dayjs = require('dayjs'); -const { CERTIFICATION_CANDIDATES_ERRORS } = require('../../constants/certification-candidates-errors'); - -module.exports = { - async validateSession({ session, line, certificationCenterId, sessionRepository, certificationCourseRepository }) { - const sessionId = session.id; - const sessionErrors = []; - - if (sessionId) { - if (_hasSessionInfo(session)) { - _addToErrorList({ - errorList: sessionErrors, - line, - codes: [CERTIFICATION_SESSIONS_ERRORS.INFORMATION_NOT_ALLOWED_WITH_SESSION_ID.code], - }); - } +import * as sessionValidator from '../../validators/session-validator.js'; +import * as certificationCpfService from '../certification-cpf-service.js'; +import { CERTIFICATION_SESSIONS_ERRORS } from '../../constants/sessions-errors.js'; +import dayjs from 'dayjs'; +import { CERTIFICATION_CANDIDATES_ERRORS } from '../../constants/certification-candidates-errors.js'; + +const validateSession = async function ({ + session, + line, + certificationCenterId, + sessionRepository, + certificationCourseRepository, +}) { + const sessionId = session.id; + const sessionErrors = []; + + if (sessionId) { + if (_hasSessionInfo(session)) { + _addToErrorList({ + errorList: sessionErrors, + line, + codes: [CERTIFICATION_SESSIONS_ERRORS.INFORMATION_NOT_ALLOWED_WITH_SESSION_ID.code], + }); + } - if (_isSessionIdFormatValid(sessionId)) { - if (await _isSessionExistingInCertificationCenter({ sessionId, certificationCenterId, sessionRepository })) { - if (await _isSessionStarted({ certificationCourseRepository, sessionId })) { - _addToErrorList({ - errorList: sessionErrors, - line, - codes: [CERTIFICATION_SESSIONS_ERRORS.CANDIDATE_NOT_ALLOWED_FOR_STARTED_SESSION.code], - }); - } - } else { + if (_isSessionIdFormatValid(sessionId)) { + if (await _isSessionExistingInCertificationCenter({ sessionId, certificationCenterId, sessionRepository })) { + if (await _isSessionStarted({ certificationCourseRepository, sessionId })) { _addToErrorList({ errorList: sessionErrors, line, - codes: [CERTIFICATION_SESSIONS_ERRORS.SESSION_ID_NOT_EXISTING.code], + codes: [CERTIFICATION_SESSIONS_ERRORS.CANDIDATE_NOT_ALLOWED_FOR_STARTED_SESSION.code], }); } } else { _addToErrorList({ errorList: sessionErrors, line, - codes: [CERTIFICATION_SESSIONS_ERRORS.SESSION_ID_NOT_VALID.code], + codes: [CERTIFICATION_SESSIONS_ERRORS.SESSION_ID_NOT_EXISTING.code], }); } } else { - if (_isDateAndTimeValid(session)) { - const isSessionExisting = await sessionRepository.isSessionExisting({ ...session }); - if (isSessionExisting) { - _addToErrorList({ - errorList: sessionErrors, - line, - codes: [CERTIFICATION_SESSIONS_ERRORS.SESSION_WITH_DATE_AND_TIME_ALREADY_EXISTS.code], - }); - } - } - - if (session.isSessionScheduledInThePast()) { + _addToErrorList({ + errorList: sessionErrors, + line, + codes: [CERTIFICATION_SESSIONS_ERRORS.SESSION_ID_NOT_VALID.code], + }); + } + } else { + if (_isDateAndTimeValid(session)) { + const isSessionExisting = await sessionRepository.isSessionExisting({ ...session }); + if (isSessionExisting) { _addToErrorList({ errorList: sessionErrors, line, - codes: [CERTIFICATION_SESSIONS_ERRORS.SESSION_SCHEDULED_IN_THE_PAST.code], + codes: [CERTIFICATION_SESSIONS_ERRORS.SESSION_WITH_DATE_AND_TIME_ALREADY_EXISTS.code], }); } - - const errorCodes = sessionValidator.validateForMassSessionImport(session); - _addToErrorList({ errorList: sessionErrors, line, codes: errorCodes }); } - if (session.certificationCandidates.length === 0) { + if (session.isSessionScheduledInThePast()) { _addToErrorList({ errorList: sessionErrors, line, - codes: [CERTIFICATION_SESSIONS_ERRORS.EMPTY_SESSION.code], - isBlocking: false, + codes: [CERTIFICATION_SESSIONS_ERRORS.SESSION_SCHEDULED_IN_THE_PAST.code], }); } - return sessionErrors; - }, - - getUniqueCandidates(candidates) { - const duplicateCandidateErrors = []; - - const uniqueCandidates = candidates.filter((candidate, index) => { - const isFirstOccurence = - index === - candidates.findIndex( - (other) => - candidate.firstName === other.firstName && - candidate.lastName === other.lastName && - candidate.birthdate === other.birthdate - ); + const errorCodes = sessionValidator.validateForMassSessionImport(session); + _addToErrorList({ errorList: sessionErrors, line, codes: errorCodes }); + } - if (!isFirstOccurence) { - _addToErrorList({ - errorList: duplicateCandidateErrors, - line: candidate.line, - codes: [CERTIFICATION_SESSIONS_ERRORS.DUPLICATE_CANDIDATE_IN_SESSION.code], - isBlocking: false, - }); - } - - return isFirstOccurence; + if (session.certificationCandidates.length === 0) { + _addToErrorList({ + errorList: sessionErrors, + line, + codes: [CERTIFICATION_SESSIONS_ERRORS.EMPTY_SESSION.code], + isBlocking: false, }); + } - return { uniqueCandidates, duplicateCandidateErrors }; - }, + return sessionErrors; +}; - async getValidatedCandidateBirthInformation({ - candidate, - isSco, - line, - certificationCpfCountryRepository, - certificationCpfCityRepository, - dependencies = { certificationCpfService }, - }) { - const certificationCandidateErrors = []; +const getUniqueCandidates = function (candidates) { + const duplicateCandidateErrors = []; - if (candidate.extraTimePercentage) { - if (candidate.extraTimePercentage >= 1) { - candidate.convertExtraTimePercentageToDecimal(); - } else { - _addToErrorList({ - errorList: certificationCandidateErrors, - line, - codes: [CERTIFICATION_CANDIDATES_ERRORS.CANDIDATE_EXTRA_TIME_OUT_OF_RANGE.code], - }); - } + const uniqueCandidates = candidates.filter((candidate, index) => { + const isFirstOccurence = + index === + candidates.findIndex( + (other) => + candidate.firstName === other.firstName && + candidate.lastName === other.lastName && + candidate.birthdate === other.birthdate + ); + + if (!isFirstOccurence) { + _addToErrorList({ + errorList: duplicateCandidateErrors, + line: candidate.line, + codes: [CERTIFICATION_SESSIONS_ERRORS.DUPLICATE_CANDIDATE_IN_SESSION.code], + isBlocking: false, + }); } - const errorCodes = candidate.validateForMassSessionImport(isSco); - _addToErrorList({ errorList: certificationCandidateErrors, line, codes: errorCodes }); + return isFirstOccurence; + }); - const cpfBirthInformation = await dependencies.certificationCpfService.getBirthInformation({ - birthCountry: candidate.birthCountry, - birthCity: candidate.birthCity, - birthPostalCode: candidate.birthPostalCode, - birthINSEECode: candidate.birthINSEECode, - certificationCpfCountryRepository, - certificationCpfCityRepository, - }); + return { uniqueCandidates, duplicateCandidateErrors }; +}; - if (cpfBirthInformation.hasFailed()) { - cpfBirthInformation.errors.forEach(({ code: errorCode }) => { - if ( - _isErrorNotDuplicated({ - certificationCandidateErrors, - errorCode, - }) - ) { - _addToErrorList({ errorList: certificationCandidateErrors, line, codes: [errorCode] }); - } +const getValidatedCandidateBirthInformation = async function ({ + candidate, + isSco, + line, + certificationCpfCountryRepository, + certificationCpfCityRepository, + dependencies = { certificationCpfService }, +}) { + const certificationCandidateErrors = []; + + if (candidate.extraTimePercentage) { + if (candidate.extraTimePercentage >= 1) { + candidate.convertExtraTimePercentageToDecimal(); + } else { + _addToErrorList({ + errorList: certificationCandidateErrors, + line, + codes: [CERTIFICATION_CANDIDATES_ERRORS.CANDIDATE_EXTRA_TIME_OUT_OF_RANGE.code], }); } + } + + const errorCodes = candidate.validateForMassSessionImport(isSco); + _addToErrorList({ errorList: certificationCandidateErrors, line, codes: errorCodes }); - return { - certificationCandidateErrors, - cpfBirthInformation: { - birthCountry: cpfBirthInformation.birthCountry, - birthCity: cpfBirthInformation.birthCity, - birthPostalCode: cpfBirthInformation.birthPostalCode, - birthINSEECode: cpfBirthInformation.birthINSEECode, - }, - }; - }, + const cpfBirthInformation = await dependencies.certificationCpfService.getBirthInformation({ + birthCountry: candidate.birthCountry, + birthCity: candidate.birthCity, + birthPostalCode: candidate.birthPostalCode, + birthINSEECode: candidate.birthINSEECode, + certificationCpfCountryRepository, + certificationCpfCityRepository, + }); + + if (cpfBirthInformation.hasFailed()) { + cpfBirthInformation.errors.forEach(({ code: errorCode }) => { + if ( + _isErrorNotDuplicated({ + certificationCandidateErrors, + errorCode, + }) + ) { + _addToErrorList({ errorList: certificationCandidateErrors, line, codes: [errorCode] }); + } + }); + } + + return { + certificationCandidateErrors, + cpfBirthInformation: { + birthCountry: cpfBirthInformation.birthCountry, + birthCity: cpfBirthInformation.birthCity, + birthPostalCode: cpfBirthInformation.birthPostalCode, + birthINSEECode: cpfBirthInformation.birthINSEECode, + }, + }; }; +export { validateSession, getUniqueCandidates, getValidatedCandidateBirthInformation }; + function _isDateAndTimeValid(session) { return dayjs(`${session.date} ${session.time}`, 'YYYY-MM-DD HH:mm', true).isValid(); } diff --git a/api/lib/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service.js b/api/lib/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service.js index 79913d068f1..251d61428fe 100644 --- a/api/lib/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service.js +++ b/api/lib/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service.js @@ -1,31 +1,32 @@ -const settings = require('../../../config'); -const { temporaryStorage } = require('../../../infrastructure/temporary-storage'); +import { config } from '../../../config.js'; +import { temporaryStorage } from '../../../infrastructure/temporary-storage/index.js'; + const sessionMassImportTemporaryStorage = temporaryStorage.withPrefix('sessions-mass-import:'); -const { v4: uuidv4 } = require('uuid'); +import { v4 as uuidv4 } from 'uuid'; -const EXPIRATION_DELAY_SECONDS = settings.temporarySessionsStorageForMassImport.expirationDelaySeconds; +const EXPIRATION_DELAY_SECONDS = config.temporarySessionsStorageForMassImport.expirationDelaySeconds; -module.exports = { - async save({ sessions, userId }) { - const uuid = uuidv4(); - await sessionMassImportTemporaryStorage.save({ - key: `${userId}:${uuid}`, - value: sessions, - expirationDelaySeconds: EXPIRATION_DELAY_SECONDS, - }); +const save = async function ({ sessions, userId }) { + const uuid = uuidv4(); + await sessionMassImportTemporaryStorage.save({ + key: `${userId}:${uuid}`, + value: sessions, + expirationDelaySeconds: EXPIRATION_DELAY_SECONDS, + }); - return uuid; - }, + return uuid; +}; - async getByKeyAndUserId({ cachedValidatedSessionsKey, userId }) { - const key = `${userId}:${cachedValidatedSessionsKey}`; - const sessions = await sessionMassImportTemporaryStorage.get(key); +const getByKeyAndUserId = async function ({ cachedValidatedSessionsKey, userId }) { + const key = `${userId}:${cachedValidatedSessionsKey}`; + const sessions = await sessionMassImportTemporaryStorage.get(key); - return sessions; - }, + return sessions; +}; - async delete({ cachedValidatedSessionsKey, userId }) { - const key = `${userId}:${cachedValidatedSessionsKey}`; - await sessionMassImportTemporaryStorage.delete(key); - }, +const remove = async function ({ cachedValidatedSessionsKey, userId }) { + const key = `${userId}:${cachedValidatedSessionsKey}`; + await sessionMassImportTemporaryStorage.delete(key); }; + +export { save, getByKeyAndUserId, remove }; diff --git a/api/lib/domain/services/solution-service-qcm.js b/api/lib/domain/services/solution-service-qcm.js index efd19b4fb45..3b9a422ba56 100644 --- a/api/lib/domain/services/solution-service-qcm.js +++ b/api/lib/domain/services/solution-service-qcm.js @@ -1,12 +1,11 @@ -const _ = require('../../infrastructure/utils/lodash-utils.js'); +import { _ } from '../../infrastructure/utils/lodash-utils.js'; +import { AnswerStatus } from '../models/AnswerStatus.js'; -const AnswerStatus = require('../models/AnswerStatus.js'); - -module.exports = { - match(answer, solution) { - if (_.areCSVequivalent(answer, solution)) { - return AnswerStatus.OK; - } - return AnswerStatus.KO; - }, +const match = function (answer, solution) { + if (_.areCSVequivalent(answer, solution)) { + return AnswerStatus.OK; + } + return AnswerStatus.KO; }; + +export { match }; diff --git a/api/lib/domain/services/solution-service-qcu.js b/api/lib/domain/services/solution-service-qcu.js index d62de7bff25..333a94bdd56 100644 --- a/api/lib/domain/services/solution-service-qcu.js +++ b/api/lib/domain/services/solution-service-qcu.js @@ -1,10 +1,10 @@ -const AnswerStatus = require('../models/AnswerStatus.js'); +import { AnswerStatus } from '../models/AnswerStatus.js'; -module.exports = { - match(answer, solution) { - if (answer === solution) { - return AnswerStatus.OK; - } - return AnswerStatus.KO; - }, +const match = function (answer, solution) { + if (answer === solution) { + return AnswerStatus.OK; + } + return AnswerStatus.KO; }; + +export { match }; diff --git a/api/lib/domain/services/solution-service-qroc.js b/api/lib/domain/services/solution-service-qroc.js index 934d949af4c..4f3e76c0fb8 100644 --- a/api/lib/domain/services/solution-service-qroc.js +++ b/api/lib/domain/services/solution-service-qroc.js @@ -1,44 +1,43 @@ -const { +import { isNumeric, splitIntoWordsAndRemoveBackspaces, cleanStringAndParseFloat, -} = require('../../../lib/infrastructure/utils/string-utils.js'); -const { every, isEmpty, isString, map } = require('lodash'); -const { applyTreatments, applyPreTreatments } = require('./validation-treatments.js'); -const { validateAnswer } = require('./string-comparison-service.js'); - -const AnswerStatus = require('../models/AnswerStatus.js'); - -const { getEnabledTreatments, useLevenshteinRatio } = require('./services-utils.js'); +} from '../../../lib/infrastructure/utils/string-utils.js'; +import lodash from 'lodash'; +import { applyTreatments, applyPreTreatments } from './validation-treatments.js'; +import { validateAnswer } from './string-comparison-service.js'; +import { AnswerStatus } from '../models/AnswerStatus.js'; +import { getEnabledTreatments, useLevenshteinRatio } from './services-utils.js'; const CHALLENGE_NUMBER_FORMAT = 'nombre'; +const { every, isEmpty, isString, map } = lodash; -module.exports = { - match({ answer, challengeFormat, solution }) { - const solutionValue = solution.value; - const deactivations = solution.deactivations; - const qrocBlocksTypes = solution.qrocBlocksTypes || {}; - const shouldApplyTreatments = qrocBlocksTypes[Object.keys(qrocBlocksTypes)[0]] === 'select' ? false : true; +const match = function ({ answer, challengeFormat, solution }) { + const solutionValue = solution.value; + const deactivations = solution.deactivations; + const qrocBlocksTypes = solution.qrocBlocksTypes || {}; + const shouldApplyTreatments = qrocBlocksTypes[Object.keys(qrocBlocksTypes)[0]] === 'select' ? false : true; - const isIncorrectAnswerFormat = !isString(answer); - const isIncorrectSolutionFormat = !isString(solutionValue) || isEmpty(solutionValue); + const isIncorrectAnswerFormat = !isString(answer); + const isIncorrectSolutionFormat = !isString(solutionValue) || isEmpty(solutionValue); - if (isIncorrectAnswerFormat || isIncorrectSolutionFormat) { - return AnswerStatus.KO; - } + if (isIncorrectAnswerFormat || isIncorrectSolutionFormat) { + return AnswerStatus.KO; + } - const solutions = splitIntoWordsAndRemoveBackspaces(solutionValue); - const areAllNumericSolutions = every(solutions, (solution) => { - return isNumeric(solution); - }); + const solutions = splitIntoWordsAndRemoveBackspaces(solutionValue); + const areAllNumericSolutions = every(solutions, (solution) => { + return isNumeric(solution); + }); - if (isNumeric(answer) && areAllNumericSolutions && challengeFormat === CHALLENGE_NUMBER_FORMAT) { - return _getAnswerStatusFromNumberMatching(answer, solutions); - } + if (isNumeric(answer) && areAllNumericSolutions && challengeFormat === CHALLENGE_NUMBER_FORMAT) { + return _getAnswerStatusFromNumberMatching(answer, solutions); + } - return _getAnswerStatusFromStringMatching(answer, solutions, deactivations, shouldApplyTreatments); - }, + return _getAnswerStatusFromStringMatching(answer, solutions, deactivations, shouldApplyTreatments); }; +export { match }; + function _getAnswerStatusFromNumberMatching(answer, solutions) { const treatedSolutions = solutions.map((solution) => cleanStringAndParseFloat(solution)); const treatedAnswer = cleanStringAndParseFloat(answer); diff --git a/api/lib/domain/services/solution-service-qrocm-dep.js b/api/lib/domain/services/solution-service-qrocm-dep.js index 3073b7677d7..9e0cd6cf403 100644 --- a/api/lib/domain/services/solution-service-qrocm-dep.js +++ b/api/lib/domain/services/solution-service-qrocm-dep.js @@ -1,11 +1,10 @@ -const jsYaml = require('js-yaml'); -const { applyPreTreatments, applyTreatments } = require('./validation-treatments.js'); -const { YamlParsingError } = require('../../domain/errors.js'); -const { getEnabledTreatments, useLevenshteinRatio } = require('./services-utils.js'); -const { validateAnswer } = require('./string-comparison-service.js'); - -const AnswerStatus = require('../models/AnswerStatus.js'); -const CorrectionBlockQROCMDep = require('../models/CorrectionBlockQROCMDep.js'); +import jsYaml from 'js-yaml'; +import { applyPreTreatments, applyTreatments } from './validation-treatments.js'; +import { YamlParsingError } from '../../domain/errors.js'; +import { getEnabledTreatments, useLevenshteinRatio } from './services-utils.js'; +import { validateAnswer } from './string-comparison-service.js'; +import { AnswerStatus } from '../models/AnswerStatus.js'; +import { CorrectionBlockQROCMDep } from '../models/CorrectionBlockQROCMDep.js'; function applyTreatmentsToSolutions(solutions, enabledTreatments) { return Object.fromEntries( @@ -95,57 +94,59 @@ function treatAnswersAndSolutions(deactivations, solutions, answers) { return { enabledTreatments, treatedSolutions, treatedAnswers }; } -module.exports = { - match({ - answerValue, - solution: { deactivations, scoring: yamlScoring, value: yamlSolution }, - dependencies = { - applyPreTreatments, - convertYamlToJsObjects, - getEnabledTreatments, - treatAnswersAndSolutions, - }, - }) { - // Input checking - if (typeof answerValue !== 'string' || !answerValue.length || !String(yamlSolution).includes('\n')) { - return AnswerStatus.KO; - } +const match = function ({ + answerValue, + solution: { deactivations, scoring: yamlScoring, value: yamlSolution }, - // Pre-Treatments - const preTreatedAnswers = dependencies.applyPreTreatments(answerValue); - const { answers, solutions, scoring } = dependencies.convertYamlToJsObjects( - preTreatedAnswers, - yamlSolution, - yamlScoring - ); - const { enabledTreatments, treatedSolutions, treatedAnswers } = dependencies.treatAnswersAndSolutions( - deactivations, - solutions, - answers - ); - const numberOfGoodAnswers = getNumberOfGoodAnswers(treatedAnswers, treatedSolutions, enabledTreatments); - - return formatResult(scoring, numberOfGoodAnswers, Object.keys(answers).length); + dependencies = { + applyPreTreatments, + convertYamlToJsObjects, + getEnabledTreatments, + treatAnswersAndSolutions, }, +}) { + // Input checking + if (typeof answerValue !== 'string' || !answerValue.length || !String(yamlSolution).includes('\n')) { + return AnswerStatus.KO; + } + + // Pre-Treatments + const preTreatedAnswers = dependencies.applyPreTreatments(answerValue); + const { answers, solutions, scoring } = dependencies.convertYamlToJsObjects( + preTreatedAnswers, + yamlSolution, + yamlScoring + ); + const { enabledTreatments, treatedSolutions, treatedAnswers } = dependencies.treatAnswersAndSolutions( + deactivations, + solutions, + answers + ); + const numberOfGoodAnswers = getNumberOfGoodAnswers(treatedAnswers, treatedSolutions, enabledTreatments); - getSolution({ - answerValue, - solution: { deactivations, scoring: yamlScoring, value: yamlSolution }, - dependencies = { - applyPreTreatments, - convertYamlToJsObjects, - treatAnswersAndSolutions, - }, - }) { - // Pre-Treatments - const preTreatedAnswers = dependencies.applyPreTreatments(answerValue); - const { answers, solutions } = dependencies.convertYamlToJsObjects(preTreatedAnswers, yamlSolution, yamlScoring); - const { enabledTreatments, treatedSolutions, treatedAnswers } = dependencies.treatAnswersAndSolutions( - deactivations, - solutions, - answers - ); - - return getAnswersStatuses(treatedAnswers, treatedSolutions, enabledTreatments); + return formatResult(scoring, numberOfGoodAnswers, Object.keys(answers).length); +}; + +const getSolution = function ({ + answerValue, + solution: { deactivations, scoring: yamlScoring, value: yamlSolution }, + + dependencies = { + applyPreTreatments, + convertYamlToJsObjects, + treatAnswersAndSolutions, }, +}) { + // Pre-Treatments + const preTreatedAnswers = dependencies.applyPreTreatments(answerValue); + const { answers, solutions } = dependencies.convertYamlToJsObjects(preTreatedAnswers, yamlSolution, yamlScoring); + const { enabledTreatments, treatedSolutions, treatedAnswers } = dependencies.treatAnswersAndSolutions( + deactivations, + solutions, + answers + ); + + return getAnswersStatuses(treatedAnswers, treatedSolutions, enabledTreatments); }; + +export { match, getSolution }; diff --git a/api/lib/domain/services/solution-service-qrocm-ind.js b/api/lib/domain/services/solution-service-qrocm-ind.js index f4fd88a07a9..d01575a4e70 100644 --- a/api/lib/domain/services/solution-service-qrocm-ind.js +++ b/api/lib/domain/services/solution-service-qrocm-ind.js @@ -1,13 +1,12 @@ -const jsYaml = require('js-yaml'); -const levenshtein = require('fast-levenshtein'); -const _ = require('../../infrastructure/utils/lodash-utils.js'); -const logger = require('../../infrastructure/logger.js'); -const { applyPreTreatments, applyTreatments } = require('./validation-treatments.js'); -const { YamlParsingError } = require('../../domain/errors.js'); -const { LEVENSHTEIN_DISTANCE_MAX_RATE } = require('../constants.js'); -const { useLevenshteinRatio } = require('./services-utils.js'); - -const AnswerStatus = require('../models/AnswerStatus.js'); +import jsYaml from 'js-yaml'; +import levenshtein from 'fast-levenshtein'; +import { _ } from '../../infrastructure/utils/lodash-utils.js'; +import { logger } from '../../infrastructure/logger.js'; +import { applyPreTreatments, applyTreatments } from './validation-treatments.js'; +import { YamlParsingError } from '../../domain/errors.js'; +import { LEVENSHTEIN_DISTANCE_MAX_RATE } from '../constants.js'; +import { useLevenshteinRatio } from './services-utils.js'; +import { AnswerStatus } from '../models/AnswerStatus.js'; function _applyTreatmentsToSolutions(solutions, enabledTreatments, qrocBlocksTypes = {}) { return _.forEach(solutions, (solution, solutionKey) => { @@ -113,10 +112,4 @@ function match({ answerValue, solution }) { }; } -module.exports = { - _applyTreatmentsToSolutions, - _applyTreatmentsToAnswers, - _compareAnswersAndSolutions, - _formatResult, - match, -}; +export { _applyTreatmentsToSolutions, _applyTreatmentsToAnswers, _compareAnswersAndSolutions, _formatResult, match }; diff --git a/api/lib/domain/services/string-comparison-service.js b/api/lib/domain/services/string-comparison-service.js index 4bbc9527710..846b206f289 100644 --- a/api/lib/domain/services/string-comparison-service.js +++ b/api/lib/domain/services/string-comparison-service.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); -const levenshtein = require('fast-levenshtein'); -const { LEVENSHTEIN_DISTANCE_MAX_RATE } = require('../constants.js'); +import _ from 'lodash'; +import levenshtein from 'fast-levenshtein'; +import { LEVENSHTEIN_DISTANCE_MAX_RATE } from '../constants.js'; function getLevenshteinRatio(inputString, reference) { return levenshtein.get(inputString, reference) / inputString.length; @@ -30,7 +30,7 @@ function validateAnswer(answer, solutions, useLevenshteinRatio) { return _.includes(solutions, answer); } -module.exports = { +export { areTwoStringsCloseEnough, isOneStringCloseEnoughFromMultipleStrings, getSmallestLevenshteinDistance, diff --git a/api/lib/domain/services/token-service.js b/api/lib/domain/services/token-service.js index c505f53cb98..a38a2d692b5 100644 --- a/api/lib/domain/services/token-service.js +++ b/api/lib/domain/services/token-service.js @@ -1,32 +1,34 @@ -const jsonwebtoken = require('jsonwebtoken'); -const { +import jsonwebtoken from 'jsonwebtoken'; + +import { InvalidTemporaryKeyError, InvalidExternalUserTokenError, InvalidResultRecipientTokenError, InvalidSessionResultError, -} = require('../../domain/errors.js'); -const settings = require('../../config.js'); -const { ForbiddenAccess } = require('../errors.js'); + ForbiddenAccess, +} from '../../domain/errors.js'; + +import { config } from '../../config.js'; function _createAccessToken({ userId, source, expirationDelaySeconds }) { - return jsonwebtoken.sign({ user_id: userId, source }, settings.authentication.secret, { + return jsonwebtoken.sign({ user_id: userId, source }, config.authentication.secret, { expiresIn: expirationDelaySeconds, }); } function createAccessTokenFromUser(userId, source) { - const expirationDelaySeconds = settings.authentication.accessTokenLifespanMs / 1000; + const expirationDelaySeconds = config.authentication.accessTokenLifespanMs / 1000; const accessToken = _createAccessToken({ userId, source, expirationDelaySeconds }); return { accessToken, expirationDelaySeconds }; } function createAccessTokenFromAnonymousUser(userId) { - const expirationDelaySeconds = settings.anonymous.accessTokenLifespanMs / 1000; + const expirationDelaySeconds = config.anonymous.accessTokenLifespanMs / 1000; return _createAccessToken({ userId, source: 'pix', expirationDelaySeconds }); } function createAccessTokenForSaml(userId) { - const expirationDelaySeconds = settings.saml.accessTokenLifespanMs / 1000; + const expirationDelaySeconds = config.saml.accessTokenLifespanMs / 1000; return _createAccessToken({ userId, source: 'external', expirationDelaySeconds }); } @@ -34,8 +36,8 @@ function createAccessTokenFromApplication( clientId, source, scope, - secret = settings.authentication.secret, - expiresIn = settings.authentication.accessTokenLifespanMs + secret = config.authentication.secret, + expiresIn = config.authentication.accessTokenLifespanMs ) { return jsonwebtoken.sign( { @@ -54,8 +56,8 @@ function createTokenForCampaignResults({ userId, campaignId }) { access_id: userId, campaign_id: campaignId, }, - settings.authentication.secret, - { expiresIn: settings.authentication.tokenForCampaignResultLifespan } + config.authentication.secret, + { expiresIn: config.authentication.tokenForCampaignResultLifespan } ); } @@ -66,8 +68,8 @@ function createIdTokenForUserReconciliation(externalUser) { last_name: externalUser.lastName, saml_id: externalUser.samlId, }, - settings.authentication.secret, - { expiresIn: settings.authentication.tokenForStudentReconciliationLifespan } + config.authentication.secret, + { expiresIn: config.authentication.tokenForStudentReconciliationLifespan } ); } @@ -81,7 +83,7 @@ function createCertificationResultsByRecipientEmailLinkToken({ session_id: sessionId, result_recipient_email: resultRecipientEmail, }, - settings.authentication.secret, + config.authentication.secret, { expiresIn: `${daysBeforeExpiration}d`, } @@ -93,7 +95,7 @@ function createCertificationResultsLinkToken({ sessionId, daysBeforeExpiration } { session_id: sessionId, }, - settings.authentication.secret, + config.authentication.secret, { expiresIn: `${daysBeforeExpiration}d`, } @@ -105,8 +107,8 @@ function createPasswordResetToken(userId) { { user_id: userId, }, - settings.authentication.secret, - { expiresIn: settings.authentication.passwordResetTokenLifespan } + config.authentication.secret, + { expiresIn: config.authentication.passwordResetTokenLifespan } ); } @@ -128,7 +130,7 @@ function decodeIfValid(token) { }); } -function getDecodedToken(token, secret = settings.authentication.secret) { +function getDecodedToken(token, secret = config.authentication.secret) { try { return jsonwebtoken.verify(token, secret); } catch (err) { @@ -169,7 +171,7 @@ function extractUserId(token) { return decoded.user_id || null; } -function extractClientId(token, secret = settings.authentication.secret) { +function extractClientId(token, secret = config.authentication.secret) { const decoded = getDecodedToken(token, secret); return decoded.client_id || null; } @@ -219,7 +221,7 @@ const tokenService = { extractCampaignResultsTokenContent, }; -module.exports = { +export { tokenService, createAccessTokenFromUser, createAccessTokenForSaml, diff --git a/api/lib/domain/services/tube-service.js b/api/lib/domain/services/tube-service.js index a2ebde3707b..19660f7dc1f 100644 --- a/api/lib/domain/services/tube-service.js +++ b/api/lib/domain/services/tube-service.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const Tube = require('../models/Tube.js'); +import _ from 'lodash'; +import { Tube } from '../models/Tube.js'; function computeTubesFromSkills(skills) { const tubes = []; @@ -20,6 +20,4 @@ function computeTubesFromSkills(skills) { return tubes; } -module.exports = { - computeTubesFromSkills, -}; +export { computeTubesFromSkills }; diff --git a/api/lib/domain/services/user-reconciliation-service.js b/api/lib/domain/services/user-reconciliation-service.js index 2087bf78857..f17982f4730 100644 --- a/api/lib/domain/services/user-reconciliation-service.js +++ b/api/lib/domain/services/user-reconciliation-service.js @@ -1,25 +1,26 @@ -const _ = require('lodash'); -const { pipe } = require('lodash/fp'); -const randomString = require('randomstring'); -const { STUDENT_RECONCILIATION_ERRORS } = require('../constants.js'); -const { +import lodash from 'lodash'; +import fp from 'lodash/fp.js'; + +const { pipe } = fp; +import randomString from 'randomstring'; +import { STUDENT_RECONCILIATION_ERRORS } from '../constants.js'; + +import { AlreadyRegisteredUsernameError, NotFoundError, OrganizationLearnerAlreadyLinkedToUserError, OrganizationLearnerAlreadyLinkedToInvalidUserError, -} = require('../errors.js'); -const { - areTwoStringsCloseEnough, - isOneStringCloseEnoughFromMultipleStrings, -} = require('./string-comparison-service.js'); -const { normalizeAndRemoveAccents, removeSpecialCharacters } = require('./validation-treatments.js'); +} from '../errors.js'; + +import { areTwoStringsCloseEnough, isOneStringCloseEnoughFromMultipleStrings } from './string-comparison-service.js'; +import { normalizeAndRemoveAccents, removeSpecialCharacters } from './validation-treatments.js'; const MAX_ACCEPTABLE_RATIO = 0.25; const STRICT_MATCH_RATIO = 0; function findMatchingCandidateIdForGivenUser(matchingUserCandidates, user) { const standardizedUser = _standardizeUser(user); - const standardizedMatchingUserCandidates = _.map(matchingUserCandidates, _standardizeMatchingCandidate); + const standardizedMatchingUserCandidates = lodash.map(matchingUserCandidates, _standardizeMatchingCandidate); const foundUserId = _findMatchingCandidateId( standardizedMatchingUserCandidates, @@ -51,7 +52,7 @@ async function findMatchingSupOrganizationLearnerIdForGivenOrganizationIdAndUser throw new NotFoundError('There were no organizationLearners matching with names'); } - if (!_.isNil(organizationLearner.userId)) { + if (!lodash.isNil(organizationLearner.userId)) { throw new OrganizationLearnerAlreadyLinkedToUserError(); } return organizationLearner; @@ -67,7 +68,7 @@ async function findMatchingOrganizationLearnerIdForGivenOrganizationIdAndUser({ birthdate, }); - if (_.isEmpty(organizationLearners)) { + if (lodash.isEmpty(organizationLearners)) { throw new NotFoundError('There are no organization learners found'); } @@ -76,7 +77,7 @@ async function findMatchingOrganizationLearnerIdForGivenOrganizationIdAndUser({ throw new NotFoundError('There were no organizationLearners matching with names'); } - return _.find(organizationLearners, { id: organizationLearnerId }); + return lodash.find(organizationLearners, { id: organizationLearnerId }); } async function checkIfStudentHasAnAlreadyReconciledAccount( @@ -85,7 +86,7 @@ async function checkIfStudentHasAnAlreadyReconciledAccount( obfuscationService, studentRepository ) { - if (!_.isNil(organizationLearner.userId)) { + if (!lodash.isNil(organizationLearner.userId)) { await _buildStudentReconciliationError( organizationLearner.userId, 'IN_SAME_ORGANIZATION', @@ -97,7 +98,7 @@ async function checkIfStudentHasAnAlreadyReconciledAccount( const student = await studentRepository.getReconciledStudentByNationalStudentId( organizationLearner.nationalStudentId ); - if (_.get(student, 'account')) { + if (lodash.get(student, 'account')) { await _buildStudentReconciliationError( student.account.userId, 'IN_OTHER_ORGANIZATION', @@ -129,29 +130,29 @@ async function _buildStudentReconciliationError(userId, errorContext, userReposi } function _containsOneElement(arr) { - return _.size(arr) === 1; + return lodash.size(arr) === 1; } function _standardizeUser(reconciliationInfo) { - return _(reconciliationInfo).pick(['firstName', 'lastName']).mapValues(_standardize).value(); + return lodash(reconciliationInfo).pick(['firstName', 'lastName']).mapValues(_standardize).value(); } function _standardizeMatchingCandidate(matchingUserCandidate) { - return _(matchingUserCandidate) + return lodash(matchingUserCandidate) .pick(['id', 'firstName', 'middleName', 'thirdName', 'lastName', 'preferredLastName']) .mapValues(_standardize) .value(); } function _standardize(propToStandardize) { - return _.isString(propToStandardize) + return lodash.isString(propToStandardize) ? pipe(normalizeAndRemoveAccents, removeSpecialCharacters)(propToStandardize) : propToStandardize; } function _findMatchingCandidateId(standardizedMatchingUserCandidates, standardizedUser, maxAcceptableRatio) { return ( - _(['firstName', 'middleName', 'thirdName']) + lodash(['firstName', 'middleName', 'thirdName']) .map(_findCandidatesMatchingWithUser(standardizedMatchingUserCandidates, standardizedUser, maxAcceptableRatio)) .filter(_containsOneElement) .flatten() @@ -227,7 +228,7 @@ async function createUsernameByUser({ user: { firstName, lastName, birthdate }, return await generateUsernameUntilAvailable({ firstPart, secondPart, userRepository }); } -module.exports = { +export { generateUsernameUntilAvailable, createUsernameByUser, findMatchingCandidateIdForGivenUser, diff --git a/api/lib/domain/services/user-service.js b/api/lib/domain/services/user-service.js index f962e25783e..d82acb1d798 100644 --- a/api/lib/domain/services/user-service.js +++ b/api/lib/domain/services/user-service.js @@ -1,7 +1,6 @@ -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); - -const AuthenticationMethod = require('../../domain/models/AuthenticationMethod.js'); -const UserToCreate = require('../models/UserToCreate.js'); +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import { AuthenticationMethod } from '../../domain/models/AuthenticationMethod.js'; +import { UserToCreate } from '../models/UserToCreate.js'; function _buildPasswordAuthenticationMethod({ userId, hashedPassword }) { return new AuthenticationMethod({ @@ -115,8 +114,4 @@ async function createAndReconcileUserToOrganizationLearner({ }); } -module.exports = { - createAndReconcileUserToOrganizationLearner, - createUserWithPassword, - updateUsernameAndAddPassword, -}; +export { createAndReconcileUserToOrganizationLearner, createUserWithPassword, updateUsernameAndAddPassword }; diff --git a/api/lib/domain/services/validation-treatments.js b/api/lib/domain/services/validation-treatments.js index 9eb28e210ac..348a3726afc 100644 --- a/api/lib/domain/services/validation-treatments.js +++ b/api/lib/domain/services/validation-treatments.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; function normalizeAndRemoveAccents(value) { // Remove uppercase/spaces/accents/diacritics, see http://stackoverflow.com/a/37511463/827989 @@ -45,10 +45,4 @@ function applyTreatments(string, enabledTreatments) { return result; } -module.exports = { - normalizeAndRemoveAccents, - removeSpecialCharacters, - applyPreTreatments, - applyTreatments, - treatments, -}; +export { normalizeAndRemoveAccents, removeSpecialCharacters, applyPreTreatments, applyTreatments, treatments }; diff --git a/api/lib/domain/services/verify-certificate-code-service.js b/api/lib/domain/services/verify-certificate-code-service.js index f35b5aec35c..cd797545df0 100644 --- a/api/lib/domain/services/verify-certificate-code-service.js +++ b/api/lib/domain/services/verify-certificate-code-service.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const certificationCourseRepository = require('../../../lib/infrastructure/repositories/certification-course-repository.js'); -const { CertificateVerificationCodeGenerationTooManyTrials } = require('../../../lib/domain/errors.js'); -const config = require('../../config.js'); +import _ from 'lodash'; +import * as certificationCourseRepository from '../../../lib/infrastructure/repositories/certification-course-repository.js'; +import { CertificateVerificationCodeGenerationTooManyTrials } from '../../../lib/domain/errors.js'; +import { config } from '../../config.js'; const availableCharacters = `${config.availableCharacterForCode.numbers}${config.availableCharacterForCode.letters}`.split(''); @@ -16,16 +16,16 @@ function _randomCharacter() { return _.sample(availableCharacters); } -module.exports = { - async generateCertificateVerificationCode({ - generateCode = _generateCode, - dependencies = { certificationCourseRepository }, - } = {}) { - for (let i = 0; i < NB_OF_TRIALS; i++) { - const code = generateCode(); - const isCodeAvailable = await dependencies.certificationCourseRepository.isVerificationCodeAvailable(code); - if (isCodeAvailable) return code; - } - throw new CertificateVerificationCodeGenerationTooManyTrials(NB_OF_TRIALS); - }, +const generateCertificateVerificationCode = async function ({ + generateCode = _generateCode, + dependencies = { certificationCourseRepository }, +} = {}) { + for (let i = 0; i < NB_OF_TRIALS; i++) { + const code = generateCode(); + const isCodeAvailable = await dependencies.certificationCourseRepository.isVerificationCodeAvailable(code); + if (isCodeAvailable) return code; + } + throw new CertificateVerificationCodeGenerationTooManyTrials(NB_OF_TRIALS); }; + +export { generateCertificateVerificationCode }; diff --git a/api/lib/domain/types/identifiers-type.js b/api/lib/domain/types/identifiers-type.js index 36cb4a9a089..022e8fa898a 100644 --- a/api/lib/domain/types/identifiers-type.js +++ b/api/lib/domain/types/identifiers-type.js @@ -1,5 +1,5 @@ -const Joi = require('joi'); -const _ = require('lodash'); +import Joi from 'joi'; +import _ from 'lodash'; const postgreSQLSequenceDefaultStart = 1; const postgreSQLSequenceEnd = 2 ** 31 - 1; @@ -70,4 +70,4 @@ valuesToExport.positiveInteger32bits = { max: postgreSQLSequenceEnd, }; -module.exports = valuesToExport; +export { valuesToExport as identifiersType }; diff --git a/api/lib/domain/usecases/abort-certification-course.js b/api/lib/domain/usecases/abort-certification-course.js index acce828ac4c..d1c7891a797 100644 --- a/api/lib/domain/usecases/abort-certification-course.js +++ b/api/lib/domain/usecases/abort-certification-course.js @@ -1,4 +1,4 @@ -module.exports = async function abortCertificationCourse({ +const abortCertificationCourse = async function ({ certificationCourseRepository, certificationCourseId, abortReason, @@ -7,3 +7,5 @@ module.exports = async function abortCertificationCourse({ certificationCourse.abort(abortReason); await certificationCourseRepository.update(certificationCourse); }; + +export { abortCertificationCourse }; diff --git a/api/lib/domain/usecases/accept-certification-center-invitation.js b/api/lib/domain/usecases/accept-certification-center-invitation.js index 656537a5c4c..c171b0b6f87 100644 --- a/api/lib/domain/usecases/accept-certification-center-invitation.js +++ b/api/lib/domain/usecases/accept-certification-center-invitation.js @@ -1,6 +1,6 @@ -const { AlreadyExistingMembershipError } = require('../errors.js'); +import { AlreadyExistingMembershipError } from '../errors.js'; -module.exports = async function acceptCertificationCenterInvitation({ +const acceptCertificationCenterInvitation = async function ({ certificationCenterInvitationId, code, email, @@ -40,3 +40,5 @@ module.exports = async function acceptCertificationCenterInvitation({ await certificationCenterInvitedUserRepository.save(certificationCenterInvitedUser); }; + +export { acceptCertificationCenterInvitation }; diff --git a/api/lib/domain/usecases/accept-organization-invitation.js b/api/lib/domain/usecases/accept-organization-invitation.js index 20bd82b26cf..692112005b3 100644 --- a/api/lib/domain/usecases/accept-organization-invitation.js +++ b/api/lib/domain/usecases/accept-organization-invitation.js @@ -1,6 +1,6 @@ -const { AlreadyExistingMembershipError } = require('../../domain/errors.js'); +import { AlreadyExistingMembershipError } from '../../domain/errors.js'; -module.exports = async function acceptOrganizationInvitation({ +const acceptOrganizationInvitation = async function ({ organizationInvitationId, code, email, @@ -31,3 +31,5 @@ module.exports = async function acceptOrganizationInvitation({ await organizationInvitedUserRepository.save({ organizationInvitedUser }); return { id: organizationInvitedUser.currentMembershipId, isAdmin: organizationInvitedUser.currentRole === 'ADMIN' }; }; + +export { acceptOrganizationInvitation }; diff --git a/api/lib/domain/usecases/accept-pix-certif-terms-of-service.js b/api/lib/domain/usecases/accept-pix-certif-terms-of-service.js index e66731c21b4..45b47640fa0 100644 --- a/api/lib/domain/usecases/accept-pix-certif-terms-of-service.js +++ b/api/lib/domain/usecases/accept-pix-certif-terms-of-service.js @@ -1,3 +1,5 @@ -module.exports = function acceptPixCertifTermsOfService({ userId, userRepository }) { +const acceptPixCertifTermsOfService = function ({ userId, userRepository }) { return userRepository.updatePixCertifTermsOfServiceAcceptedToTrue(userId); }; + +export { acceptPixCertifTermsOfService }; diff --git a/api/lib/domain/usecases/accept-pix-last-terms-of-service.js b/api/lib/domain/usecases/accept-pix-last-terms-of-service.js index 46e828a2995..b6a48d1945a 100644 --- a/api/lib/domain/usecases/accept-pix-last-terms-of-service.js +++ b/api/lib/domain/usecases/accept-pix-last-terms-of-service.js @@ -1,3 +1,5 @@ -module.exports = function acceptPixLastTermsOfService({ userId, userRepository }) { +const acceptPixLastTermsOfService = function ({ userId, userRepository }) { return userRepository.acceptPixLastTermsOfService(userId); }; + +export { acceptPixLastTermsOfService }; diff --git a/api/lib/domain/usecases/accept-pix-orga-terms-of-service.js b/api/lib/domain/usecases/accept-pix-orga-terms-of-service.js index 67d5ad819ea..1010e884b02 100644 --- a/api/lib/domain/usecases/accept-pix-orga-terms-of-service.js +++ b/api/lib/domain/usecases/accept-pix-orga-terms-of-service.js @@ -1,3 +1,5 @@ -module.exports = function acceptPixOrgaTermsOfService({ userId, userRepository }) { +const acceptPixOrgaTermsOfService = function ({ userId, userRepository }) { return userRepository.updatePixOrgaTermsOfServiceAcceptedToTrue(userId); }; + +export { acceptPixOrgaTermsOfService }; diff --git a/api/lib/domain/usecases/account-recovery/get-account-recovery-details.js b/api/lib/domain/usecases/account-recovery/get-account-recovery-details.js index 4a8f8c8efc1..e70798f829d 100644 --- a/api/lib/domain/usecases/account-recovery/get-account-recovery-details.js +++ b/api/lib/domain/usecases/account-recovery/get-account-recovery-details.js @@ -1,4 +1,4 @@ -module.exports = async function getAccountRecoveryDetails({ +const getAccountRecoveryDetails = async function ({ temporaryKey, accountRecoveryDemandRepository, organizationLearnerRepository, @@ -20,3 +20,5 @@ module.exports = async function getAccountRecoveryDetails({ firstName, }; }; + +export { getAccountRecoveryDetails }; diff --git a/api/lib/domain/usecases/account-recovery/send-email-for-account-recovery.js b/api/lib/domain/usecases/account-recovery/send-email-for-account-recovery.js index 85f2bc5af9e..e6db0030e52 100644 --- a/api/lib/domain/usecases/account-recovery/send-email-for-account-recovery.js +++ b/api/lib/domain/usecases/account-recovery/send-email-for-account-recovery.js @@ -1,7 +1,7 @@ -const crypto = require('crypto'); -const AccountRecoveryDemand = require('../../models/AccountRecoveryDemand.js'); +import crypto from 'crypto'; +import { AccountRecoveryDemand } from '../../models/AccountRecoveryDemand.js'; -module.exports = async function sendEmailForAccountRecovery({ +const sendEmailForAccountRecovery = async function ({ studentInformation, temporaryKey, organizationLearnerRepository, @@ -45,3 +45,5 @@ module.exports = async function sendEmailForAccountRecovery({ temporaryKey: encodedTemporaryKey, }); }; + +export { sendEmailForAccountRecovery }; diff --git a/api/lib/domain/usecases/account-recovery/update-user-for-account-recovery.js b/api/lib/domain/usecases/account-recovery/update-user-for-account-recovery.js index 64e0da0d662..a4f7b9cb597 100644 --- a/api/lib/domain/usecases/account-recovery/update-user-for-account-recovery.js +++ b/api/lib/domain/usecases/account-recovery/update-user-for-account-recovery.js @@ -1,6 +1,6 @@ -const AuthenticationMethod = require('../../models/AuthenticationMethod.js'); +import { AuthenticationMethod } from '../../models/AuthenticationMethod.js'; -module.exports = async function updateUserForAccountRecovery({ +const updateUserForAccountRecovery = async function ({ password, temporaryKey, userRepository, @@ -59,3 +59,5 @@ module.exports = async function updateUserForAccountRecovery({ }); await accountRecoveryDemandRepository.markAsBeingUsed(temporaryKey, domainTransaction); }; + +export { updateUserForAccountRecovery }; diff --git a/api/lib/domain/usecases/add-certification-candidate-to-session.js b/api/lib/domain/usecases/add-certification-candidate-to-session.js index b4b281c3d4b..42209e7ccfa 100644 --- a/api/lib/domain/usecases/add-certification-candidate-to-session.js +++ b/api/lib/domain/usecases/add-certification-candidate-to-session.js @@ -1,11 +1,11 @@ -const { +import { CertificationCandidateByPersonalInfoTooManyMatchesError, CertificationCandidateAddError, CertificationCandidateOnFinalizedSessionError, CpfBirthInformationValidationError, -} = require('../errors.js'); +} from '../errors.js'; -module.exports = async function addCertificationCandidateToSession({ +const addCertificationCandidateToSession = async function ({ sessionId, certificationCandidate, complementaryCertifications, @@ -62,3 +62,5 @@ module.exports = async function addCertificationCandidateToSession({ sessionId: certificationCandidate.sessionId, }); }; + +export { addCertificationCandidateToSession }; diff --git a/api/lib/domain/usecases/add-pix-authentication-method-by-email.js b/api/lib/domain/usecases/add-pix-authentication-method-by-email.js index 212934fa385..9a4d672675d 100644 --- a/api/lib/domain/usecases/add-pix-authentication-method-by-email.js +++ b/api/lib/domain/usecases/add-pix-authentication-method-by-email.js @@ -1,7 +1,7 @@ -const { AuthenticationMethodAlreadyExistsError } = require('../errors.js'); -const AuthenticationMethod = require('../models/AuthenticationMethod.js'); +import { AuthenticationMethodAlreadyExistsError } from '../errors.js'; +import { AuthenticationMethod } from '../models/AuthenticationMethod.js'; -module.exports = async function addPixAuthenticationMethodByEmail({ +const addPixAuthenticationMethodByEmail = async function ({ userId, email, passwordGenerator, @@ -32,3 +32,5 @@ module.exports = async function addPixAuthenticationMethodByEmail({ return userRepository.getUserDetailsForAdmin(userId); } }; + +export { addPixAuthenticationMethodByEmail }; diff --git a/api/lib/domain/usecases/add-tutorial-evaluation.js b/api/lib/domain/usecases/add-tutorial-evaluation.js index b4821b84f7e..d95b630f140 100644 --- a/api/lib/domain/usecases/add-tutorial-evaluation.js +++ b/api/lib/domain/usecases/add-tutorial-evaluation.js @@ -1,4 +1,4 @@ -module.exports = async function addTutorialEvaluation({ +const addTutorialEvaluation = async function ({ tutorialRepository, tutorialEvaluationRepository, userId, @@ -9,3 +9,5 @@ module.exports = async function addTutorialEvaluation({ return tutorialEvaluationRepository.createOrUpdate({ userId, tutorialId, status }); }; + +export { addTutorialEvaluation }; diff --git a/api/lib/domain/usecases/add-tutorial-to-user.js b/api/lib/domain/usecases/add-tutorial-to-user.js index 4182d9ea1ed..ce8a272be9b 100644 --- a/api/lib/domain/usecases/add-tutorial-to-user.js +++ b/api/lib/domain/usecases/add-tutorial-to-user.js @@ -1,4 +1,4 @@ -module.exports = async function addTutorialToUser({ +const addTutorialToUser = async function ({ tutorialRepository, skillRepository, userSavedTutorialRepository, @@ -11,3 +11,5 @@ module.exports = async function addTutorialToUser({ return userSavedTutorialRepository.addTutorial({ userId, tutorialId, skillId }); }; + +export { addTutorialToUser }; diff --git a/api/lib/domain/usecases/anonymize-user.js b/api/lib/domain/usecases/anonymize-user.js index 2752c7ecdcd..eadc7d276ba 100644 --- a/api/lib/domain/usecases/anonymize-user.js +++ b/api/lib/domain/usecases/anonymize-user.js @@ -1,6 +1,6 @@ -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; -module.exports = async function anonymizeUser({ +const anonymizeUser = async function ({ updatedByUserId, userId, userRepository, @@ -38,3 +38,5 @@ module.exports = async function anonymizeUser({ }); return userRepository.getUserDetailsForAdmin(userId); }; + +export { anonymizeUser }; diff --git a/api/lib/domain/usecases/archive-campaign-from-campaign-code.js b/api/lib/domain/usecases/archive-campaign-from-campaign-code.js index 7273d268da9..89e2d797c61 100644 --- a/api/lib/domain/usecases/archive-campaign-from-campaign-code.js +++ b/api/lib/domain/usecases/archive-campaign-from-campaign-code.js @@ -1,9 +1,7 @@ -module.exports = async function archiveCampaignFromCampaignCode({ - campaignCode, - userId, - campaignForArchivingRepository, -}) { +const archiveCampaignFromCampaignCode = async function ({ campaignCode, userId, campaignForArchivingRepository }) { const campaign = await campaignForArchivingRepository.getByCode(campaignCode); campaign.archive(new Date(), userId); await campaignForArchivingRepository.save(campaign); }; + +export { archiveCampaignFromCampaignCode }; diff --git a/api/lib/domain/usecases/archive-campaign.js b/api/lib/domain/usecases/archive-campaign.js index 8be5355112f..d90dccb0e7d 100644 --- a/api/lib/domain/usecases/archive-campaign.js +++ b/api/lib/domain/usecases/archive-campaign.js @@ -1,6 +1,8 @@ -module.exports = async function archiveCampaign({ campaignId, userId, campaignForArchivingRepository }) { +const archiveCampaign = async function ({ campaignId, userId, campaignForArchivingRepository }) { const campaign = await campaignForArchivingRepository.get(campaignId); campaign.archive(new Date(), userId); await campaignForArchivingRepository.save(campaign); return campaign; }; + +export { archiveCampaign }; diff --git a/api/lib/domain/usecases/archive-organization.js b/api/lib/domain/usecases/archive-organization.js index 636035b3103..1fb68cdbcb1 100644 --- a/api/lib/domain/usecases/archive-organization.js +++ b/api/lib/domain/usecases/archive-organization.js @@ -1,4 +1,6 @@ -module.exports = async function archiveOrganization({ organizationId, userId, organizationForAdminRepository }) { +const archiveOrganization = async function ({ organizationId, userId, organizationForAdminRepository }) { await organizationForAdminRepository.archive({ id: organizationId, archivedBy: userId }); return await organizationForAdminRepository.get(organizationId); }; + +export { archiveOrganization }; diff --git a/api/lib/domain/usecases/assign-certification-officer-to-jury-session.js b/api/lib/domain/usecases/assign-certification-officer-to-jury-session.js index c6a9ae3fd80..863f328f5fd 100644 --- a/api/lib/domain/usecases/assign-certification-officer-to-jury-session.js +++ b/api/lib/domain/usecases/assign-certification-officer-to-jury-session.js @@ -1,4 +1,4 @@ -module.exports = async function assignCertificationOfficerToJurySession({ +const assignCertificationOfficerToJurySession = async function ({ sessionId, certificationOfficerId, jurySessionRepository, @@ -17,3 +17,5 @@ module.exports = async function assignCertificationOfficerToJurySession({ assignedCertificationOfficerId: certificationOfficer.id, }); }; + +export { assignCertificationOfficerToJurySession }; diff --git a/api/lib/domain/usecases/attach-organizations-from-existing-target-profile.js b/api/lib/domain/usecases/attach-organizations-from-existing-target-profile.js index 1f013abe7a8..2f31cafe387 100644 --- a/api/lib/domain/usecases/attach-organizations-from-existing-target-profile.js +++ b/api/lib/domain/usecases/attach-organizations-from-existing-target-profile.js @@ -1,6 +1,6 @@ -const { OrganizationsToAttachToTargetProfile } = require('../models/index.js'); +import { OrganizationsToAttachToTargetProfile } from '../models/index.js'; -module.exports = async function attachOrganizationsFromExistingTargetProfile({ +const attachOrganizationsFromExistingTargetProfile = async function ({ targetProfileId, existingTargetProfileId, organizationsToAttachToTargetProfileRepository, @@ -13,3 +13,5 @@ module.exports = async function attachOrganizationsFromExistingTargetProfile({ await organizationsToAttachToTargetProfileRepository.attachOrganizations(targetProfileOrganizations); }; + +export { attachOrganizationsFromExistingTargetProfile }; diff --git a/api/lib/domain/usecases/attach-organizations-to-target-profile.js b/api/lib/domain/usecases/attach-organizations-to-target-profile.js index daf25c8a8e9..b60b17b780e 100644 --- a/api/lib/domain/usecases/attach-organizations-to-target-profile.js +++ b/api/lib/domain/usecases/attach-organizations-to-target-profile.js @@ -1,6 +1,6 @@ -const { OrganizationsToAttachToTargetProfile } = require('../models/index.js'); +import { OrganizationsToAttachToTargetProfile } from '../models/index.js'; -module.exports = async function attachOrganizationsToTargetProfile({ +const attachOrganizationsToTargetProfile = async function ({ targetProfileId, organizationIds, organizationsToAttachToTargetProfileRepository, @@ -11,3 +11,5 @@ module.exports = async function attachOrganizationsToTargetProfile({ return organizationsToAttachToTargetProfileRepository.attachOrganizations(targetProfileOrganizations); }; + +export { attachOrganizationsToTargetProfile }; diff --git a/api/lib/domain/usecases/attach-target-profiles-to-organization.js b/api/lib/domain/usecases/attach-target-profiles-to-organization.js index 5b17d9da120..19c12ba2771 100644 --- a/api/lib/domain/usecases/attach-target-profiles-to-organization.js +++ b/api/lib/domain/usecases/attach-target-profiles-to-organization.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const { NotFoundError } = require('../errors.js'); +import _ from 'lodash'; +import { NotFoundError } from '../errors.js'; -module.exports = async function attachTargetProfilesToOrganization({ +const attachTargetProfilesToOrganization = async function ({ organizationId, targetProfileIds, targetProfileRepository, @@ -20,3 +20,5 @@ module.exports = async function attachTargetProfilesToOrganization({ targetProfileIdList: uniqTargetProfileIds, }); }; + +export { attachTargetProfilesToOrganization }; diff --git a/api/lib/domain/usecases/attach-target-profiles-to-training.js b/api/lib/domain/usecases/attach-target-profiles-to-training.js index 8763456b372..96a43072860 100644 --- a/api/lib/domain/usecases/attach-target-profiles-to-training.js +++ b/api/lib/domain/usecases/attach-target-profiles-to-training.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const { NotFoundError } = require('../errors.js'); +import _ from 'lodash'; +import { NotFoundError } from '../errors.js'; -module.exports = async function attachTargetProfilesToTraining({ +const attachTargetProfilesToTraining = async function ({ trainingId, targetProfileIds, targetProfileRepository, @@ -20,3 +20,5 @@ module.exports = async function attachTargetProfilesToTraining({ targetProfileIds: uniqTargetProfileIds, }); }; + +export { attachTargetProfilesToTraining }; diff --git a/api/lib/domain/usecases/authenticate-anonymous-user.js b/api/lib/domain/usecases/authenticate-anonymous-user.js index ec85923194a..5c5f3b806dd 100644 --- a/api/lib/domain/usecases/authenticate-anonymous-user.js +++ b/api/lib/domain/usecases/authenticate-anonymous-user.js @@ -1,7 +1,7 @@ -const { UserCantBeCreatedError } = require('../errors.js'); -const UserToCreate = require('../models/UserToCreate.js'); +import { UserCantBeCreatedError } from '../errors.js'; +import { UserToCreate } from '../models/UserToCreate.js'; -module.exports = async function authenticateAnonymousUser({ +const authenticateAnonymousUser = async function ({ campaignCode, lang = 'fr', campaignToJoinRepository, @@ -18,3 +18,5 @@ module.exports = async function authenticateAnonymousUser({ return tokenService.createAccessTokenFromAnonymousUser(newUser.id); }; + +export { authenticateAnonymousUser }; diff --git a/api/lib/domain/usecases/authenticate-application.js b/api/lib/domain/usecases/authenticate-application.js index 86239e36dd8..00e680d3478 100644 --- a/api/lib/domain/usecases/authenticate-application.js +++ b/api/lib/domain/usecases/authenticate-application.js @@ -1,11 +1,15 @@ -const { +import { ApplicationScopeNotAllowedError, ApplicationWithInvalidClientIdError, ApplicationWithInvalidClientSecretError, -} = require('../../domain/errors.js'); +} from '../../domain/errors.js'; -const { find } = require('lodash'); -const { apimRegisterApplicationsCredentials, jwtConfig } = require('../../config.js'); +import lodash from 'lodash'; + +const { find } = lodash; + +import { config } from '../../config.js'; +const { apimRegisterApplicationsCredentials, jwtConfig } = config; function _checkClientId(application, clientId) { if (!application || application.clientId !== clientId) { @@ -25,7 +29,7 @@ function _checkAppScope(application, scope) { } } -module.exports = async function authenticateApplication({ clientId, clientSecret, scope, tokenService }) { +const authenticateApplication = async function ({ clientId, clientSecret, scope, tokenService }) { const application = find(apimRegisterApplicationsCredentials, { clientId }); _checkClientId(application, clientId); _checkClientSecret(application, clientSecret); @@ -39,3 +43,5 @@ module.exports = async function authenticateApplication({ clientId, clientSecret jwtConfig[application.source].tokenLifespan ); }; + +export { authenticateApplication }; diff --git a/api/lib/domain/usecases/authenticate-external-user.js b/api/lib/domain/usecases/authenticate-external-user.js index bf1bdee8dd1..2b7214b82b5 100644 --- a/api/lib/domain/usecases/authenticate-external-user.js +++ b/api/lib/domain/usecases/authenticate-external-user.js @@ -1,13 +1,13 @@ -const { +import { MissingOrInvalidCredentialsError, UserNotFoundError, PasswordNotMatching, UnexpectedUserAccountError, UserAlreadyExistsWithAuthenticationMethodError, UserShouldChangePasswordError, -} = require('../errors.js'); +} from '../errors.js'; -const AuthenticationMethod = require('../models/AuthenticationMethod.js'); +import { AuthenticationMethod } from '../models/AuthenticationMethod.js'; async function authenticateExternalUser({ username, @@ -91,4 +91,4 @@ const _checkIfSamlIdIsNotReconciledWithAnotherUser = async ({ samlId, userId, us } }; -module.exports = authenticateExternalUser; +export { authenticateExternalUser }; diff --git a/api/lib/domain/usecases/authenticate-user.js b/api/lib/domain/usecases/authenticate-user.js index 7b06eb1e5e3..d287948aa70 100644 --- a/api/lib/domain/usecases/authenticate-user.js +++ b/api/lib/domain/usecases/authenticate-user.js @@ -1,29 +1,31 @@ -const get = require('lodash/get'); +import lodash from 'lodash'; -const { +const { get } = lodash; + +import { ForbiddenAccess, LocaleFormatError, LocaleNotSupportedError, MissingOrInvalidCredentialsError, UserShouldChangePasswordError, -} = require('../../domain/errors.js'); +} from '../../domain/errors.js'; -const apps = require('../constants.js'); +import { PIX_ORGA, PIX_ADMIN } from '../constants.js'; async function _checkUserAccessScope(scope, user, adminMemberRepository) { - if (scope === apps.PIX_ORGA.SCOPE && !user.isLinkedToOrganizations()) { - throw new ForbiddenAccess(apps.PIX_ORGA.NOT_LINKED_ORGANIZATION_MSG); + if (scope === PIX_ORGA.SCOPE && !user.isLinkedToOrganizations()) { + throw new ForbiddenAccess(PIX_ORGA.NOT_LINKED_ORGANIZATION_MSG); } - if (scope === apps.PIX_ADMIN.SCOPE) { + if (scope === PIX_ADMIN.SCOPE) { const adminMember = await adminMemberRepository.get({ userId: user.id }); if (!adminMember?.hasAccessToAdminScope) { - throw new ForbiddenAccess(apps.PIX_ADMIN.NOT_ALLOWED_MSG); + throw new ForbiddenAccess(PIX_ADMIN.NOT_ALLOWED_MSG); } } } -module.exports = async function authenticateUser({ +const authenticateUser = async function ({ password, scope, source, @@ -77,3 +79,5 @@ module.exports = async function authenticateUser({ throw new MissingOrInvalidCredentialsError(); } }; + +export { authenticateUser }; diff --git a/api/lib/domain/usecases/authentication/authenticate-oidc-user.js b/api/lib/domain/usecases/authentication/authenticate-oidc-user.js index 89709acb64b..704a5b9b845 100644 --- a/api/lib/domain/usecases/authentication/authenticate-oidc-user.js +++ b/api/lib/domain/usecases/authentication/authenticate-oidc-user.js @@ -1,7 +1,7 @@ -const { UnexpectedOidcStateError } = require('../../errors.js'); -const logger = require('../../../infrastructure/logger.js'); +import { UnexpectedOidcStateError } from '../../errors.js'; +import { logger } from '../../../infrastructure/logger.js'; -module.exports = async function authenticateOidcUser({ +const authenticateOidcUser = async function ({ stateReceived, stateSent, code, @@ -50,6 +50,8 @@ module.exports = async function authenticateOidcUser({ return { pixAccessToken, logoutUrlUUID, isAuthenticationComplete: true }; }; +export { authenticateOidcUser }; + async function _updateAuthenticationMethodWithComplement({ userId, sessionContent, diff --git a/api/lib/domain/usecases/authorize-certification-candidate-to-resume.js b/api/lib/domain/usecases/authorize-certification-candidate-to-resume.js index 2cc6e1e83a7..f480eb72058 100644 --- a/api/lib/domain/usecases/authorize-certification-candidate-to-resume.js +++ b/api/lib/domain/usecases/authorize-certification-candidate-to-resume.js @@ -1,4 +1,4 @@ -module.exports = async function authorizeCertificationCandidateToResume({ +const authorizeCertificationCandidateToResume = async function ({ certificationCandidateId, certificationCandidateForSupervisingRepository, }) { @@ -7,3 +7,5 @@ module.exports = async function authorizeCertificationCandidateToResume({ await certificationCandidateForSupervisingRepository.update(candidate); }; + +export { authorizeCertificationCandidateToResume }; diff --git a/api/lib/domain/usecases/authorize-certification-candidate-to-start.js b/api/lib/domain/usecases/authorize-certification-candidate-to-start.js index 8e139218e81..ef7b5944ac7 100644 --- a/api/lib/domain/usecases/authorize-certification-candidate-to-start.js +++ b/api/lib/domain/usecases/authorize-certification-candidate-to-start.js @@ -1,4 +1,4 @@ -module.exports = async function authorizeCertificationCandidateToStart({ +const authorizeCertificationCandidateToStart = async function ({ certificationCandidateForSupervisingId, authorizedToStart, certificationCandidateForSupervisingRepository, @@ -8,3 +8,5 @@ module.exports = async function authorizeCertificationCandidateToStart({ authorizedToStart, }); }; + +export { authorizeCertificationCandidateToStart }; diff --git a/api/lib/domain/usecases/begin-campaign-participation-improvement.js b/api/lib/domain/usecases/begin-campaign-participation-improvement.js index 6fbcc2a289b..13f65d610da 100644 --- a/api/lib/domain/usecases/begin-campaign-participation-improvement.js +++ b/api/lib/domain/usecases/begin-campaign-participation-improvement.js @@ -1,10 +1,8 @@ -const Assessment = require('../models/Assessment.js'); -const { - AlreadySharedCampaignParticipationError, - UserNotAuthorizedToAccessEntityError, -} = require('../../domain/errors.js'); +import { Assessment } from '../models/Assessment.js'; -module.exports = async function beginCampaignParticipationImprovement({ +import { AlreadySharedCampaignParticipationError, UserNotAuthorizedToAccessEntityError } from '../../domain/errors.js'; + +const beginCampaignParticipationImprovement = async function ({ campaignParticipationId, userId, assessmentRepository, @@ -30,3 +28,5 @@ module.exports = async function beginCampaignParticipationImprovement({ const assessment = Assessment.createImprovingForCampaign({ userId, campaignParticipationId }); await assessmentRepository.save({ assessment, domainTransaction }); }; + +export { beginCampaignParticipationImprovement }; diff --git a/api/lib/domain/usecases/campaigns-administration/archive-campaigns.js b/api/lib/domain/usecases/campaigns-administration/archive-campaigns.js index 95724430fe8..9c5970d2eb8 100644 --- a/api/lib/domain/usecases/campaigns-administration/archive-campaigns.js +++ b/api/lib/domain/usecases/campaigns-administration/archive-campaigns.js @@ -1,3 +1,5 @@ -module.exports = async function archiveCampaigns({ userId, campaignIds, campaignAdministrationRepository }) { +const archiveCampaigns = async function ({ userId, campaignIds, campaignAdministrationRepository }) { await campaignAdministrationRepository.archiveCampaigns(campaignIds, userId); }; + +export { archiveCampaigns }; diff --git a/api/lib/domain/usecases/cancel-certification-center-invitation.js b/api/lib/domain/usecases/cancel-certification-center-invitation.js index 4f72453452e..3cd277dd43f 100644 --- a/api/lib/domain/usecases/cancel-certification-center-invitation.js +++ b/api/lib/domain/usecases/cancel-certification-center-invitation.js @@ -1,6 +1,6 @@ -const { UncancellableCertificationCenterInvitationError } = require('../../domain/errors.js'); +import { UncancellableCertificationCenterInvitationError } from '../../domain/errors.js'; -module.exports = async function cancelCertificationCenterInvitation({ +const cancelCertificationCenterInvitation = async function ({ certificationCenterInvitationId, certificationCenterInvitationRepository, }) { @@ -12,3 +12,5 @@ module.exports = async function cancelCertificationCenterInvitation({ } return await certificationCenterInvitationRepository.markAsCancelled({ id: foundCertificationCenterInvitation.id }); }; + +export { cancelCertificationCenterInvitation }; diff --git a/api/lib/domain/usecases/cancel-certification-course.js b/api/lib/domain/usecases/cancel-certification-course.js index ed214c20dcd..231be506287 100644 --- a/api/lib/domain/usecases/cancel-certification-course.js +++ b/api/lib/domain/usecases/cancel-certification-course.js @@ -1,5 +1,7 @@ -module.exports = async function cancelCertificationCourse({ certificationCourseId, certificationCourseRepository }) { +const cancelCertificationCourse = async function ({ certificationCourseId, certificationCourseRepository }) { const certificationCourse = await certificationCourseRepository.get(certificationCourseId); certificationCourse.cancel(); await certificationCourseRepository.update(certificationCourse); }; + +export { cancelCertificationCourse }; diff --git a/api/lib/domain/usecases/cancel-organization-invitation.js b/api/lib/domain/usecases/cancel-organization-invitation.js index 9a1904586a7..e04c849ed42 100644 --- a/api/lib/domain/usecases/cancel-organization-invitation.js +++ b/api/lib/domain/usecases/cancel-organization-invitation.js @@ -1,9 +1,6 @@ -const { UncancellableOrganizationInvitationError } = require('../../domain/errors.js'); +import { UncancellableOrganizationInvitationError } from '../../domain/errors.js'; -module.exports = async function cancelOrganizationInvitation({ - organizationInvitationId, - organizationInvitationRepository, -}) { +const cancelOrganizationInvitation = async function ({ organizationInvitationId, organizationInvitationRepository }) { const foundOrganizationInvitation = await organizationInvitationRepository.get(organizationInvitationId); if (!foundOrganizationInvitation.isPending) { @@ -12,3 +9,5 @@ module.exports = async function cancelOrganizationInvitation({ return await organizationInvitationRepository.markAsCancelled({ id: organizationInvitationId }); }; + +export { cancelOrganizationInvitation }; diff --git a/api/lib/domain/usecases/certificate/find-certification-attestations-for-division.js b/api/lib/domain/usecases/certificate/find-certification-attestations-for-division.js index 73c155fbea0..3b83589f693 100644 --- a/api/lib/domain/usecases/certificate/find-certification-attestations-for-division.js +++ b/api/lib/domain/usecases/certificate/find-certification-attestations-for-division.js @@ -1,10 +1,6 @@ -const { NoCertificationAttestationForDivisionError } = require('../../errors.js'); +import { NoCertificationAttestationForDivisionError } from '../../errors.js'; -module.exports = async function findCertificationAttestationsForDivision({ - organizationId, - division, - certificateRepository, -}) { +const findCertificationAttestationsForDivision = async function ({ organizationId, division, certificateRepository }) { const certificationAttestations = await certificateRepository.findByDivisionForScoIsManagingStudentsOrganization({ organizationId, division, @@ -15,3 +11,5 @@ module.exports = async function findCertificationAttestationsForDivision({ } return certificationAttestations; }; + +export { findCertificationAttestationsForDivision }; diff --git a/api/lib/domain/usecases/certificate/get-certification-attestation.js b/api/lib/domain/usecases/certificate/get-certification-attestation.js index aab39074857..ee2c48b8f35 100644 --- a/api/lib/domain/usecases/certificate/get-certification-attestation.js +++ b/api/lib/domain/usecases/certificate/get-certification-attestation.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../../errors.js'); +import { NotFoundError } from '../../errors.js'; -module.exports = async function getCertificationAttestation({ userId, certificationId, certificateRepository }) { +const getCertificationAttestation = async function ({ userId, certificationId, certificateRepository }) { const certificationAttestation = await certificateRepository.getCertificationAttestation(certificationId); if (certificationAttestation.userId !== userId) { throw new NotFoundError(); @@ -8,3 +8,5 @@ module.exports = async function getCertificationAttestation({ userId, certificat return certificationAttestation; }; + +export { getCertificationAttestation }; diff --git a/api/lib/domain/usecases/certificate/get-certifications-results-for-ls.js b/api/lib/domain/usecases/certificate/get-certifications-results-for-ls.js index b92a95eb7e0..a9c3eb3dbd8 100644 --- a/api/lib/domain/usecases/certificate/get-certifications-results-for-ls.js +++ b/api/lib/domain/usecases/certificate/get-certifications-results-for-ls.js @@ -1,12 +1,10 @@ -const CertificationsResults = require('../../read-models/livret-scolaire/CertificationsResults.js'); -const Competence = require('../../read-models/livret-scolaire/Competence.js'); -const sortBy = require('lodash/sortBy'); +import { CertificationsResults } from '../../read-models/livret-scolaire/CertificationsResults.js'; +import { Competence } from '../../read-models/livret-scolaire/Competence.js'; +import lodash from 'lodash'; -module.exports = async function getCertificationsResultsForLS({ - uai, - certificationLsRepository, - competenceTreeRepository, -}) { +const { sortBy } = lodash; + +const getCertificationsResultsForLS = async function ({ uai, certificationLsRepository, competenceTreeRepository }) { const [referential, certifications] = await Promise.all([ competenceTreeRepository.get(), certificationLsRepository.getCertificatesByOrganizationUAI(uai), @@ -23,3 +21,5 @@ module.exports = async function getCertificationsResultsForLS({ return new CertificationsResults({ certifications, competences: sortedCompetences }); }; + +export { getCertificationsResultsForLS }; diff --git a/api/lib/domain/usecases/certificate/get-private-certificate.js b/api/lib/domain/usecases/certificate/get-private-certificate.js index 24253d5867a..b0983d1fdaa 100644 --- a/api/lib/domain/usecases/certificate/get-private-certificate.js +++ b/api/lib/domain/usecases/certificate/get-private-certificate.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../../errors.js'); +import { NotFoundError } from '../../errors.js'; -module.exports = async function getPrivateCertificate({ certificationId, userId, locale, certificateRepository }) { +const getPrivateCertificate = async function ({ certificationId, userId, locale, certificateRepository }) { const privateCertificate = await certificateRepository.getPrivateCertificate(certificationId, { locale }); if (privateCertificate.userId !== userId) { throw new NotFoundError(); @@ -8,3 +8,5 @@ module.exports = async function getPrivateCertificate({ certificationId, userId, return privateCertificate; }; + +export { getPrivateCertificate }; diff --git a/api/lib/domain/usecases/certificate/get-shareable-certificate.js b/api/lib/domain/usecases/certificate/get-shareable-certificate.js index b82923f3d8c..d63220392c7 100644 --- a/api/lib/domain/usecases/certificate/get-shareable-certificate.js +++ b/api/lib/domain/usecases/certificate/get-shareable-certificate.js @@ -1,7 +1,9 @@ -module.exports = async function getShareableCertificate({ verificationCode, certificateRepository, locale }) { +const getShareableCertificate = async function ({ verificationCode, certificateRepository, locale }) { const shareableCertificate = await certificateRepository.getShareableCertificateByVerificationCode(verificationCode, { locale, }); return shareableCertificate; }; + +export { getShareableCertificate }; diff --git a/api/lib/domain/usecases/change-user-lang.js b/api/lib/domain/usecases/change-user-lang.js index 8e1d255e3f2..dfbda701104 100644 --- a/api/lib/domain/usecases/change-user-lang.js +++ b/api/lib/domain/usecases/change-user-lang.js @@ -1,4 +1,6 @@ -module.exports = async function changeUserLang({ userId, lang, userRepository }) { +const changeUserLang = async function ({ userId, lang, userRepository }) { await userRepository.update({ id: userId, lang }); return userRepository.getFullById(userId); }; + +export { changeUserLang }; diff --git a/api/lib/domain/usecases/check-sco-account-recovery.js b/api/lib/domain/usecases/check-sco-account-recovery.js index e3a12f3b018..c93f7b25b3e 100644 --- a/api/lib/domain/usecases/check-sco-account-recovery.js +++ b/api/lib/domain/usecases/check-sco-account-recovery.js @@ -1,6 +1,6 @@ -const StudentInformationForAccountRecovery = require('../read-models/StudentInformationForAccountRecovery.js'); +import { StudentInformationForAccountRecovery } from '../read-models/StudentInformationForAccountRecovery.js'; -module.exports = async function checkScoAccountRecovery({ +const checkScoAccountRecovery = async function ({ studentInformation, organizationLearnerRepository, organizationRepository, @@ -28,3 +28,5 @@ module.exports = async function checkScoAccountRecovery({ latestOrganizationName, }); }; + +export { checkScoAccountRecovery }; diff --git a/api/lib/domain/usecases/comment-session-as-jury.js b/api/lib/domain/usecases/comment-session-as-jury.js index edf6108b67d..07ecc424097 100644 --- a/api/lib/domain/usecases/comment-session-as-jury.js +++ b/api/lib/domain/usecases/comment-session-as-jury.js @@ -1,4 +1,4 @@ -module.exports = async function commentSessionAsJury({ +const commentSessionAsJury = async function ({ sessionId, juryComment, juryCommentAuthorId, @@ -13,3 +13,5 @@ module.exports = async function commentSessionAsJury({ await sessionJuryCommentRepository.save(sessionJuryComment); }; + +export { commentSessionAsJury }; diff --git a/api/lib/domain/usecases/complete-assessment.js b/api/lib/domain/usecases/complete-assessment.js index 6f24d5860c4..4555761f861 100644 --- a/api/lib/domain/usecases/complete-assessment.js +++ b/api/lib/domain/usecases/complete-assessment.js @@ -1,9 +1,8 @@ -const AssessmentCompleted = require('../events/AssessmentCompleted.js'); -const CampaignParticipationStatuses = require('../models/CampaignParticipationStatuses.js'); +import { AssessmentCompleted } from '../events/AssessmentCompleted.js'; +import { CampaignParticipationStatuses } from '../models/CampaignParticipationStatuses.js'; +import { AlreadyRatedAssessmentError } from '../errors.js'; -const { AlreadyRatedAssessmentError } = require('../errors.js'); - -module.exports = async function completeAssessment({ +const completeAssessment = async function ({ assessmentId, domainTransaction, campaignParticipationRepository, @@ -38,3 +37,5 @@ module.exports = async function completeAssessment({ assessment, }; }; + +export { completeAssessment }; diff --git a/api/lib/domain/usecases/compute-campaign-analysis.js b/api/lib/domain/usecases/compute-campaign-analysis.js index 86c78feb52a..e58a0580edb 100644 --- a/api/lib/domain/usecases/compute-campaign-analysis.js +++ b/api/lib/domain/usecases/compute-campaign-analysis.js @@ -1,7 +1,7 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); -const CampaignLearningContent = require('../models/CampaignLearningContent.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; +import { CampaignLearningContent } from '../models/CampaignLearningContent.js'; -module.exports = async function computeCampaignAnalysis({ +const computeCampaignAnalysis = async function ({ userId, campaignId, campaignRepository, @@ -22,3 +22,5 @@ module.exports = async function computeCampaignAnalysis({ return campaignAnalysisRepository.getCampaignAnalysis(campaignId, campaignLearningContent, tutorials); }; + +export { computeCampaignAnalysis }; diff --git a/api/lib/domain/usecases/compute-campaign-collective-result.js b/api/lib/domain/usecases/compute-campaign-collective-result.js index dbffcaaef3a..bdb6e884b49 100644 --- a/api/lib/domain/usecases/compute-campaign-collective-result.js +++ b/api/lib/domain/usecases/compute-campaign-collective-result.js @@ -1,7 +1,7 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); -const CampaignLearningContent = require('../models/CampaignLearningContent.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; +import { CampaignLearningContent } from '../models/CampaignLearningContent.js'; -module.exports = async function computeCampaignCollectiveResult({ +const computeCampaignCollectiveResult = async function ({ userId, campaignId, campaignRepository, @@ -19,3 +19,5 @@ module.exports = async function computeCampaignCollectiveResult({ const campaignLearningContent = new CampaignLearningContent(learningContent); return campaignCollectiveResultRepository.getCampaignCollectiveResult(campaignId, campaignLearningContent); }; + +export { computeCampaignCollectiveResult }; diff --git a/api/lib/domain/usecases/compute-campaign-participation-analysis.js b/api/lib/domain/usecases/compute-campaign-participation-analysis.js index 2f5f7780bb0..3089cc09443 100644 --- a/api/lib/domain/usecases/compute-campaign-participation-analysis.js +++ b/api/lib/domain/usecases/compute-campaign-participation-analysis.js @@ -1,7 +1,7 @@ -const { UserNotAuthorizedToAccessEntityError, CampaignParticipationDeletedError } = require('../errors.js'); -const CampaignLearningContent = require('../models/CampaignLearningContent.js'); +import { UserNotAuthorizedToAccessEntityError, CampaignParticipationDeletedError } from '../errors.js'; +import { CampaignLearningContent } from '../models/CampaignLearningContent.js'; -module.exports = async function computeCampaignParticipationAnalysis({ +const computeCampaignParticipationAnalysis = async function ({ userId, campaignParticipationId, campaignParticipationRepository, @@ -38,3 +38,5 @@ module.exports = async function computeCampaignParticipationAnalysis({ tutorials ); }; + +export { computeCampaignParticipationAnalysis }; diff --git a/api/lib/domain/usecases/correct-answer-then-update-assessment.js b/api/lib/domain/usecases/correct-answer-then-update-assessment.js index 0d7f3821b00..6de5f73965b 100644 --- a/api/lib/domain/usecases/correct-answer-then-update-assessment.js +++ b/api/lib/domain/usecases/correct-answer-then-update-assessment.js @@ -1,14 +1,15 @@ -const { +import { ForbiddenAccess, ChallengeNotAskedError, CertificationEndedBySupervisorError, CertificationEndedByFinalizationError, -} = require('../errors.js'); -const Examiner = require('../models/Examiner.js'); -const KnowledgeElement = require('../models/KnowledgeElement.js'); -const logger = require('../../infrastructure/logger.js'); +} from '../errors.js'; -module.exports = async function correctAnswerThenUpdateAssessment({ +import { Examiner } from '../models/Examiner.js'; +import { KnowledgeElement } from '../models/KnowledgeElement.js'; +import { logger } from '../../infrastructure/logger.js'; + +const correctAnswerThenUpdateAssessment = async function ({ answer, userId, locale, @@ -116,6 +117,8 @@ module.exports = async function correctAnswerThenUpdateAssessment({ return answerSaved; }; +export { correctAnswerThenUpdateAssessment }; + function _evaluateAnswer({ challenge, answer, assessment, examiner: injectedExaminer }) { const examiner = injectedExaminer ?? new Examiner({ validator: challenge.validator }); return examiner.evaluate({ diff --git a/api/lib/domain/usecases/correct-answer.js b/api/lib/domain/usecases/correct-answer.js index bc5ebf2b752..ec94037cc8b 100644 --- a/api/lib/domain/usecases/correct-answer.js +++ b/api/lib/domain/usecases/correct-answer.js @@ -1,11 +1,13 @@ -const Examiner = require('../models/Examiner'); +import { Examiner } from '../models/Examiner.js'; -module.exports = async function correctAnswer({ answer, challengeId, challengeRepository, examiner } = {}) { +const correctAnswer = async function ({ answer, challengeId, challengeRepository, examiner } = {}) { const challenge = await challengeRepository.get(challengeId); const result = _evaluateAnswer({ challenge, answer, examiner }); return result; }; +export { correctAnswer }; + // Evaluation temporaire sans enregistrement de la réponse. Utiliser correct-answer-then-update-assessment après ? Peut être... function _evaluateAnswer({ challenge, answer, examiner: injectedExaminer }) { const examiner = injectedExaminer ?? new Examiner({ validator: challenge.validator }); diff --git a/api/lib/domain/usecases/correct-candidate-identity-in-certification-course.js b/api/lib/domain/usecases/correct-candidate-identity-in-certification-course.js index 6162f56b1d7..a0379d29bd3 100644 --- a/api/lib/domain/usecases/correct-candidate-identity-in-certification-course.js +++ b/api/lib/domain/usecases/correct-candidate-identity-in-certification-course.js @@ -1,6 +1,6 @@ -const { CpfBirthInformationValidationError } = require('../errors'); +import { CpfBirthInformationValidationError } from '../errors.js'; -module.exports = async function correctCandidateIdentityInCertificationCourse({ +const correctCandidateIdentityInCertificationCourse = async function ({ command: { certificationCourseId, firstName, @@ -12,6 +12,7 @@ module.exports = async function correctCandidateIdentityInCertificationCourse({ birthPostalCode, birthINSEECode, }, + certificationCourseRepository, certificationCpfService, certificationCpfCountryRepository, @@ -41,3 +42,5 @@ module.exports = async function correctCandidateIdentityInCertificationCourse({ await certificationCourseRepository.update(certificationCourse); }; + +export { correctCandidateIdentityInCertificationCourse }; diff --git a/api/lib/domain/usecases/create-access-token-from-refresh-token.js b/api/lib/domain/usecases/create-access-token-from-refresh-token.js index 1ae14c6404a..a18038e7c2e 100644 --- a/api/lib/domain/usecases/create-access-token-from-refresh-token.js +++ b/api/lib/domain/usecases/create-access-token-from-refresh-token.js @@ -1,3 +1,5 @@ -module.exports = async function createAccessTokenFromRefreshToken({ refreshToken, refreshTokenService }) { +const createAccessTokenFromRefreshToken = async function ({ refreshToken, refreshTokenService }) { return refreshTokenService.createAccessTokenFromRefreshToken({ refreshToken }); }; + +export { createAccessTokenFromRefreshToken }; diff --git a/api/lib/domain/usecases/create-and-reconcile-user-to-organization-learner.js b/api/lib/domain/usecases/create-and-reconcile-user-to-organization-learner.js index 09503239a03..fd4b3c709a6 100644 --- a/api/lib/domain/usecases/create-and-reconcile-user-to-organization-learner.js +++ b/api/lib/domain/usecases/create-and-reconcile-user-to-organization-learner.js @@ -1,17 +1,18 @@ -const isNil = require('lodash/isNil'); +import lodash from 'lodash'; -const { +const { isNil } = lodash; + +import { AlreadyRegisteredEmailError, AlreadyRegisteredUsernameError, CampaignCodeError, EntityValidationError, OrganizationLearnerAlreadyLinkedToUserError, -} = require('../errors.js'); - -const User = require('../models/User.js'); +} from '../errors.js'; -const { getCampaignUrl } = require('../../infrastructure/utils/url-builder.js'); -const { STUDENT_RECONCILIATION_ERRORS } = require('../constants.js'); +import { User } from '../models/User.js'; +import { getCampaignUrl } from '../../infrastructure/utils/url-builder.js'; +import { STUDENT_RECONCILIATION_ERRORS } from '../constants.js'; function _encryptPassword(userPassword, encryptionService) { const encryptedPassword = encryptionService.hashPassword(userPassword); @@ -112,7 +113,7 @@ async function _validateData({ } } -module.exports = async function createAndReconcileUserToOrganizationLearner({ +const createAndReconcileUserToOrganizationLearner = async function ({ campaignCode, locale, password, @@ -185,3 +186,5 @@ module.exports = async function createAndReconcileUserToOrganizationLearner({ } return createdUser; }; + +export { createAndReconcileUserToOrganizationLearner }; diff --git a/api/lib/domain/usecases/create-badge.js b/api/lib/domain/usecases/create-badge.js index d7c46231411..523b9e934e1 100644 --- a/api/lib/domain/usecases/create-badge.js +++ b/api/lib/domain/usecases/create-badge.js @@ -1,7 +1,7 @@ -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); -const { MissingBadgeCriterionError } = require('../errors.js'); +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import { MissingBadgeCriterionError } from '../errors.js'; -module.exports = async function createBadge({ +const createBadge = async function ({ targetProfileId, badgeCreation, badgeRepository, @@ -91,3 +91,5 @@ module.exports = async function createBadge({ return savedBadge; }); }; + +export { createBadge }; diff --git a/api/lib/domain/usecases/create-campaign.js b/api/lib/domain/usecases/create-campaign.js index 20069b5b984..cb73f9d2452 100644 --- a/api/lib/domain/usecases/create-campaign.js +++ b/api/lib/domain/usecases/create-campaign.js @@ -1,4 +1,4 @@ -module.exports = async function createCampaign({ +const createCampaign = async function ({ campaign, campaignRepository, campaignCreatorRepository, @@ -15,3 +15,5 @@ module.exports = async function createCampaign({ return campaignRepository.save(campaignForCreation); }; + +export { createCampaign }; diff --git a/api/lib/domain/usecases/create-certification-center-membership-by-email.js b/api/lib/domain/usecases/create-certification-center-membership-by-email.js index 1744f879c39..8e178bfb458 100644 --- a/api/lib/domain/usecases/create-certification-center-membership-by-email.js +++ b/api/lib/domain/usecases/create-certification-center-membership-by-email.js @@ -1,6 +1,6 @@ -const { AlreadyExistingEntityError } = require('../errors.js'); +import { AlreadyExistingEntityError } from '../errors.js'; -module.exports = async function createCertificationCenterMembershipByEmail({ +const createCertificationCenterMembershipByEmail = async function ({ certificationCenterId, email, certificationCenterMembershipRepository, @@ -21,3 +21,5 @@ module.exports = async function createCertificationCenterMembershipByEmail({ return certificationCenterMembershipRepository.save({ userId, certificationCenterId }); }; + +export { createCertificationCenterMembershipByEmail }; diff --git a/api/lib/domain/usecases/create-certification-center-membership-for-sco-organization-member.js b/api/lib/domain/usecases/create-certification-center-membership-for-sco-organization-member.js index cb035b05ebb..94ae7dc6d2d 100644 --- a/api/lib/domain/usecases/create-certification-center-membership-for-sco-organization-member.js +++ b/api/lib/domain/usecases/create-certification-center-membership-for-sco-organization-member.js @@ -1,4 +1,4 @@ -module.exports = async function createCertificationCenterMembershipForScoOrganizationMember({ +const createCertificationCenterMembershipForScoOrganizationMember = async function ({ membership, membershipRepository, certificationCenterRepository, @@ -27,3 +27,5 @@ module.exports = async function createCertificationCenterMembershipForScoOrganiz } } }; + +export { createCertificationCenterMembershipForScoOrganizationMember }; diff --git a/api/lib/domain/usecases/create-certification-center.js b/api/lib/domain/usecases/create-certification-center.js index 9171227250d..43dc774bdcb 100644 --- a/api/lib/domain/usecases/create-certification-center.js +++ b/api/lib/domain/usecases/create-certification-center.js @@ -1,7 +1,7 @@ -const ComplementaryCertificationHabilitation = require('../models/ComplementaryCertificationHabilitation.js'); -const certificationCenterCreationValidator = require('../validators/certification-center-creation-validator.js'); +import { ComplementaryCertificationHabilitation } from '../models/ComplementaryCertificationHabilitation.js'; +import * as certificationCenterCreationValidator from '../validators/certification-center-creation-validator.js'; -module.exports = async function createCertificationCenter({ +const createCertificationCenter = async function ({ certificationCenter, complementaryCertificationIds, complementaryCertificationHabilitationRepository, @@ -33,3 +33,5 @@ module.exports = async function createCertificationCenter({ return createdCertificationCenter; }; + +export { createCertificationCenter }; diff --git a/api/lib/domain/usecases/create-lcms-release.js b/api/lib/domain/usecases/create-lcms-release.js index 1b4f0860d55..ce7e1ed0bb7 100644 --- a/api/lib/domain/usecases/create-lcms-release.js +++ b/api/lib/domain/usecases/create-lcms-release.js @@ -1,7 +1,9 @@ -const lcms = require('../../infrastructure/lcms.js'); -const { learningContentCache } = require('../../infrastructure/caches/learning-content-cache.js'); +import { lcms } from '../../infrastructure/lcms.js'; +import { learningContentCache } from '../../infrastructure/caches/learning-content-cache.js'; -module.exports = async function createLcmsRelease() { +const createLcmsRelease = async function () { const learningContent = await lcms.createRelease(); learningContentCache.set(learningContent); }; + +export { createLcmsRelease }; diff --git a/api/lib/domain/usecases/create-membership.js b/api/lib/domain/usecases/create-membership.js index 52e2d87eadb..92877fe9912 100644 --- a/api/lib/domain/usecases/create-membership.js +++ b/api/lib/domain/usecases/create-membership.js @@ -1,12 +1,7 @@ -const { roles } = require('../models/Membership.js'); -const { OrganizationArchivedError } = require('../errors.js'); +import { roles } from '../models/Membership.js'; +import { OrganizationArchivedError } from '../errors.js'; -module.exports = async function createMembership({ - userId, - organizationId, - membershipRepository, - organizationRepository, -}) { +const createMembership = async function ({ userId, organizationId, membershipRepository, organizationRepository }) { const organization = await organizationRepository.get(organizationId); if (organization.archivedAt) { @@ -18,3 +13,5 @@ module.exports = async function createMembership({ return membershipRepository.create(userId, organizationId, organizationRole); }; + +export { createMembership }; diff --git a/api/lib/domain/usecases/create-oidc-user.js b/api/lib/domain/usecases/create-oidc-user.js index 12ad582e46f..b39a70fee17 100644 --- a/api/lib/domain/usecases/create-oidc-user.js +++ b/api/lib/domain/usecases/create-oidc-user.js @@ -1,7 +1,7 @@ -const UserToCreate = require('../models/UserToCreate.js'); -const { AuthenticationKeyExpired, UserAlreadyExistsWithAuthenticationMethodError } = require('../errors.js'); +import { UserToCreate } from '../models/UserToCreate.js'; +import { AuthenticationKeyExpired, UserAlreadyExistsWithAuthenticationMethodError } from '../errors.js'; -module.exports = async function createOidcUser({ +const createOidcUser = async function ({ identityProvider, authenticationKey, localeFromCookie, @@ -49,3 +49,5 @@ module.exports = async function createOidcUser({ return { accessToken, logoutUrlUUID }; }; + +export { createOidcUser }; diff --git a/api/lib/domain/usecases/create-or-update-certification-center-invitation-for-admin.js b/api/lib/domain/usecases/create-or-update-certification-center-invitation-for-admin.js index 23fd191dfe3..2568dc41da2 100644 --- a/api/lib/domain/usecases/create-or-update-certification-center-invitation-for-admin.js +++ b/api/lib/domain/usecases/create-or-update-certification-center-invitation-for-admin.js @@ -1,7 +1,7 @@ -const { SendingEmailError, SendingEmailToInvalidDomainError } = require('../errors.js'); -const CertificationCenterInvitation = require('../models/CertificationCenterInvitation.js'); +import { SendingEmailError, SendingEmailToInvalidDomainError } from '../errors.js'; +import { CertificationCenterInvitation } from '../models/CertificationCenterInvitation.js'; -module.exports = async function createOrUpdateCertificationCenterInvitationForAdmin({ +const createOrUpdateCertificationCenterInvitationForAdmin = async function ({ email, certificationCenterId, locale, @@ -45,3 +45,5 @@ module.exports = async function createOrUpdateCertificationCenterInvitationForAd return { isInvitationCreated, certificationCenterInvitation }; }; + +export { createOrUpdateCertificationCenterInvitationForAdmin }; diff --git a/api/lib/domain/usecases/create-or-update-training-trigger.js b/api/lib/domain/usecases/create-or-update-training-trigger.js index 3e87882f689..034840d061e 100644 --- a/api/lib/domain/usecases/create-or-update-training-trigger.js +++ b/api/lib/domain/usecases/create-or-update-training-trigger.js @@ -1,4 +1,4 @@ -module.exports = async function createOrUpdateTrainingTrigger({ +const createOrUpdateTrainingTrigger = async function ({ trainingId, tubes, type, @@ -16,3 +16,5 @@ module.exports = async function createOrUpdateTrainingTrigger({ domainTransaction, }); }; + +export { createOrUpdateTrainingTrigger }; diff --git a/api/lib/domain/usecases/create-or-update-user-orga-settings.js b/api/lib/domain/usecases/create-or-update-user-orga-settings.js index e55c9625bbb..6297306cb3b 100644 --- a/api/lib/domain/usecases/create-or-update-user-orga-settings.js +++ b/api/lib/domain/usecases/create-or-update-user-orga-settings.js @@ -1,7 +1,7 @@ -const { UserNotMemberOfOrganizationError } = require('../errors.js'); -const _ = require('lodash'); +import { UserNotMemberOfOrganizationError } from '../errors.js'; +import _ from 'lodash'; -module.exports = async function createOrUpdateUserOrgaSettings({ +const createOrUpdateUserOrgaSettings = async function ({ userId, organizationId, userOrgaSettingsRepository, @@ -17,3 +17,5 @@ module.exports = async function createOrUpdateUserOrgaSettings({ return userOrgaSettingsRepository.createOrUpdate({ userId, organizationId }); }; + +export { createOrUpdateUserOrgaSettings }; diff --git a/api/lib/domain/usecases/create-organization-invitation-by-admin.js b/api/lib/domain/usecases/create-organization-invitation-by-admin.js index 375f97581c4..8ee98c3ceee 100644 --- a/api/lib/domain/usecases/create-organization-invitation-by-admin.js +++ b/api/lib/domain/usecases/create-organization-invitation-by-admin.js @@ -1,6 +1,6 @@ -const { OrganizationArchivedError } = require('../errors.js'); +import { OrganizationArchivedError } from '../errors.js'; -module.exports = async function createOrganizationInvitationByAdmin({ +const createOrganizationInvitationByAdmin = async function ({ organizationId, email, locale, @@ -24,3 +24,5 @@ module.exports = async function createOrganizationInvitationByAdmin({ organizationRepository, }); }; + +export { createOrganizationInvitationByAdmin }; diff --git a/api/lib/domain/usecases/create-organization-invitations.js b/api/lib/domain/usecases/create-organization-invitations.js index e9dfe35bcdc..beae37ffd2e 100644 --- a/api/lib/domain/usecases/create-organization-invitations.js +++ b/api/lib/domain/usecases/create-organization-invitations.js @@ -1,8 +1,8 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; -const { OrganizationArchivedError } = require('../errors.js'); +import { OrganizationArchivedError } from '../errors.js'; -module.exports = async function createOrganizationInvitations({ +const createOrganizationInvitations = async function ({ organizationId, emails, locale, @@ -29,3 +29,5 @@ module.exports = async function createOrganizationInvitations({ }); }); }; + +export { createOrganizationInvitations }; diff --git a/api/lib/domain/usecases/create-organization-places-lot.js b/api/lib/domain/usecases/create-organization-places-lot.js index 03472ed4b7e..82e71f5a64d 100644 --- a/api/lib/domain/usecases/create-organization-places-lot.js +++ b/api/lib/domain/usecases/create-organization-places-lot.js @@ -1,6 +1,6 @@ -const OrganizationPlacesLot = require('../models/OrganizationPlacesLot.js'); +import { OrganizationPlacesLot } from '../models/OrganizationPlacesLot.js'; -module.exports = async function createOrganizationPlacesLot({ +const createOrganizationPlacesLot = async function ({ organizationPlacesLotData, organizationId, createdBy, @@ -18,3 +18,5 @@ module.exports = async function createOrganizationPlacesLot({ const id = await organizationPlacesLotRepository.create(organizationPlaceLot); return await organizationPlacesLotRepository.get(id); }; + +export { createOrganizationPlacesLot }; diff --git a/api/lib/domain/usecases/create-organization.js b/api/lib/domain/usecases/create-organization.js index 17dffec927f..e40f9ab8d30 100644 --- a/api/lib/domain/usecases/create-organization.js +++ b/api/lib/domain/usecases/create-organization.js @@ -1,4 +1,4 @@ -module.exports = async function createOrganization({ +const createOrganization = async function ({ organization, dataProtectionOfficerRepository, organizationForAdminRepository, @@ -20,3 +20,5 @@ module.exports = async function createOrganization({ return createdOrganization; }; + +export { createOrganization }; diff --git a/api/lib/domain/usecases/create-organizations-with-tags-and-target-profiles.js b/api/lib/domain/usecases/create-organizations-with-tags-and-target-profiles.js index ccef3ed54a0..036df7e739b 100644 --- a/api/lib/domain/usecases/create-organizations-with-tags-and-target-profiles.js +++ b/api/lib/domain/usecases/create-organizations-with-tags-and-target-profiles.js @@ -1,20 +1,23 @@ -const { isEmpty, uniqBy } = require('lodash'); -const bluebird = require('bluebird'); -const Organization = require('../models/Organization.js'); -const OrganizationTag = require('../models/OrganizationTag.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import lodash from 'lodash'; -const { +const { isEmpty, uniqBy } = lodash; + +import bluebird from 'bluebird'; +import { Organization } from '../models/Organization.js'; +import { OrganizationTag } from '../models/OrganizationTag.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; + +import { ManyOrganizationsFoundError, OrganizationAlreadyExistError, OrganizationTagNotFound, ObjectValidationError, TargetProfileInvalidError, -} = require('../errors.js'); +} from '../errors.js'; const SEPARATOR = '_'; -module.exports = async function createOrganizationsWithTagsAndTargetProfiles({ +const createOrganizationsWithTagsAndTargetProfiles = async function ({ organizations, domainTransaction = DomainTransaction, organizationRepository, @@ -123,6 +126,8 @@ module.exports = async function createOrganizationsWithTagsAndTargetProfiles({ return createdOrganizations; }; +export { createOrganizationsWithTagsAndTargetProfiles }; + function _checkIfOrganizationsDataAreUnique(organizations) { const uniqOrganizations = uniqBy(organizations, 'externalId'); diff --git a/api/lib/domain/usecases/create-password-reset-demand.js b/api/lib/domain/usecases/create-password-reset-demand.js index 0e133efd681..b8adb9111c1 100644 --- a/api/lib/domain/usecases/create-password-reset-demand.js +++ b/api/lib/domain/usecases/create-password-reset-demand.js @@ -1,4 +1,4 @@ -module.exports = async function createPasswordResetDemand({ +const createPasswordResetDemand = async function ({ email, locale, mailService, @@ -15,3 +15,5 @@ module.exports = async function createPasswordResetDemand({ return passwordResetDemand; }; + +export { createPasswordResetDemand }; diff --git a/api/lib/domain/usecases/create-session.js b/api/lib/domain/usecases/create-session.js index 4f038432b32..8c3e0d4030d 100644 --- a/api/lib/domain/usecases/create-session.js +++ b/api/lib/domain/usecases/create-session.js @@ -1,9 +1,9 @@ -const { ForbiddenAccess } = require('../errors.js'); -const sessionValidator = require('../validators/session-validator.js'); -const sessionCodeService = require('../services/session-code-service.js'); -const Session = require('../models/Session.js'); +import { ForbiddenAccess } from '../errors.js'; +import * as sessionValidator from '../validators/session-validator.js'; +import * as sessionCodeService from '../services/session-code-service.js'; +import { Session } from '../models/Session.js'; -module.exports = async function createSession({ +const createSession = async function ({ userId, session, certificationCenterRepository, @@ -31,3 +31,5 @@ module.exports = async function createSession({ return sessionRepository.save(domainSession); }; + +export { createSession }; diff --git a/api/lib/domain/usecases/create-tag.js b/api/lib/domain/usecases/create-tag.js index 568dbe31ded..9cb333df789 100644 --- a/api/lib/domain/usecases/create-tag.js +++ b/api/lib/domain/usecases/create-tag.js @@ -1,6 +1,8 @@ -const Tag = require('../models/Tag.js'); +import { Tag } from '../models/Tag.js'; -module.exports = async function createTag({ tagName, tagRepository }) { +const createTag = async function ({ tagName, tagRepository }) { const tag = new Tag({ name: tagName }); return tagRepository.create(tag); }; + +export { createTag }; diff --git a/api/lib/domain/usecases/create-target-profile.js b/api/lib/domain/usecases/create-target-profile.js index 75d49e915ad..490219805f6 100644 --- a/api/lib/domain/usecases/create-target-profile.js +++ b/api/lib/domain/usecases/create-target-profile.js @@ -1,7 +1,7 @@ -const TargetProfileForCreation = require('../models/TargetProfileForCreation.js'); -const { TargetProfileCannotBeCreated } = require('../errors'); +import { TargetProfileForCreation } from '../models/TargetProfileForCreation.js'; +import { TargetProfileCannotBeCreated } from '../errors.js'; -module.exports = async function createTargetProfile({ +const createTargetProfile = async function ({ targetProfileCreationCommand, domainTransaction, targetProfileRepository, @@ -21,3 +21,5 @@ module.exports = async function createTargetProfile({ domainTransaction, }); }; + +export { createTargetProfile }; diff --git a/api/lib/domain/usecases/create-training.js b/api/lib/domain/usecases/create-training.js index 3f151717736..c8df0bff95a 100644 --- a/api/lib/domain/usecases/create-training.js +++ b/api/lib/domain/usecases/create-training.js @@ -1,3 +1,5 @@ -module.exports = function createTraining({ training, domainTransaction, trainingRepository }) { +const createTraining = function ({ training, domainTransaction, trainingRepository }) { return trainingRepository.create({ training, domainTransaction }); }; + +export { createTraining }; diff --git a/api/lib/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user.js b/api/lib/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user.js index e315d6e31d3..9faa6c55923 100644 --- a/api/lib/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user.js +++ b/api/lib/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user.js @@ -1,9 +1,9 @@ -const { CampaignCodeError, ObjectValidationError } = require('../errors.js'); -const User = require('../models/User.js'); -const AuthenticationMethod = require('../models/AuthenticationMethod.js'); -const { STUDENT_RECONCILIATION_ERRORS } = require('../constants.js'); +import { CampaignCodeError, ObjectValidationError } from '../errors.js'; +import { User } from '../models/User.js'; +import { AuthenticationMethod } from '../models/AuthenticationMethod.js'; +import { STUDENT_RECONCILIATION_ERRORS } from '../constants.js'; -module.exports = async function createUserAndReconcileToOrganizationLearnerFromExternalUser({ +const createUserAndReconcileToOrganizationLearnerFromExternalUser = async function ({ birthdate, campaignCode, token, @@ -96,3 +96,5 @@ module.exports = async function createUserAndReconcileToOrganizationLearnerFromE await userRepository.updateLastLoggedAt({ userId: tokenUserId }); return accessToken; }; + +export { createUserAndReconcileToOrganizationLearnerFromExternalUser }; diff --git a/api/lib/domain/usecases/create-user.js b/api/lib/domain/usecases/create-user.js index 4f128cd0eaa..37d08701395 100644 --- a/api/lib/domain/usecases/create-user.js +++ b/api/lib/domain/usecases/create-user.js @@ -1,6 +1,5 @@ -const { AlreadyRegisteredEmailError, EntityValidationError } = require('../errors.js'); - -const { getCampaignUrl } = require('../../infrastructure/utils/url-builder.js'); +import { AlreadyRegisteredEmailError, EntityValidationError } from '../errors.js'; +import { getCampaignUrl } from '../../infrastructure/utils/url-builder.js'; function _manageEmailAvailabilityError(error) { return _manageError(error, AlreadyRegisteredEmailError, 'email', 'ALREADY_REGISTERED_EMAIL'); @@ -52,7 +51,7 @@ async function _validateData({ password, user, userRepository, userValidator, pa return true; } -module.exports = async function createUser({ +const createUser = async function ({ campaignCode, localeFromHeader, password, @@ -104,3 +103,5 @@ module.exports = async function createUser({ return savedUser; } }; + +export { createUser }; diff --git a/api/lib/domain/usecases/deactivate-admin-member.js b/api/lib/domain/usecases/deactivate-admin-member.js index 608f9da0742..c94a8de05e9 100644 --- a/api/lib/domain/usecases/deactivate-admin-member.js +++ b/api/lib/domain/usecases/deactivate-admin-member.js @@ -1,5 +1,7 @@ -module.exports = async function deactivateAdminMember({ id, adminMemberRepository, refreshTokenService }) { +const deactivateAdminMember = async function ({ id, adminMemberRepository, refreshTokenService }) { const { userId } = await adminMemberRepository.getById(id); await adminMemberRepository.deactivate({ id }); await refreshTokenService.revokeRefreshTokensForUserId({ userId }); }; + +export { deactivateAdminMember }; diff --git a/api/lib/domain/usecases/delete-campaign-participation-for-admin.js b/api/lib/domain/usecases/delete-campaign-participation-for-admin.js index 5949a73b8b0..3b6b7585040 100644 --- a/api/lib/domain/usecases/delete-campaign-participation-for-admin.js +++ b/api/lib/domain/usecases/delete-campaign-participation-for-admin.js @@ -1,6 +1,6 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; -module.exports = async function deleteCampaignParticipationForAdmin({ +const deleteCampaignParticipationForAdmin = async function ({ userId, campaignParticipationId, domainTransaction, @@ -19,6 +19,8 @@ module.exports = async function deleteCampaignParticipationForAdmin({ await bluebird.mapSeries(campaignParticipations, async (campaignParticipation) => { campaignParticipation.delete(userId); const { id, deletedAt, deletedBy } = campaignParticipation; - await campaignParticipationRepository.delete({ id, deletedAt, deletedBy, domainTransaction }); + await campaignParticipationRepository.remove({ id, deletedAt, deletedBy, domainTransaction }); }); }; + +export { deleteCampaignParticipationForAdmin }; diff --git a/api/lib/domain/usecases/delete-campaign-participation.js b/api/lib/domain/usecases/delete-campaign-participation.js index d8cf1d48cb6..01fc364f830 100644 --- a/api/lib/domain/usecases/delete-campaign-participation.js +++ b/api/lib/domain/usecases/delete-campaign-participation.js @@ -1,6 +1,6 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; -module.exports = async function deleteCampaignParticipation({ +const deleteCampaignParticipation = async function ({ userId, campaignId, domainTransaction, @@ -17,6 +17,8 @@ module.exports = async function deleteCampaignParticipation({ await bluebird.mapSeries(campaignParticipations, async (campaignParticipation) => { campaignParticipation.delete(userId); const { id, deletedAt, deletedBy } = campaignParticipation; - await campaignParticipationRepository.delete({ id, deletedAt, deletedBy, domainTransaction }); + await campaignParticipationRepository.remove({ id, deletedAt, deletedBy, domainTransaction }); }); }; + +export { deleteCampaignParticipation }; diff --git a/api/lib/domain/usecases/delete-certification-issue-report.js b/api/lib/domain/usecases/delete-certification-issue-report.js index 0fc1e76a719..ababea7d2bd 100644 --- a/api/lib/domain/usecases/delete-certification-issue-report.js +++ b/api/lib/domain/usecases/delete-certification-issue-report.js @@ -1,6 +1,6 @@ -const { ForbiddenAccess } = require('../errors.js'); +import { ForbiddenAccess } from '../errors.js'; -module.exports = async function deleteCertificationIssueReport({ +const deleteCertificationIssueReport = async function ({ certificationIssueReportId, certificationCourseRepository, certificationIssueReportRepository, @@ -14,5 +14,7 @@ module.exports = async function deleteCertificationIssueReport({ throw new ForbiddenAccess('Certification issue report deletion forbidden'); } - return certificationIssueReportRepository.delete(certificationIssueReportId); + return certificationIssueReportRepository.remove(certificationIssueReportId); }; + +export { deleteCertificationIssueReport }; diff --git a/api/lib/domain/usecases/delete-organization-place-lot.js b/api/lib/domain/usecases/delete-organization-place-lot.js index d226ffa2d23..895ea8597e7 100644 --- a/api/lib/domain/usecases/delete-organization-place-lot.js +++ b/api/lib/domain/usecases/delete-organization-place-lot.js @@ -1,8 +1,6 @@ -module.exports = async function deleteOrganizationPlaceLot({ - organizationPlaceId, - userId, - organizationPlacesLotRepository, -}) { +const deleteOrganizationPlaceLot = async function ({ organizationPlaceId, userId, organizationPlacesLotRepository }) { await organizationPlacesLotRepository.get(organizationPlaceId); - await organizationPlacesLotRepository.delete({ id: organizationPlaceId, deletedBy: userId }); + await organizationPlacesLotRepository.remove({ id: organizationPlaceId, deletedBy: userId }); }; + +export { deleteOrganizationPlaceLot }; diff --git a/api/lib/domain/usecases/delete-session-jury-comment.js b/api/lib/domain/usecases/delete-session-jury-comment.js index bf06b9fd617..b27d8d1c5d1 100644 --- a/api/lib/domain/usecases/delete-session-jury-comment.js +++ b/api/lib/domain/usecases/delete-session-jury-comment.js @@ -1,3 +1,5 @@ -module.exports = async function deleteSessionJuryComment({ sessionId, sessionJuryCommentRepository }) { - await sessionJuryCommentRepository.delete(sessionId); +const deleteSessionJuryComment = async function ({ sessionId, sessionJuryCommentRepository }) { + await sessionJuryCommentRepository.remove(sessionId); }; + +export { deleteSessionJuryComment }; diff --git a/api/lib/domain/usecases/delete-session.js b/api/lib/domain/usecases/delete-session.js index 94f55e46556..3045dcee4c7 100644 --- a/api/lib/domain/usecases/delete-session.js +++ b/api/lib/domain/usecases/delete-session.js @@ -1,13 +1,15 @@ -const { SessionStartedDeletionError } = require('../errors.js'); +import { SessionStartedDeletionError } from '../errors.js'; -module.exports = async function deleteSession({ sessionId, sessionRepository, certificationCourseRepository }) { +const deleteSession = async function ({ sessionId, sessionRepository, certificationCourseRepository }) { if (await _isSessionStarted(certificationCourseRepository, sessionId)) { throw new SessionStartedDeletionError(); } - await sessionRepository.delete(sessionId); + await sessionRepository.remove(sessionId); }; +export { deleteSession }; + async function _isSessionStarted(certificationCourseRepository, sessionId) { const foundCertificationCourses = await certificationCourseRepository.findCertificationCoursesBySessionId({ sessionId, diff --git a/api/lib/domain/usecases/delete-unassociated-badge.js b/api/lib/domain/usecases/delete-unassociated-badge.js index d16a93f3548..f8a2887b7c0 100644 --- a/api/lib/domain/usecases/delete-unassociated-badge.js +++ b/api/lib/domain/usecases/delete-unassociated-badge.js @@ -1,7 +1,8 @@ -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); -const { AcquiredBadgeForbiddenDeletionError, CertificationBadgeForbiddenDeletionError } = require('../errors.js'); +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; -module.exports = async function deleteUnassociatedBadge({ badgeId, badgeRepository }) { +import { AcquiredBadgeForbiddenDeletionError, CertificationBadgeForbiddenDeletionError } from '../errors.js'; + +const deleteUnassociatedBadge = async function ({ badgeId, badgeRepository }) { return DomainTransaction.execute(async (domainTransaction) => { const isAssociated = await badgeRepository.isAssociated(badgeId, domainTransaction); const isRelatedToCertification = await badgeRepository.isRelatedToCertification(badgeId, domainTransaction); @@ -14,6 +15,8 @@ module.exports = async function deleteUnassociatedBadge({ badgeId, badgeReposito throw new CertificationBadgeForbiddenDeletionError(); } - return badgeRepository.delete(badgeId, domainTransaction); + return badgeRepository.remove(badgeId, domainTransaction); }); }; + +export { deleteUnassociatedBadge }; diff --git a/api/lib/domain/usecases/delete-unlinked-certification-candidate.js b/api/lib/domain/usecases/delete-unlinked-certification-candidate.js index fb8b1d29486..72b35eb799e 100644 --- a/api/lib/domain/usecases/delete-unlinked-certification-candidate.js +++ b/api/lib/domain/usecases/delete-unlinked-certification-candidate.js @@ -1,14 +1,16 @@ -const { CertificationCandidateForbiddenDeletionError } = require('../errors.js'); +import { CertificationCandidateForbiddenDeletionError } from '../errors.js'; -module.exports = async function deleteUnlinkedCertificationCandidate({ +const deleteUnlinkedCertificationCandidate = async function ({ certificationCandidateId, certificationCandidateRepository, }) { const isNotLinked = await certificationCandidateRepository.isNotLinked(certificationCandidateId); if (isNotLinked) { - return certificationCandidateRepository.delete(certificationCandidateId); + return certificationCandidateRepository.remove(certificationCandidateId); } throw new CertificationCandidateForbiddenDeletionError(); }; + +export { deleteUnlinkedCertificationCandidate }; diff --git a/api/lib/domain/usecases/deneutralize-challenge.js b/api/lib/domain/usecases/deneutralize-challenge.js index ad2e6a86d99..56ea5aa9d9a 100644 --- a/api/lib/domain/usecases/deneutralize-challenge.js +++ b/api/lib/domain/usecases/deneutralize-challenge.js @@ -1,6 +1,6 @@ -const ChallengeDeneutralized = require('../events/ChallengeDeneutralized.js'); +import { ChallengeDeneutralized } from '../events/ChallengeDeneutralized.js'; -module.exports = async function deneutralizeChallenge({ +const deneutralizeChallenge = async function ({ certificationAssessmentRepository, certificationCourseId, challengeRecId, @@ -13,3 +13,5 @@ module.exports = async function deneutralizeChallenge({ await certificationAssessmentRepository.save(certificationAssessment); return new ChallengeDeneutralized({ certificationCourseId, juryId }); }; + +export { deneutralizeChallenge }; diff --git a/api/lib/domain/usecases/disable-certification-center-membership.js b/api/lib/domain/usecases/disable-certification-center-membership.js index 924a7fa552d..41a8ae628cf 100644 --- a/api/lib/domain/usecases/disable-certification-center-membership.js +++ b/api/lib/domain/usecases/disable-certification-center-membership.js @@ -1,6 +1,8 @@ -module.exports = async function disableCertificationCenterMembership({ +const disableCertificationCenterMembership = async function ({ certificationCenterMembershipId, certificationCenterMembershipRepository, }) { return certificationCenterMembershipRepository.disableById({ certificationCenterMembershipId }); }; + +export { disableCertificationCenterMembership }; diff --git a/api/lib/domain/usecases/disable-membership.js b/api/lib/domain/usecases/disable-membership.js index 8d0117d9fe0..075a2628312 100644 --- a/api/lib/domain/usecases/disable-membership.js +++ b/api/lib/domain/usecases/disable-membership.js @@ -1,4 +1,6 @@ -module.exports = async function disableMembership({ membershipId, userId, membershipRepository }) { +const disableMembership = async function ({ membershipId, userId, membershipRepository }) { const membership = { disabledAt: new Date(), updatedByUserId: userId }; return membershipRepository.updateById({ id: membershipId, membership }); }; + +export { disableMembership }; diff --git a/api/lib/domain/usecases/dissociate-user-from-organization-learner.js b/api/lib/domain/usecases/dissociate-user-from-organization-learner.js index 410a7735d9d..9acbe953ef0 100644 --- a/api/lib/domain/usecases/dissociate-user-from-organization-learner.js +++ b/api/lib/domain/usecases/dissociate-user-from-organization-learner.js @@ -1,6 +1,6 @@ -const { OrganizationLearnerCannotBeDissociatedError } = require('../errors.js'); +import { OrganizationLearnerCannotBeDissociatedError } from '../errors.js'; -module.exports = async function dissociateUserFromOrganizationLearner({ +const dissociateUserFromOrganizationLearner = async function ({ organizationLearnerId, organizationLearnerRepository, }) { @@ -13,3 +13,5 @@ module.exports = async function dissociateUserFromOrganizationLearner({ await organizationLearnerRepository.dissociateUserFromOrganizationLearner(organizationLearnerId); }; + +export { dissociateUserFromOrganizationLearner }; diff --git a/api/lib/domain/usecases/end-assessment-by-supervisor.js b/api/lib/domain/usecases/end-assessment-by-supervisor.js index 3dcc4a14fab..a5507531b2c 100644 --- a/api/lib/domain/usecases/end-assessment-by-supervisor.js +++ b/api/lib/domain/usecases/end-assessment-by-supervisor.js @@ -1,4 +1,4 @@ -module.exports = async function endAssessmentBySupervisor({ certificationCandidateId, assessmentRepository }) { +const endAssessmentBySupervisor = async function ({ certificationCandidateId, assessmentRepository }) { const assessment = await assessmentRepository.getByCertificationCandidateId(certificationCandidateId); if (assessment.isCompleted()) { @@ -7,3 +7,5 @@ module.exports = async function endAssessmentBySupervisor({ certificationCandida await assessmentRepository.endBySupervisorByAssessmentId(assessment.id); }; + +export { endAssessmentBySupervisor }; diff --git a/api/lib/domain/usecases/enrol-students-to-session.js b/api/lib/domain/usecases/enrol-students-to-session.js index b32c66ae82d..9dd026f18a0 100644 --- a/api/lib/domain/usecases/enrol-students-to-session.js +++ b/api/lib/domain/usecases/enrol-students-to-session.js @@ -1,9 +1,9 @@ -const SCOCertificationCandidate = require('../models/SCOCertificationCandidate.js'); -const _ = require('lodash'); -const { ForbiddenAccess, UnknownCountryForStudentEnrolmentError } = require('../errors.js'); +import { SCOCertificationCandidate } from '../models/SCOCertificationCandidate.js'; +import _ from 'lodash'; +import { ForbiddenAccess, UnknownCountryForStudentEnrolmentError } from '../errors.js'; const INSEE_PREFIX_CODE = '99'; -module.exports = async function enrolStudentsToSession({ +const enrolStudentsToSession = async function ({ sessionId, referentId, studentIds, @@ -61,6 +61,8 @@ module.exports = async function enrolStudentsToSession({ }); }; +export { enrolStudentsToSession }; + function _doesSessionBelongToSameCertificationCenterAsReferent(referentCertificationCenterMemberships, session) { return referentCertificationCenterMemberships.some( (membership) => membership.certificationCenter.id === session.certificationCenterId diff --git a/api/lib/domain/usecases/finalize-session.js b/api/lib/domain/usecases/finalize-session.js index 432eda0af54..741093741c1 100644 --- a/api/lib/domain/usecases/finalize-session.js +++ b/api/lib/domain/usecases/finalize-session.js @@ -1,13 +1,14 @@ -const { +import { SessionAlreadyFinalizedError, SessionWithoutStartedCertificationError, SessionWithAbortReasonOnCompletedCertificationCourseError, SessionWithMissingAbortReasonError, -} = require('../errors.js'); -const SessionFinalized = require('../events/SessionFinalized.js'); -const bluebird = require('bluebird'); +} from '../errors.js'; -module.exports = async function finalizeSession({ +import { SessionFinalized } from '../events/SessionFinalized.js'; +import bluebird from 'bluebird'; + +const finalizeSession = async function ({ sessionId, examinerGlobalComment, certificationReports, @@ -74,6 +75,8 @@ module.exports = async function finalizeSession({ }); }; +export { finalizeSession }; + function _hasAbortReasonForCompletedCertificationCourse({ abortReasonCount, uncompletedCertificationCount }) { return abortReasonCount > uncompletedCertificationCount; } diff --git a/api/lib/domain/usecases/find-all-tags.js b/api/lib/domain/usecases/find-all-tags.js index d126101085b..d4c0119849a 100644 --- a/api/lib/domain/usecases/find-all-tags.js +++ b/api/lib/domain/usecases/find-all-tags.js @@ -1,3 +1,5 @@ -module.exports = function findAllTags({ tagRepository }) { +const findAllTags = function ({ tagRepository }) { return tagRepository.findAll(); }; + +export { findAllTags }; diff --git a/api/lib/domain/usecases/find-answer-by-assessment.js b/api/lib/domain/usecases/find-answer-by-assessment.js index c978df9a59f..344366e4bf4 100644 --- a/api/lib/domain/usecases/find-answer-by-assessment.js +++ b/api/lib/domain/usecases/find-answer-by-assessment.js @@ -1,11 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError, EntityValidationError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError, EntityValidationError } from '../errors.js'; -module.exports = async function findAnswerByAssessment({ - assessmentId, - userId, - answerRepository, - assessmentRepository, -} = {}) { +const findAnswerByAssessment = async function ({ assessmentId, userId, answerRepository, assessmentRepository } = {}) { const integerAssessmentId = parseInt(assessmentId); if (!Number.isFinite(integerAssessmentId)) { throw new EntityValidationError({ @@ -19,3 +14,5 @@ module.exports = async function findAnswerByAssessment({ } return answerRepository.findByAssessment(integerAssessmentId); }; + +export { findAnswerByAssessment }; diff --git a/api/lib/domain/usecases/find-answer-by-challenge-and-assessment.js b/api/lib/domain/usecases/find-answer-by-challenge-and-assessment.js index 9dd7f7b3ac3..b016ed941f6 100644 --- a/api/lib/domain/usecases/find-answer-by-challenge-and-assessment.js +++ b/api/lib/domain/usecases/find-answer-by-challenge-and-assessment.js @@ -1,4 +1,4 @@ -module.exports = async function findAnswerByChallengeAndAssessment({ +const findAnswerByChallengeAndAssessment = async function ({ challengeId, assessmentId, userId, @@ -17,3 +17,5 @@ module.exports = async function findAnswerByChallengeAndAssessment({ return answerRepository.findByChallengeAndAssessment({ challengeId, assessmentId: integerAssessmentId }); }; + +export { findAnswerByChallengeAndAssessment }; diff --git a/api/lib/domain/usecases/find-assessment-participation-result-list.js b/api/lib/domain/usecases/find-assessment-participation-result-list.js index b01fc0036de..1f7aed912d5 100644 --- a/api/lib/domain/usecases/find-assessment-participation-result-list.js +++ b/api/lib/domain/usecases/find-assessment-participation-result-list.js @@ -7,4 +7,4 @@ function findAssessmentParticipationResultList({ return campaignAssessmentParticipationResultListRepository.findPaginatedByCampaignId({ campaignId, filters, page }); } -module.exports = findAssessmentParticipationResultList; +export { findAssessmentParticipationResultList }; diff --git a/api/lib/domain/usecases/find-association-between-user-and-organization-learner.js b/api/lib/domain/usecases/find-association-between-user-and-organization-learner.js index 99ad2e9a2b6..bf0f1d9f273 100644 --- a/api/lib/domain/usecases/find-association-between-user-and-organization-learner.js +++ b/api/lib/domain/usecases/find-association-between-user-and-organization-learner.js @@ -1,10 +1,10 @@ -const { +import { CampaignCodeError, UserNotAuthorizedToAccessEntityError, OrganizationLearnerDisabledError, -} = require('../errors.js'); +} from '../errors.js'; -module.exports = async function findAssociationBetweenUserAndOrganizationLearner({ +const findAssociationBetweenUserAndOrganizationLearner = async function ({ authenticatedUserId, requestedUserId, campaignCode, @@ -31,3 +31,5 @@ module.exports = async function findAssociationBetweenUserAndOrganizationLearner return organizationLearner; }; + +export { findAssociationBetweenUserAndOrganizationLearner }; diff --git a/api/lib/domain/usecases/find-campaign-participation-trainings.js b/api/lib/domain/usecases/find-campaign-participation-trainings.js index 3b00139000f..4ef893be5e4 100644 --- a/api/lib/domain/usecases/find-campaign-participation-trainings.js +++ b/api/lib/domain/usecases/find-campaign-participation-trainings.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToFindTrainings } = require('../errors.js'); +import { UserNotAuthorizedToFindTrainings } from '../errors.js'; -module.exports = async function findCampaignParticipationTrainings({ +const findCampaignParticipationTrainings = async function ({ userId, locale, campaignParticipationId, @@ -15,3 +15,5 @@ module.exports = async function findCampaignParticipationTrainings({ return userRecommendedTrainingRepository.findByCampaignParticipationId({ campaignParticipationId, locale }); }; + +export { findCampaignParticipationTrainings }; diff --git a/api/lib/domain/usecases/find-campaign-participations-for-user-management.js b/api/lib/domain/usecases/find-campaign-participations-for-user-management.js index d549e12408b..c80e3eb1efd 100644 --- a/api/lib/domain/usecases/find-campaign-participations-for-user-management.js +++ b/api/lib/domain/usecases/find-campaign-participations-for-user-management.js @@ -1,6 +1,8 @@ -module.exports = async function findCampaignParticipationsForUserManagement({ +const findCampaignParticipationsForUserManagement = async function ({ userId, participationsForUserManagementRepository, }) { return participationsForUserManagementRepository.findByUserId(userId); }; + +export { findCampaignParticipationsForUserManagement }; diff --git a/api/lib/domain/usecases/find-campaign-profiles-collection-participation-summaries.js b/api/lib/domain/usecases/find-campaign-profiles-collection-participation-summaries.js index 175af3a35a5..bf16be682cd 100644 --- a/api/lib/domain/usecases/find-campaign-profiles-collection-participation-summaries.js +++ b/api/lib/domain/usecases/find-campaign-profiles-collection-participation-summaries.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function findCampaignProfilesCollectionParticipationSummaries({ +const findCampaignProfilesCollectionParticipationSummaries = async function ({ userId, campaignId, page, @@ -13,3 +13,5 @@ module.exports = async function findCampaignProfilesCollectionParticipationSumma } return campaignProfilesCollectionParticipationSummaryRepository.findPaginatedByCampaignId(campaignId, page, filters); }; + +export { findCampaignProfilesCollectionParticipationSummaries }; diff --git a/api/lib/domain/usecases/find-certification-center-memberships-by-certification-center.js b/api/lib/domain/usecases/find-certification-center-memberships-by-certification-center.js index 06b9aebd190..87a5fdd16a8 100644 --- a/api/lib/domain/usecases/find-certification-center-memberships-by-certification-center.js +++ b/api/lib/domain/usecases/find-certification-center-memberships-by-certification-center.js @@ -1,6 +1,8 @@ -module.exports = function findCertificationCenterMembershipsByCertificationCenter({ +const findCertificationCenterMembershipsByCertificationCenter = function ({ certificationCenterId, certificationCenterMembershipRepository, }) { return certificationCenterMembershipRepository.findActiveByCertificationCenterIdSortedById({ certificationCenterId }); }; + +export { findCertificationCenterMembershipsByCertificationCenter }; diff --git a/api/lib/domain/usecases/find-certification-center-memberships-by-user.js b/api/lib/domain/usecases/find-certification-center-memberships-by-user.js index 85150b55a11..21c037b46eb 100644 --- a/api/lib/domain/usecases/find-certification-center-memberships-by-user.js +++ b/api/lib/domain/usecases/find-certification-center-memberships-by-user.js @@ -1,6 +1,5 @@ -module.exports = async function findCertificationCenterMembershipsByUser({ - userId, - certificationCenterMembershipRepository, -}) { +const findCertificationCenterMembershipsByUser = async function ({ userId, certificationCenterMembershipRepository }) { return certificationCenterMembershipRepository.findByUserId(userId); }; + +export { findCertificationCenterMembershipsByUser }; diff --git a/api/lib/domain/usecases/find-competence-evaluations-by-assessment.js b/api/lib/domain/usecases/find-competence-evaluations-by-assessment.js index 7a3066c63f6..96914750c6f 100644 --- a/api/lib/domain/usecases/find-competence-evaluations-by-assessment.js +++ b/api/lib/domain/usecases/find-competence-evaluations-by-assessment.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function findCompetenceEvaluationsByAssessment({ +const findCompetenceEvaluationsByAssessment = async function ({ userId, assessmentId, assessmentRepository, @@ -12,3 +12,5 @@ module.exports = async function findCompetenceEvaluationsByAssessment({ return competenceEvaluationRepository.findByAssessmentId(assessmentId); }; + +export { findCompetenceEvaluationsByAssessment }; diff --git a/api/lib/domain/usecases/find-complementary-certifications.js b/api/lib/domain/usecases/find-complementary-certifications.js index 0b91c4cf03d..ceb78682a14 100644 --- a/api/lib/domain/usecases/find-complementary-certifications.js +++ b/api/lib/domain/usecases/find-complementary-certifications.js @@ -1,3 +1,5 @@ -module.exports = function findComplementaryCertifications({ complementaryCertificationRepository }) { +const findComplementaryCertifications = function ({ complementaryCertificationRepository }) { return complementaryCertificationRepository.findAll(); }; + +export { findComplementaryCertifications }; diff --git a/api/lib/domain/usecases/find-countries.js b/api/lib/domain/usecases/find-countries.js index e56bb8ba489..bd508040147 100644 --- a/api/lib/domain/usecases/find-countries.js +++ b/api/lib/domain/usecases/find-countries.js @@ -1,3 +1,5 @@ -module.exports = function findCountries({ countryRepository }) { +const findCountries = function ({ countryRepository }) { return countryRepository.findAll(); }; + +export { findCountries }; diff --git a/api/lib/domain/usecases/find-divisions-by-certification-center.js b/api/lib/domain/usecases/find-divisions-by-certification-center.js index ab84fc0c567..86ca40b34b4 100644 --- a/api/lib/domain/usecases/find-divisions-by-certification-center.js +++ b/api/lib/domain/usecases/find-divisions-by-certification-center.js @@ -1,4 +1,4 @@ -module.exports = async function findDivisionsByCertificationCenter({ +const findDivisionsByCertificationCenter = async function ({ certificationCenterId, organizationRepository, divisionRepository, @@ -6,3 +6,5 @@ module.exports = async function findDivisionsByCertificationCenter({ const organizationId = await organizationRepository.getIdByCertificationCenterId(certificationCenterId); return divisionRepository.findByOrganizationIdForCurrentSchoolYear({ organizationId }); }; + +export { findDivisionsByCertificationCenter }; diff --git a/api/lib/domain/usecases/find-divisions-by-organization.js b/api/lib/domain/usecases/find-divisions-by-organization.js index c576ae0a39d..b50a7c6c524 100644 --- a/api/lib/domain/usecases/find-divisions-by-organization.js +++ b/api/lib/domain/usecases/find-divisions-by-organization.js @@ -1,4 +1,4 @@ -module.exports = async function findDivisionsByOrganization({ organizationId, divisionRepository }) { +const findDivisionsByOrganization = async function ({ organizationId, divisionRepository }) { const divisionsOrderedByPostgres = await divisionRepository.findByOrganizationIdForCurrentSchoolYear({ organizationId, }); @@ -7,3 +7,5 @@ module.exports = async function findDivisionsByOrganization({ organizationId, di ); return divisionsOrderedByName; }; + +export { findDivisionsByOrganization }; diff --git a/api/lib/domain/usecases/find-finalized-sessions-to-publish.js b/api/lib/domain/usecases/find-finalized-sessions-to-publish.js index f6281975c78..6adb6b4faef 100644 --- a/api/lib/domain/usecases/find-finalized-sessions-to-publish.js +++ b/api/lib/domain/usecases/find-finalized-sessions-to-publish.js @@ -1,3 +1,5 @@ -module.exports = function findFinalizedSessionsToPublish({ finalizedSessionRepository }) { +const findFinalizedSessionsToPublish = function ({ finalizedSessionRepository }) { return finalizedSessionRepository.findFinalizedSessionsToPublish(); }; + +export { findFinalizedSessionsToPublish }; diff --git a/api/lib/domain/usecases/find-finalized-sessions-with-required-action.js b/api/lib/domain/usecases/find-finalized-sessions-with-required-action.js index 793ba5a46ba..0a194039242 100644 --- a/api/lib/domain/usecases/find-finalized-sessions-with-required-action.js +++ b/api/lib/domain/usecases/find-finalized-sessions-with-required-action.js @@ -1,3 +1,5 @@ -module.exports = function findFinalizedSessionsWithRequiredAction({ finalizedSessionRepository }) { +const findFinalizedSessionsWithRequiredAction = function ({ finalizedSessionRepository }) { return finalizedSessionRepository.findFinalizedSessionsWithRequiredAction(); }; + +export { findFinalizedSessionsWithRequiredAction }; diff --git a/api/lib/domain/usecases/find-groups-by-organization.js b/api/lib/domain/usecases/find-groups-by-organization.js index 424c9465c40..51588084a64 100644 --- a/api/lib/domain/usecases/find-groups-by-organization.js +++ b/api/lib/domain/usecases/find-groups-by-organization.js @@ -1,3 +1,5 @@ -module.exports = async function findGroupByOrganization({ organizationId, groupRepository }) { +const findGroupsByOrganization = async function ({ organizationId, groupRepository }) { return groupRepository.findByOrganizationId({ organizationId }); }; + +export { findGroupsByOrganization }; diff --git a/api/lib/domain/usecases/find-latest-ongoing-user-campaign-participations.js b/api/lib/domain/usecases/find-latest-ongoing-user-campaign-participations.js index 8d5ce469c1d..94b832b1f3f 100644 --- a/api/lib/domain/usecases/find-latest-ongoing-user-campaign-participations.js +++ b/api/lib/domain/usecases/find-latest-ongoing-user-campaign-participations.js @@ -1,6 +1,5 @@ -module.exports = async function findLatestOngoingUserCampaignParticipations({ - userId, - campaignParticipationRepository, -}) { +const findLatestOngoingUserCampaignParticipations = async function ({ userId, campaignParticipationRepository }) { return campaignParticipationRepository.findLatestOngoingByUserId(userId); }; + +export { findLatestOngoingUserCampaignParticipations }; diff --git a/api/lib/domain/usecases/find-organization-places-lot.js b/api/lib/domain/usecases/find-organization-places-lot.js index 4ef18f0105a..f1bb2bc1da1 100644 --- a/api/lib/domain/usecases/find-organization-places-lot.js +++ b/api/lib/domain/usecases/find-organization-places-lot.js @@ -1,3 +1,5 @@ -module.exports = async function findOrganizationPlacesLot({ organizationId, organizationPlacesLotRepository }) { +const findOrganizationPlacesLot = async function ({ organizationId, organizationPlacesLotRepository }) { return organizationPlacesLotRepository.findByOrganizationId(organizationId); }; + +export { findOrganizationPlacesLot }; diff --git a/api/lib/domain/usecases/find-organization-target-profile-summaries-for-admin.js b/api/lib/domain/usecases/find-organization-target-profile-summaries-for-admin.js index ebb14d21a0d..d77ae3bd050 100644 --- a/api/lib/domain/usecases/find-organization-target-profile-summaries-for-admin.js +++ b/api/lib/domain/usecases/find-organization-target-profile-summaries-for-admin.js @@ -1,6 +1,8 @@ -module.exports = function findOrganizationTargetProfileSummariesForAdmin({ +const findOrganizationTargetProfileSummariesForAdmin = function ({ organizationId, targetProfileSummaryForAdminRepository, }) { return targetProfileSummaryForAdminRepository.findByOrganization({ organizationId }); }; + +export { findOrganizationTargetProfileSummariesForAdmin }; diff --git a/api/lib/domain/usecases/find-paginated-campaign-managements.js b/api/lib/domain/usecases/find-paginated-campaign-managements.js index 52326381623..8e0ccf955e7 100644 --- a/api/lib/domain/usecases/find-paginated-campaign-managements.js +++ b/api/lib/domain/usecases/find-paginated-campaign-managements.js @@ -1,3 +1,5 @@ -module.exports = function findPaginatedCampaignManagements({ organizationId, page, campaignManagementRepository }) { +const findPaginatedCampaignManagements = function ({ organizationId, page, campaignManagementRepository }) { return campaignManagementRepository.findPaginatedCampaignManagements({ organizationId, page }); }; + +export { findPaginatedCampaignManagements }; diff --git a/api/lib/domain/usecases/find-paginated-campaign-participants-activities.js b/api/lib/domain/usecases/find-paginated-campaign-participants-activities.js index 95b8ad03cbf..a1ce65a323b 100644 --- a/api/lib/domain/usecases/find-paginated-campaign-participants-activities.js +++ b/api/lib/domain/usecases/find-paginated-campaign-participants-activities.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function findPaginatedCampaignParticipantsActivities({ +const findPaginatedCampaignParticipantsActivities = async function ({ userId, campaignId, page, @@ -13,6 +13,8 @@ module.exports = async function findPaginatedCampaignParticipantsActivities({ return campaignParticipantActivityRepository.findPaginatedByCampaignId({ page, campaignId, filters }); }; +export { findPaginatedCampaignParticipantsActivities }; + async function _checkUserAccessToCampaign(campaignId, userId, campaignRepository) { const hasAccess = await campaignRepository.checkIfUserOrganizationHasAccessToCampaign(campaignId, userId); if (!hasAccess) { diff --git a/api/lib/domain/usecases/find-paginated-certification-center-session-summaries.js b/api/lib/domain/usecases/find-paginated-certification-center-session-summaries.js index fe19999cf20..da14a0b036d 100644 --- a/api/lib/domain/usecases/find-paginated-certification-center-session-summaries.js +++ b/api/lib/domain/usecases/find-paginated-certification-center-session-summaries.js @@ -1,6 +1,6 @@ -const { ForbiddenAccess } = require('../../domain/errors.js'); +import { ForbiddenAccess } from '../../domain/errors.js'; -module.exports = async function findPaginatedCertificationCenterSessionSummaries({ +const findPaginatedCertificationCenterSessionSummaries = async function ({ userId, certificationCenterId, page, @@ -14,3 +14,5 @@ module.exports = async function findPaginatedCertificationCenterSessionSummaries return sessionSummaryRepository.findPaginatedByCertificationCenterId({ certificationCenterId, page }); }; + +export { findPaginatedCertificationCenterSessionSummaries }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-certification-centers.js b/api/lib/domain/usecases/find-paginated-filtered-certification-centers.js index b4fad00a8c9..9c52f45cdb0 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-certification-centers.js +++ b/api/lib/domain/usecases/find-paginated-filtered-certification-centers.js @@ -1,3 +1,5 @@ -module.exports = function findPaginatedFilteredCertificationCenters({ filter, page, certificationCenterRepository }) { +const findPaginatedFilteredCertificationCenters = function ({ filter, page, certificationCenterRepository }) { return certificationCenterRepository.findPaginatedFiltered({ filter, page }); }; + +export { findPaginatedFilteredCertificationCenters }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-organization-campaigns.js b/api/lib/domain/usecases/find-paginated-filtered-organization-campaigns.js index cef104795f2..2a2da841f1e 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-organization-campaigns.js +++ b/api/lib/domain/usecases/find-paginated-filtered-organization-campaigns.js @@ -1,4 +1,4 @@ -module.exports = function findPaginatedFilteredOrganizationCampaigns({ +const findPaginatedFilteredOrganizationCampaigns = function ({ userId, organizationId, filter, @@ -7,3 +7,5 @@ module.exports = function findPaginatedFilteredOrganizationCampaigns({ }) { return campaignReportRepository.findPaginatedFilteredByOrganizationId({ organizationId, filter, page, userId }); }; + +export { findPaginatedFilteredOrganizationCampaigns }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-organization-memberships.js b/api/lib/domain/usecases/find-paginated-filtered-organization-memberships.js index ab224013a8f..e97a540b72f 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-organization-memberships.js +++ b/api/lib/domain/usecases/find-paginated-filtered-organization-memberships.js @@ -1,8 +1,5 @@ -module.exports = function findPaginatedFilteredOrganizationMemberships({ - organizationId, - filter, - page, - membershipRepository, -}) { +const findPaginatedFilteredOrganizationMemberships = function ({ organizationId, filter, page, membershipRepository }) { return membershipRepository.findPaginatedFiltered({ organizationId, filter, page }); }; + +export { findPaginatedFilteredOrganizationMemberships }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-organizations.js b/api/lib/domain/usecases/find-paginated-filtered-organizations.js index 1969c594fbf..ceccb3e4cbc 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-organizations.js +++ b/api/lib/domain/usecases/find-paginated-filtered-organizations.js @@ -1,3 +1,5 @@ -module.exports = function findPaginatedFilteredOrganizations({ filter, page, organizationRepository }) { +const findPaginatedFilteredOrganizations = function ({ filter, page, organizationRepository }) { return organizationRepository.findPaginatedFiltered({ filter, page }); }; + +export { findPaginatedFilteredOrganizations }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-sco-participants.js b/api/lib/domain/usecases/find-paginated-filtered-sco-participants.js index 9b77fbd3463..d23cdc7fd62 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-sco-participants.js +++ b/api/lib/domain/usecases/find-paginated-filtered-sco-participants.js @@ -1,4 +1,4 @@ -module.exports = function findPaginatedFilteredScoParticipants({ +const findPaginatedFilteredScoParticipants = function ({ organizationId, filter, page, @@ -12,3 +12,5 @@ module.exports = function findPaginatedFilteredScoParticipants({ sort, }); }; + +export { findPaginatedFilteredScoParticipants }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-sup-participants.js b/api/lib/domain/usecases/find-paginated-filtered-sup-participants.js index 12816db1ed3..17d4081cc6c 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-sup-participants.js +++ b/api/lib/domain/usecases/find-paginated-filtered-sup-participants.js @@ -1,4 +1,4 @@ -module.exports = function findPaginatedFilteredSupParticipants({ +const findPaginatedFilteredSupParticipants = function ({ organizationId, filter, page, @@ -12,3 +12,5 @@ module.exports = function findPaginatedFilteredSupParticipants({ sort, }); }; + +export { findPaginatedFilteredSupParticipants }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-target-profile-organizations.js b/api/lib/domain/usecases/find-paginated-filtered-target-profile-organizations.js index 7f34eb61914..f2e42e9766e 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-target-profile-organizations.js +++ b/api/lib/domain/usecases/find-paginated-filtered-target-profile-organizations.js @@ -1,3 +1,5 @@ -module.exports = function findTargetProfileOrganizations({ targetProfileId, filter, page, organizationRepository }) { +const findTargetProfileOrganizations = function ({ targetProfileId, filter, page, organizationRepository }) { return organizationRepository.findPaginatedFilteredByTargetProfile({ targetProfileId, filter, page }); }; + +export { findTargetProfileOrganizations }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-target-profile-summaries-for-admin.js b/api/lib/domain/usecases/find-paginated-filtered-target-profile-summaries-for-admin.js index e74382420bd..afefe3ac13e 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-target-profile-summaries-for-admin.js +++ b/api/lib/domain/usecases/find-paginated-filtered-target-profile-summaries-for-admin.js @@ -1,7 +1,9 @@ -module.exports = function findPaginatedFilteredTargetProfileSummariesForAdmin({ +const findPaginatedFilteredTargetProfileSummariesForAdmin = function ({ filter, page, targetProfileSummaryForAdminRepository, }) { return targetProfileSummaryForAdminRepository.findPaginatedFiltered({ filter, page }); }; + +export { findPaginatedFilteredTargetProfileSummariesForAdmin }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-tutorials.js b/api/lib/domain/usecases/find-paginated-filtered-tutorials.js index 1a8ad72b84c..ef865eb4e7b 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-tutorials.js +++ b/api/lib/domain/usecases/find-paginated-filtered-tutorials.js @@ -1,6 +1,6 @@ -const Tutorial = require('../models/Tutorial.js'); +import { Tutorial } from '../models/Tutorial.js'; -module.exports = async function findPaginatedFilteredTutorials({ userId, filters, page, locale, tutorialRepository }) { +const findPaginatedFilteredTutorials = async function ({ userId, filters, page, locale, tutorialRepository }) { if (filters?.type === Tutorial.TYPES.RECOMMENDED) { const { results: tutorials, pagination } = await tutorialRepository.findPaginatedFilteredRecommendedByUserId({ userId, @@ -18,3 +18,5 @@ module.exports = async function findPaginatedFilteredTutorials({ userId, filters }); return { tutorials, meta: { pagination } }; }; + +export { findPaginatedFilteredTutorials }; diff --git a/api/lib/domain/usecases/find-paginated-filtered-users.js b/api/lib/domain/usecases/find-paginated-filtered-users.js index bfe431549cd..c680bab101a 100644 --- a/api/lib/domain/usecases/find-paginated-filtered-users.js +++ b/api/lib/domain/usecases/find-paginated-filtered-users.js @@ -1,3 +1,5 @@ -module.exports = function findPaginatedFilteredUsers({ filter, page, userRepository }) { +const findPaginatedFilteredUsers = function ({ filter, page, userRepository }) { return userRepository.findPaginatedFiltered({ filter, page }); }; + +export { findPaginatedFilteredUsers }; diff --git a/api/lib/domain/usecases/find-paginated-participations-for-campaign-management.js b/api/lib/domain/usecases/find-paginated-participations-for-campaign-management.js index f28c784f2fb..29621fcc4e0 100644 --- a/api/lib/domain/usecases/find-paginated-participations-for-campaign-management.js +++ b/api/lib/domain/usecases/find-paginated-participations-for-campaign-management.js @@ -1,4 +1,4 @@ -module.exports = function findPaginatedParticipationsForCampaignManagement({ +const findPaginatedParticipationsForCampaignManagement = function ({ campaignId, page, participationsForCampaignManagementRepository, @@ -8,3 +8,5 @@ module.exports = function findPaginatedParticipationsForCampaignManagement({ page, }); }; + +export { findPaginatedParticipationsForCampaignManagement }; diff --git a/api/lib/domain/usecases/find-paginated-target-profile-training-summaries.js b/api/lib/domain/usecases/find-paginated-target-profile-training-summaries.js index 10da7f93aed..5842b592640 100644 --- a/api/lib/domain/usecases/find-paginated-target-profile-training-summaries.js +++ b/api/lib/domain/usecases/find-paginated-target-profile-training-summaries.js @@ -1,4 +1,4 @@ -module.exports = async function findPaginatedTargetProfileTrainings({ targetProfileId, page, trainingRepository }) { +const findPaginatedTargetProfileTrainingSummaries = async function ({ targetProfileId, page, trainingRepository }) { const { trainings, pagination } = await trainingRepository.findPaginatedSummariesByTargetProfileId({ targetProfileId, page, @@ -9,3 +9,5 @@ module.exports = async function findPaginatedTargetProfileTrainings({ targetProf meta: { pagination }, }; }; + +export { findPaginatedTargetProfileTrainingSummaries }; diff --git a/api/lib/domain/usecases/find-paginated-training-summaries.js b/api/lib/domain/usecases/find-paginated-training-summaries.js index f7dc69e31ac..cce558abec6 100644 --- a/api/lib/domain/usecases/find-paginated-training-summaries.js +++ b/api/lib/domain/usecases/find-paginated-training-summaries.js @@ -1,4 +1,4 @@ -module.exports = async function findPaginatedTrainingSummaries({ filter, page, trainingRepository }) { +const findPaginatedTrainingSummaries = async function ({ filter, page, trainingRepository }) { const { trainings, pagination } = await trainingRepository.findPaginatedSummaries({ filter, page }); return { @@ -6,3 +6,5 @@ module.exports = async function findPaginatedTrainingSummaries({ filter, page, t meta: { pagination }, }; }; + +export { findPaginatedTrainingSummaries }; diff --git a/api/lib/domain/usecases/find-paginated-user-recommended-trainings.js b/api/lib/domain/usecases/find-paginated-user-recommended-trainings.js index cae6477a924..80b2b6316d4 100644 --- a/api/lib/domain/usecases/find-paginated-user-recommended-trainings.js +++ b/api/lib/domain/usecases/find-paginated-user-recommended-trainings.js @@ -12,4 +12,4 @@ async function findPaginatedUserRecommendedTrainings({ userId, locale, page, tra }; } -module.exports = findPaginatedUserRecommendedTrainings; +export { findPaginatedUserRecommendedTrainings }; diff --git a/api/lib/domain/usecases/find-pending-certification-center-invitations.js b/api/lib/domain/usecases/find-pending-certification-center-invitations.js index f1d925f4405..5d678a1e375 100644 --- a/api/lib/domain/usecases/find-pending-certification-center-invitations.js +++ b/api/lib/domain/usecases/find-pending-certification-center-invitations.js @@ -1,6 +1,8 @@ -module.exports = async function findPendingCertificationCenterInvitations({ +const findPendingCertificationCenterInvitations = async function ({ certificationCenterId, certificationCenterInvitationRepository, }) { return await certificationCenterInvitationRepository.findPendingByCertificationCenterId({ certificationCenterId }); }; + +export { findPendingCertificationCenterInvitations }; diff --git a/api/lib/domain/usecases/find-pending-organization-invitations.js b/api/lib/domain/usecases/find-pending-organization-invitations.js index bf06aa395ce..330ce8654f1 100644 --- a/api/lib/domain/usecases/find-pending-organization-invitations.js +++ b/api/lib/domain/usecases/find-pending-organization-invitations.js @@ -1,3 +1,5 @@ -module.exports = function findPendingOrganizationInvitations({ organizationId, organizationInvitationRepository }) { +const findPendingOrganizationInvitations = function ({ organizationId, organizationInvitationRepository }) { return organizationInvitationRepository.findPendingByOrganizationId({ organizationId }); }; + +export { findPendingOrganizationInvitations }; diff --git a/api/lib/domain/usecases/find-students-for-enrolment.js b/api/lib/domain/usecases/find-students-for-enrolment.js index e39031f4b58..1bfdaf67ff2 100644 --- a/api/lib/domain/usecases/find-students-for-enrolment.js +++ b/api/lib/domain/usecases/find-students-for-enrolment.js @@ -1,7 +1,7 @@ -const { NotFoundError } = require('../errors.js'); -const StudentForEnrolment = require('../read-models/StudentForEnrolment.js'); +import { NotFoundError } from '../errors.js'; +import { StudentForEnrolment } from '../read-models/StudentForEnrolment.js'; -module.exports = async function findStudentsForEnrolment({ +const findStudentsForEnrolment = async function ({ certificationCenterId, sessionId, page, @@ -32,6 +32,8 @@ module.exports = async function findStudentsForEnrolment({ } }; +export { findStudentsForEnrolment }; + function _buildStudentsForEnrolment({ students, certificationCandidates }) { return students.map((student) => StudentForEnrolment.fromStudentsAndCertificationCandidates({ student, certificationCandidates }) diff --git a/api/lib/domain/usecases/find-target-profile-summaries-for-training.js b/api/lib/domain/usecases/find-target-profile-summaries-for-training.js index 064487d3e92..a6856684e22 100644 --- a/api/lib/domain/usecases/find-target-profile-summaries-for-training.js +++ b/api/lib/domain/usecases/find-target-profile-summaries-for-training.js @@ -1,6 +1,5 @@ -module.exports = function findTargetProfileSummariesForTraining({ - trainingId, - targetProfileSummaryForAdminRepository, -}) { +const findTargetProfileSummariesForTraining = function ({ trainingId, targetProfileSummaryForAdminRepository }) { return targetProfileSummaryForAdminRepository.findByTraining({ trainingId }); }; + +export { findTargetProfileSummariesForTraining }; diff --git a/api/lib/domain/usecases/find-tutorials.js b/api/lib/domain/usecases/find-tutorials.js index 2b0c9776c67..b172668fb39 100644 --- a/api/lib/domain/usecases/find-tutorials.js +++ b/api/lib/domain/usecases/find-tutorials.js @@ -1,9 +1,9 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); -const Scorecard = require('../models/Scorecard.js'); -const KnowledgeElement = require('../models/KnowledgeElement.js'); -const _ = require('lodash'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; +import { Scorecard } from '../models/Scorecard.js'; +import { KnowledgeElement } from '../models/KnowledgeElement.js'; +import _ from 'lodash'; -module.exports = async function findTutorials({ +const findTutorials = async function ({ authenticatedUserId, scorecardId, knowledgeElementRepository, @@ -43,6 +43,8 @@ module.exports = async function findTutorials({ return _.orderBy(_.flatten(tutorialsWithTubesList), 'tubeName'); }; +export { findTutorials }; + async function _getTutorialsWithTubesList(easiestSkills, tubes, tutorialRepository, userId, locale) { return await Promise.all( _.map(easiestSkills, async (skill) => { diff --git a/api/lib/domain/usecases/find-user-authentication-methods.js b/api/lib/domain/usecases/find-user-authentication-methods.js index 5acef5066e7..8b4c8e22007 100644 --- a/api/lib/domain/usecases/find-user-authentication-methods.js +++ b/api/lib/domain/usecases/find-user-authentication-methods.js @@ -1,3 +1,5 @@ -module.exports = function findUserAuthenticationMethods({ userId, authenticationMethodRepository }) { +const findUserAuthenticationMethods = function ({ userId, authenticationMethodRepository }) { return authenticationMethodRepository.findByUserId({ userId }); }; + +export { findUserAuthenticationMethods }; diff --git a/api/lib/domain/usecases/find-user-campaign-participation-overviews.js b/api/lib/domain/usecases/find-user-campaign-participation-overviews.js index 75cf8d921cf..3faf16e3f54 100644 --- a/api/lib/domain/usecases/find-user-campaign-participation-overviews.js +++ b/api/lib/domain/usecases/find-user-campaign-participation-overviews.js @@ -1,4 +1,4 @@ -module.exports = async function findUserCampaignParticipationOverviews({ +const findUserCampaignParticipationOverviews = async function ({ userId, states, page, @@ -14,3 +14,5 @@ module.exports = async function findUserCampaignParticipationOverviews({ return campaignParticipationOverviews; }; + +export { findUserCampaignParticipationOverviews }; diff --git a/api/lib/domain/usecases/find-user-for-oidc-reconciliation.js b/api/lib/domain/usecases/find-user-for-oidc-reconciliation.js index c50073ed9a6..993644c9cb6 100644 --- a/api/lib/domain/usecases/find-user-for-oidc-reconciliation.js +++ b/api/lib/domain/usecases/find-user-for-oidc-reconciliation.js @@ -1,6 +1,6 @@ -const { AuthenticationKeyExpired, DifferentExternalIdentifierError } = require('../errors.js'); +import { AuthenticationKeyExpired, DifferentExternalIdentifierError } from '../errors.js'; -module.exports = async function findUserForOidcReconciliation({ +const findUserForOidcReconciliation = async function ({ authenticationKey, email, password, @@ -46,3 +46,5 @@ module.exports = async function findUserForOidcReconciliation({ authenticationMethods, }; }; + +export { findUserForOidcReconciliation }; diff --git a/api/lib/domain/usecases/find-user-organizations-for-admin.js b/api/lib/domain/usecases/find-user-organizations-for-admin.js index 66244ac5658..17325319fb4 100644 --- a/api/lib/domain/usecases/find-user-organizations-for-admin.js +++ b/api/lib/domain/usecases/find-user-organizations-for-admin.js @@ -1,3 +1,5 @@ -module.exports = async function findUserOrganizationsForAdmin({ userId, userOrganizationsForAdminRepository }) { +const findUserOrganizationsForAdmin = async function ({ userId, userOrganizationsForAdminRepository }) { return userOrganizationsForAdminRepository.findByUserId(userId); }; + +export { findUserOrganizationsForAdmin }; diff --git a/api/lib/domain/usecases/find-user-private-certificates.js b/api/lib/domain/usecases/find-user-private-certificates.js index ade6582b603..4008ed480aa 100644 --- a/api/lib/domain/usecases/find-user-private-certificates.js +++ b/api/lib/domain/usecases/find-user-private-certificates.js @@ -1,3 +1,5 @@ -module.exports = async function findUserPrivateCertificates({ userId, certificateRepository }) { +const findUserPrivateCertificates = async function ({ userId, certificateRepository }) { return certificateRepository.findPrivateCertificatesByUserId({ userId }); }; + +export { findUserPrivateCertificates }; diff --git a/api/lib/domain/usecases/flag-session-results-as-sent-to-prescriber.js b/api/lib/domain/usecases/flag-session-results-as-sent-to-prescriber.js index a2a8bc34698..dc5098f7371 100644 --- a/api/lib/domain/usecases/flag-session-results-as-sent-to-prescriber.js +++ b/api/lib/domain/usecases/flag-session-results-as-sent-to-prescriber.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../../domain/errors.js'); +import { NotFoundError } from '../../domain/errors.js'; -module.exports = async function flagSessionResultsAsSentToPrescriber({ sessionId, sessionRepository }) { +const flagSessionResultsAsSentToPrescriber = async function ({ sessionId, sessionRepository }) { const integerSessionId = parseInt(sessionId); const NOT_FOUND_SESSION = `La session ${sessionId} n'existe pas ou son accès est restreint lors du marquage d'envoi des résultats au prescripteur`; @@ -20,3 +20,5 @@ module.exports = async function flagSessionResultsAsSentToPrescriber({ sessionId return { resultsFlaggedAsSent: false, session }; }; + +export { flagSessionResultsAsSentToPrescriber }; diff --git a/api/lib/domain/usecases/generate-username-with-temporary-password.js b/api/lib/domain/usecases/generate-username-with-temporary-password.js index 2199977a34c..f298b15196c 100644 --- a/api/lib/domain/usecases/generate-username-with-temporary-password.js +++ b/api/lib/domain/usecases/generate-username-with-temporary-password.js @@ -1,7 +1,10 @@ -const isEmpty = require('lodash/isEmpty'); -const { UserNotAuthorizedToGenerateUsernamePasswordError } = require('../errors.js'); +import lodash from 'lodash'; -module.exports = async function generateUsernameWithTemporaryPassword({ +const { isEmpty } = lodash; + +import { UserNotAuthorizedToGenerateUsernamePasswordError } from '../errors.js'; + +const generateUsernameWithTemporaryPassword = async function ({ organizationLearnerId, organizationId, passwordGenerator, @@ -47,6 +50,8 @@ module.exports = async function generateUsernameWithTemporaryPassword({ } }; +export { generateUsernameWithTemporaryPassword }; + function _checkIfStudentHasAccessToOrganization(organizationLearner, organizationId) { if (organizationLearner.organizationId !== organizationId) { throw new UserNotAuthorizedToGenerateUsernamePasswordError( diff --git a/api/lib/domain/usecases/generate-username.js b/api/lib/domain/usecases/generate-username.js index 7ef593132d9..232598959a3 100644 --- a/api/lib/domain/usecases/generate-username.js +++ b/api/lib/domain/usecases/generate-username.js @@ -1,12 +1,15 @@ -const { +import { CampaignCodeError, OrganizationLearnerNotFound, OrganizationLearnerAlreadyLinkedToUserError, -} = require('../errors.js'); -const { STUDENT_RECONCILIATION_ERRORS } = require('../constants.js'); -const { find, get } = require('lodash'); +} from '../errors.js'; -module.exports = async function generateUsername({ +import { STUDENT_RECONCILIATION_ERRORS } from '../constants.js'; +import lodash from 'lodash'; + +const { find, get } = lodash; + +const generateUsername = async function ({ studentInformation, campaignCode, campaignRepository, @@ -48,6 +51,8 @@ module.exports = async function generateUsername({ return userReconciliationService.createUsernameByUser({ user: studentInformation, userRepository }); }; +export { generateUsername }; + async function findMatchedOrganizationLearnerForGivenOrganizationIdAndStudentInfo({ organizationId, studentInformation: { firstName, lastName, birthdate }, diff --git a/api/lib/domain/usecases/get-admin-member-details.js b/api/lib/domain/usecases/get-admin-member-details.js index 68efc3eb651..3c176daf677 100644 --- a/api/lib/domain/usecases/get-admin-member-details.js +++ b/api/lib/domain/usecases/get-admin-member-details.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../errors.js'); +import { NotFoundError } from '../errors.js'; -module.exports = async function getAdminMemberDetails({ adminMemberRepository, userId }) { +const getAdminMemberDetails = async function ({ adminMemberRepository, userId }) { const adminMemberDetail = await adminMemberRepository.get({ userId }); if (!adminMemberDetail) { @@ -9,3 +9,5 @@ module.exports = async function getAdminMemberDetails({ adminMemberRepository, u return adminMemberDetail; }; + +export { getAdminMemberDetails }; diff --git a/api/lib/domain/usecases/get-admin-members.js b/api/lib/domain/usecases/get-admin-members.js index f5c07fc5c33..4f22f507e80 100644 --- a/api/lib/domain/usecases/get-admin-members.js +++ b/api/lib/domain/usecases/get-admin-members.js @@ -1,3 +1,5 @@ -module.exports = async function getAdminMembers({ adminMemberRepository }) { +const getAdminMembers = async function ({ adminMemberRepository }) { return adminMemberRepository.findAll(); }; + +export { getAdminMembers }; diff --git a/api/lib/domain/usecases/get-answer.js b/api/lib/domain/usecases/get-answer.js index e63ae1d0d10..f54b571591f 100644 --- a/api/lib/domain/usecases/get-answer.js +++ b/api/lib/domain/usecases/get-answer.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../errors.js'); +import { NotFoundError } from '../errors.js'; -module.exports = async function getAnswer({ answerId, userId, answerRepository, assessmentRepository } = {}) { +const getAnswer = async function ({ answerId, userId, answerRepository, assessmentRepository } = {}) { const integerAnswerId = parseInt(answerId); if (!Number.isFinite(integerAnswerId)) { throw new NotFoundError(`Not found answer for ID ${answerId}`); @@ -12,3 +12,5 @@ module.exports = async function getAnswer({ answerId, userId, answerRepository, } return answer; }; + +export { getAnswer }; diff --git a/api/lib/domain/usecases/get-assessment.js b/api/lib/domain/usecases/get-assessment.js index 7c668f8d98b..74a3c8ca6c2 100644 --- a/api/lib/domain/usecases/get-assessment.js +++ b/api/lib/domain/usecases/get-assessment.js @@ -1,6 +1,6 @@ -const Assessment = require('../models/Assessment.js'); +import { Assessment } from '../models/Assessment.js'; -module.exports = async function getAssessment({ +const getAssessment = async function ({ assessmentId, locale, assessmentRepository, @@ -26,6 +26,8 @@ module.exports = async function getAssessment({ return assessment; }; +export { getAssessment }; + function _fetchAssessmentTitle({ assessment, locale, competenceRepository, courseRepository, campaignRepository }) { switch (assessment.type) { case Assessment.types.CERTIFICATION: { diff --git a/api/lib/domain/usecases/get-attendance-sheet.js b/api/lib/domain/usecases/get-attendance-sheet.js index 72ed562568c..32c31a83cf1 100644 --- a/api/lib/domain/usecases/get-attendance-sheet.js +++ b/api/lib/domain/usecases/get-attendance-sheet.js @@ -1,14 +1,18 @@ -const _ = require('lodash'); -const moment = require('moment'); -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); -const { +import _ from 'lodash'; +import moment from 'moment'; +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; + +import { EXTRA_EMPTY_CANDIDATE_ROWS, NON_SCO_ATTENDANCE_SHEET_CANDIDATE_TEMPLATE_VALUES, SCO_ATTENDANCE_SHEET_CANDIDATE_TEMPLATE_VALUES, ATTENDANCE_SHEET_SESSION_TEMPLATE_VALUES, -} = require('./../../infrastructure/files/attendance-sheet/attendance-sheet-placeholders.js'); +} from './../../infrastructure/files/attendance-sheet/attendance-sheet-placeholders.js'; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); -module.exports = async function getAttendanceSheet({ +const getAttendanceSheet = async function ({ userId, sessionId, sessionRepository, @@ -40,6 +44,8 @@ module.exports = async function getAttendanceSheet({ }); }; +export { getAttendanceSheet }; + function _updateXmlWithSession(stringifiedXml, session, sessionXmlService) { const sessionData = _.transform(session, _transformSessionIntoAttendanceSheetSessionData); const updatedStringifiedXml = sessionXmlService.getUpdatedXmlWithSessionData({ diff --git a/api/lib/domain/usecases/get-available-target-profiles-for-organization.js b/api/lib/domain/usecases/get-available-target-profiles-for-organization.js index 1f84f8a7112..e311de2e76e 100644 --- a/api/lib/domain/usecases/get-available-target-profiles-for-organization.js +++ b/api/lib/domain/usecases/get-available-target-profiles-for-organization.js @@ -1,6 +1,5 @@ -module.exports = function getAvailableTargetProfilesForOrganization({ - organizationId, - TargetProfileForSpecifierRepository, -}) { +const getAvailableTargetProfilesForOrganization = function ({ organizationId, TargetProfileForSpecifierRepository }) { return TargetProfileForSpecifierRepository.availableForOrganization(organizationId); }; + +export { getAvailableTargetProfilesForOrganization }; diff --git a/api/lib/domain/usecases/get-campaign-assessment-participation-result.js b/api/lib/domain/usecases/get-campaign-assessment-participation-result.js index 1aaaf23807f..38ef7eadf83 100644 --- a/api/lib/domain/usecases/get-campaign-assessment-participation-result.js +++ b/api/lib/domain/usecases/get-campaign-assessment-participation-result.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function getCampaignAssessmentParticipationResult({ +const getCampaignAssessmentParticipationResult = async function ({ userId, campaignId, campaignParticipationId, @@ -18,3 +18,5 @@ module.exports = async function getCampaignAssessmentParticipationResult({ locale, }); }; + +export { getCampaignAssessmentParticipationResult }; diff --git a/api/lib/domain/usecases/get-campaign-assessment-participation.js b/api/lib/domain/usecases/get-campaign-assessment-participation.js index 09941bdb317..9893aebe783 100644 --- a/api/lib/domain/usecases/get-campaign-assessment-participation.js +++ b/api/lib/domain/usecases/get-campaign-assessment-participation.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function getCampaignAssessmentParticipation({ +const getCampaignAssessmentParticipation = async function ({ userId, campaignId, campaignParticipationId, @@ -35,3 +35,5 @@ module.exports = async function getCampaignAssessmentParticipation({ return campaignAssessmentParticipation; }; + +export { getCampaignAssessmentParticipation }; diff --git a/api/lib/domain/usecases/get-campaign-by-code.js b/api/lib/domain/usecases/get-campaign-by-code.js index a8488a654ef..d3edb5e2a87 100644 --- a/api/lib/domain/usecases/get-campaign-by-code.js +++ b/api/lib/domain/usecases/get-campaign-by-code.js @@ -1,3 +1,5 @@ -module.exports = function getCampaignByCode({ code, campaignToJoinRepository }) { +const getCampaignByCode = function ({ code, campaignToJoinRepository }) { return campaignToJoinRepository.getByCode(code); }; + +export { getCampaignByCode }; diff --git a/api/lib/domain/usecases/get-campaign-details-management.js b/api/lib/domain/usecases/get-campaign-details-management.js index 3c577be000d..bfe6e24f199 100644 --- a/api/lib/domain/usecases/get-campaign-details-management.js +++ b/api/lib/domain/usecases/get-campaign-details-management.js @@ -1,3 +1,5 @@ -module.exports = async function getCampaignManagement({ campaignId, campaignManagementRepository }) { +const getCampaignManagement = async function ({ campaignId, campaignManagementRepository }) { return campaignManagementRepository.get(campaignId); }; + +export { getCampaignManagement }; diff --git a/api/lib/domain/usecases/get-campaign-participations-activity-by-day.js b/api/lib/domain/usecases/get-campaign-participations-activity-by-day.js index 75848cbc6da..6e26c963b13 100644 --- a/api/lib/domain/usecases/get-campaign-participations-activity-by-day.js +++ b/api/lib/domain/usecases/get-campaign-participations-activity-by-day.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function getCampaignParticipationsActivityByDay({ +const getCampaignParticipationsActivityByDay = async function ({ userId, campaignId, campaignRepository, @@ -12,3 +12,5 @@ module.exports = async function getCampaignParticipationsActivityByDay({ return campaignParticipationsStatsRepository.getParticipationsActivityByDate(campaignId); }; + +export { getCampaignParticipationsActivityByDay }; diff --git a/api/lib/domain/usecases/get-campaign-participations-counts-by-stage.js b/api/lib/domain/usecases/get-campaign-participations-counts-by-stage.js index 8111c4602bf..4e4d461234d 100644 --- a/api/lib/domain/usecases/get-campaign-participations-counts-by-stage.js +++ b/api/lib/domain/usecases/get-campaign-participations-counts-by-stage.js @@ -1,7 +1,7 @@ -const stageCollectionRepository = require('../../infrastructure/repositories/user-campaign-results/stage-collection-repository.js'); -const { UserNotAuthorizedToAccessEntityError, NoStagesForCampaign } = require('../errors.js'); +import * as stageCollectionRepository from '../../infrastructure/repositories/user-campaign-results/stage-collection-repository.js'; +import { UserNotAuthorizedToAccessEntityError, NoStagesForCampaign } from '../errors.js'; -module.exports = async function getCampaignParticipationsCountByStage({ +const getCampaignParticipationsCountByStage = async function ({ userId, campaignId, campaignRepository, @@ -40,3 +40,5 @@ module.exports = async function getCampaignParticipationsCountByStage({ return participantsByStage; }; + +export { getCampaignParticipationsCountByStage }; diff --git a/api/lib/domain/usecases/get-campaign-participations-counts-by-status.js b/api/lib/domain/usecases/get-campaign-participations-counts-by-status.js index f77c6ed3b6e..008464661bb 100644 --- a/api/lib/domain/usecases/get-campaign-participations-counts-by-status.js +++ b/api/lib/domain/usecases/get-campaign-participations-counts-by-status.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function getCampaignParticipationsCountsByStatus({ +const getCampaignParticipationsCountsByStatus = async function ({ userId, campaignId, campaignRepository, @@ -14,3 +14,5 @@ module.exports = async function getCampaignParticipationsCountsByStatus({ return campaignParticipationRepository.countParticipationsByStatus(campaignId, campaign.type); }; + +export { getCampaignParticipationsCountsByStatus }; diff --git a/api/lib/domain/usecases/get-campaign-profile.js b/api/lib/domain/usecases/get-campaign-profile.js index a71b58fccd8..fa61855a2d2 100644 --- a/api/lib/domain/usecases/get-campaign-profile.js +++ b/api/lib/domain/usecases/get-campaign-profile.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function getCampaignProfile({ +const getCampaignProfile = async function ({ userId, campaignId, campaignParticipationId, @@ -14,3 +14,5 @@ module.exports = async function getCampaignProfile({ return campaignProfileRepository.findProfile({ campaignId, campaignParticipationId, locale }); }; + +export { getCampaignProfile }; diff --git a/api/lib/domain/usecases/get-campaign.js b/api/lib/domain/usecases/get-campaign.js index 86939c5e309..9f9e2bd4190 100644 --- a/api/lib/domain/usecases/get-campaign.js +++ b/api/lib/domain/usecases/get-campaign.js @@ -1,7 +1,7 @@ -const { NotFoundError, UserNotAuthorizedToAccessEntityError } = require('../../domain/errors.js'); -const stageCollectionRepository = require('../../infrastructure/repositories/user-campaign-results/stage-collection-repository.js'); +import { NotFoundError, UserNotAuthorizedToAccessEntityError } from '../../domain/errors.js'; +import * as stageCollectionRepository from '../../infrastructure/repositories/user-campaign-results/stage-collection-repository.js'; -module.exports = async function getCampaign({ +const getCampaign = async function ({ campaignId, userId, badgeRepository, @@ -38,3 +38,5 @@ module.exports = async function getCampaign({ } return campaignReport; }; + +export { getCampaign }; diff --git a/api/lib/domain/usecases/get-candidate-import-sheet-data.js b/api/lib/domain/usecases/get-candidate-import-sheet-data.js index b6337e5da61..31b426cd053 100644 --- a/api/lib/domain/usecases/get-candidate-import-sheet-data.js +++ b/api/lib/domain/usecases/get-candidate-import-sheet-data.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function getCandidateImportSheetData({ +const getCandidateImportSheetData = async function ({ userId, sessionId, sessionRepository, @@ -20,3 +20,5 @@ module.exports = async function getCandidateImportSheetData({ isScoCertificationCenter: certificationCenter.isSco, }; }; + +export { getCandidateImportSheetData }; diff --git a/api/lib/domain/usecases/get-certification-candidate-subscription.js b/api/lib/domain/usecases/get-certification-candidate-subscription.js index 7b03ac00af5..908f177a9eb 100644 --- a/api/lib/domain/usecases/get-certification-candidate-subscription.js +++ b/api/lib/domain/usecases/get-certification-candidate-subscription.js @@ -1,7 +1,7 @@ -const CertificationCandidateSubscription = require('../read-models/CertificationCandidateSubscription.js'); -const _ = require('lodash'); +import { CertificationCandidateSubscription } from '../read-models/CertificationCandidateSubscription.js'; +import _ from 'lodash'; -module.exports = async function getCertificationCandidateSubscription({ +const getCertificationCandidateSubscription = async function ({ certificationCandidateId, certificationBadgesService, certificationCandidateRepository, @@ -50,3 +50,5 @@ module.exports = async function getCertificationCandidateSubscription({ nonEligibleSubscriptions, }); }; + +export { getCertificationCandidateSubscription }; diff --git a/api/lib/domain/usecases/get-certification-candidate.js b/api/lib/domain/usecases/get-certification-candidate.js index 953214d74d1..da3cf7f1524 100644 --- a/api/lib/domain/usecases/get-certification-candidate.js +++ b/api/lib/domain/usecases/get-certification-candidate.js @@ -2,4 +2,4 @@ async function getCertificationCandidate({ userId, sessionId, certificationCandi return certificationCandidateRepository.getBySessionIdAndUserId({ userId, sessionId }); } -module.exports = getCertificationCandidate; +export { getCertificationCandidate }; diff --git a/api/lib/domain/usecases/get-certification-center-for-admin.js b/api/lib/domain/usecases/get-certification-center-for-admin.js index d37cfa25a34..55f152413c4 100644 --- a/api/lib/domain/usecases/get-certification-center-for-admin.js +++ b/api/lib/domain/usecases/get-certification-center-for-admin.js @@ -1,3 +1,5 @@ -module.exports = function getCertificationCenterForAdmin({ id, certificationCenterForAdminRepository }) { +const getCertificationCenterForAdmin = function ({ id, certificationCenterForAdminRepository }) { return certificationCenterForAdminRepository.get(id); }; + +export { getCertificationCenterForAdmin }; diff --git a/api/lib/domain/usecases/get-certification-center-invitation.js b/api/lib/domain/usecases/get-certification-center-invitation.js index 066965eb1b8..7431118e0d2 100644 --- a/api/lib/domain/usecases/get-certification-center-invitation.js +++ b/api/lib/domain/usecases/get-certification-center-invitation.js @@ -1,6 +1,6 @@ -const { CancelledInvitationError, AlreadyExistingInvitationError } = require('../errors.js'); +import { CancelledInvitationError, AlreadyExistingInvitationError } from '../errors.js'; -module.exports = async function getCertificationCenterInvitation({ +const getCertificationCenterInvitation = async function ({ certificationCenterInvitationId, certificationCenterInvitationCode, certificationCenterInvitationRepository, @@ -22,3 +22,5 @@ module.exports = async function getCertificationCenterInvitation({ return foundCertificationCenterInvitation; }; + +export { getCertificationCenterInvitation }; diff --git a/api/lib/domain/usecases/get-certification-center.js b/api/lib/domain/usecases/get-certification-center.js index d285ab8cc59..e8b7219d574 100644 --- a/api/lib/domain/usecases/get-certification-center.js +++ b/api/lib/domain/usecases/get-certification-center.js @@ -1,3 +1,5 @@ -module.exports = function getCertificationCenter({ id, certificationCenterRepository }) { +const getCertificationCenter = function ({ id, certificationCenterRepository }) { return certificationCenterRepository.get(id); }; + +export { getCertificationCenter }; diff --git a/api/lib/domain/usecases/get-certification-course.js b/api/lib/domain/usecases/get-certification-course.js index 1f7cee82a74..a721935eee4 100644 --- a/api/lib/domain/usecases/get-certification-course.js +++ b/api/lib/domain/usecases/get-certification-course.js @@ -1,3 +1,5 @@ -module.exports = async function getCertificationCourse({ certificationCourseId, certificationCourseRepository }) { +const getCertificationCourse = async function ({ certificationCourseId, certificationCourseRepository }) { return certificationCourseRepository.get(certificationCourseId); }; + +export { getCertificationCourse }; diff --git a/api/lib/domain/usecases/get-certification-details.js b/api/lib/domain/usecases/get-certification-details.js index 09af425b003..19c7fcf11f9 100644 --- a/api/lib/domain/usecases/get-certification-details.js +++ b/api/lib/domain/usecases/get-certification-details.js @@ -1,6 +1,6 @@ -const CertificationDetails = require('../read-models/CertificationDetails.js'); +import { CertificationDetails } from '../read-models/CertificationDetails.js'; -module.exports = async function getCertificationDetails({ +const getCertificationDetails = async function ({ certificationCourseId, competenceMarkRepository, certificationAssessmentRepository, @@ -24,6 +24,8 @@ module.exports = async function getCertificationDetails({ } }; +export { getCertificationDetails }; + async function _computeCertificationDetailsOnTheFly( certificationAssessment, placementProfileService, diff --git a/api/lib/domain/usecases/get-certification-point-of-contact.js b/api/lib/domain/usecases/get-certification-point-of-contact.js index e252eadd760..dbe8cce7f0d 100644 --- a/api/lib/domain/usecases/get-certification-point-of-contact.js +++ b/api/lib/domain/usecases/get-certification-point-of-contact.js @@ -1,3 +1,5 @@ -module.exports = async function getCertificationPointOfContact({ userId, certificationPointOfContactRepository }) { +const getCertificationPointOfContact = async function ({ userId, certificationPointOfContactRepository }) { return certificationPointOfContactRepository.get(userId); }; + +export { getCertificationPointOfContact }; diff --git a/api/lib/domain/usecases/get-challenge-for-pix-auto-answer.js b/api/lib/domain/usecases/get-challenge-for-pix-auto-answer.js index a732dc6679d..c77181dd9a9 100644 --- a/api/lib/domain/usecases/get-challenge-for-pix-auto-answer.js +++ b/api/lib/domain/usecases/get-challenge-for-pix-auto-answer.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../errors.js'); +import { NotFoundError } from '../errors.js'; -module.exports = async function getChallengeForPixAutoAnswer({ +const getChallengeForPixAutoAnswer = async function ({ assessmentId, assessmentRepository, challengeForPixAutoAnswerRepository, @@ -13,3 +13,5 @@ module.exports = async function getChallengeForPixAutoAnswer({ const lastChallengeId = assessment.lastChallengeId; return challengeForPixAutoAnswerRepository.get(lastChallengeId); }; + +export { getChallengeForPixAutoAnswer }; diff --git a/api/lib/domain/usecases/get-clea-certified-candidate-by-session.js b/api/lib/domain/usecases/get-clea-certified-candidate-by-session.js index 772bfd8fedd..d1487d52e31 100644 --- a/api/lib/domain/usecases/get-clea-certified-candidate-by-session.js +++ b/api/lib/domain/usecases/get-clea-certified-candidate-by-session.js @@ -1,4 +1,4 @@ -module.exports = async function getCleaCertifiedCandidateBySession({ +const getCleaCertifiedCandidateBySession = async function ({ sessionId, cleaCertifiedCandidateRepository, sessionRepository, @@ -8,3 +8,5 @@ module.exports = async function getCleaCertifiedCandidateBySession({ return { session, cleaCertifiedCandidateData }; }; + +export { getCleaCertifiedCandidateBySession }; diff --git a/api/lib/domain/usecases/get-correction-for-answer.js b/api/lib/domain/usecases/get-correction-for-answer.js index 2012b8aae61..5cf04c3b7af 100644 --- a/api/lib/domain/usecases/get-correction-for-answer.js +++ b/api/lib/domain/usecases/get-correction-for-answer.js @@ -1,6 +1,6 @@ -const { AssessmentNotCompletedError, NotFoundError } = require('../errors.js'); +import { AssessmentNotCompletedError, NotFoundError } from '../errors.js'; -module.exports = async function getCorrectionForAnswer({ +const getCorrectionForAnswer = async function ({ assessmentRepository, answerRepository, correctionRepository, @@ -22,6 +22,8 @@ module.exports = async function getCorrectionForAnswer({ return correctionRepository.getByChallengeId({ challengeId: answer.challengeId, userId, locale }); }; +export { getCorrectionForAnswer }; + function _validateCorrectionIsAccessible(assessment) { if (assessment.isForCampaign() || assessment.isCompetenceEvaluation()) { return; diff --git a/api/lib/domain/usecases/get-current-user.js b/api/lib/domain/usecases/get-current-user.js index 47ceab28d06..4a9b84ff538 100644 --- a/api/lib/domain/usecases/get-current-user.js +++ b/api/lib/domain/usecases/get-current-user.js @@ -1,6 +1,6 @@ -const UserWithActivity = require('../read-models/UserWithActivity.js'); +import { UserWithActivity } from '../read-models/UserWithActivity.js'; -module.exports = async function getCurrentUser({ +const getCurrentUser = async function ({ authenticatedUserId, userRepository, campaignParticipationRepository, @@ -21,3 +21,5 @@ module.exports = async function getCurrentUser({ shouldSeeDataProtectionPolicyInformationBanner, }); }; + +export { getCurrentUser }; diff --git a/api/lib/domain/usecases/get-external-authentication-redirection-url.js b/api/lib/domain/usecases/get-external-authentication-redirection-url.js index b24d0cdd9dc..f2063d2696c 100644 --- a/api/lib/domain/usecases/get-external-authentication-redirection-url.js +++ b/api/lib/domain/usecases/get-external-authentication-redirection-url.js @@ -1,13 +1,13 @@ -const AuthenticationMethod = require('../models/AuthenticationMethod.js'); +import { AuthenticationMethod } from '../models/AuthenticationMethod.js'; -module.exports = async function getExternalAuthenticationRedirectionUrl({ +const getExternalAuthenticationRedirectionUrl = async function ({ userAttributes, userRepository, authenticationMethodRepository, tokenService, - settings, + config, }) { - const { attributeMapping } = settings.saml; + const { attributeMapping } = config.saml; const externalUser = { firstName: userAttributes[attributeMapping.firstName], lastName: userAttributes[attributeMapping.lastName], @@ -29,6 +29,8 @@ module.exports = async function getExternalAuthenticationRedirectionUrl({ return _getUrlForReconciliationPage({ tokenService, externalUser }); }; +export { getExternalAuthenticationRedirectionUrl }; + async function _getUrlWithAccessToken({ user, externalUser, diff --git a/api/lib/domain/usecases/get-framework-areas.js b/api/lib/domain/usecases/get-framework-areas.js index fd94269d857..36561295f2a 100644 --- a/api/lib/domain/usecases/get-framework-areas.js +++ b/api/lib/domain/usecases/get-framework-areas.js @@ -1,4 +1,4 @@ -module.exports = async function getFrameworkAreas({ +const getFrameworkAreas = async function ({ frameworkId, frameworkName, locale, @@ -24,3 +24,5 @@ module.exports = async function getFrameworkAreas({ return { areas: areasWithCompetences, thematics, tubes }; }; + +export { getFrameworkAreas }; diff --git a/api/lib/domain/usecases/get-frameworks.js b/api/lib/domain/usecases/get-frameworks.js index 33ee7bb7728..ec54816cf17 100644 --- a/api/lib/domain/usecases/get-frameworks.js +++ b/api/lib/domain/usecases/get-frameworks.js @@ -1,3 +1,5 @@ -module.exports = async function getFrameworks({ frameworkRepository }) { +const getFrameworks = async function ({ frameworkRepository }) { return frameworkRepository.list(); }; + +export { getFrameworks }; diff --git a/api/lib/domain/usecases/get-identity-providers.js b/api/lib/domain/usecases/get-identity-providers.js index bd25d8755a0..af39484cc0e 100644 --- a/api/lib/domain/usecases/get-identity-providers.js +++ b/api/lib/domain/usecases/get-identity-providers.js @@ -1,10 +1,14 @@ -const { isEmpty, isNil, pick } = require('lodash'); -const OidcIdentityProviders = require('../constants/oidc-identity-providers.js'); -const config = require('../../config.js'); +import lodash from 'lodash'; -module.exports = function getIdentityProviders() { +const { isEmpty, isNil, pick } = lodash; + +import * as OidcIdentityProviders from '../constants/oidc-identity-providers.js'; +import { config } from '../../config.js'; + +const getIdentityProviders = function () { return Object.keys(OidcIdentityProviders) .map((oidcIdentityProviderKey) => { + // eslint-disable-next-line import/namespace const { configKey, propertyPathsToPick, service } = OidcIdentityProviders[oidcIdentityProviderKey]; const providerConfig = pick(config[configKey], propertyPathsToPick); @@ -24,3 +28,5 @@ module.exports = function getIdentityProviders() { }) .filter((identityProvider) => !isEmpty(identityProvider)); }; + +export { getIdentityProviders }; diff --git a/api/lib/domain/usecases/get-import-session-complementary-certification-habilitations-labels.js b/api/lib/domain/usecases/get-import-session-complementary-certification-habilitations-labels.js index 034ea98d309..ec1f817d4ef 100644 --- a/api/lib/domain/usecases/get-import-session-complementary-certification-habilitations-labels.js +++ b/api/lib/domain/usecases/get-import-session-complementary-certification-habilitations-labels.js @@ -1,4 +1,4 @@ -module.exports = async function getImportSessionComplementaryCertificationHabilitationsLabels({ +const getImportSessionComplementaryCertificationHabilitationsLabels = async function ({ certificationCenterId, complementaryCertificationHabilitationRepository, }) { @@ -10,3 +10,5 @@ module.exports = async function getImportSessionComplementaryCertificationHabili return habilitationsLabels; }; + +export { getImportSessionComplementaryCertificationHabilitationsLabels }; diff --git a/api/lib/domain/usecases/get-jury-certification.js b/api/lib/domain/usecases/get-jury-certification.js index 1d5bcf5bbdb..21deeefdceb 100644 --- a/api/lib/domain/usecases/get-jury-certification.js +++ b/api/lib/domain/usecases/get-jury-certification.js @@ -1,3 +1,5 @@ -module.exports = async function getJuryCertification({ certificationCourseId, juryCertificationRepository }) { +const getJuryCertification = async function ({ certificationCourseId, juryCertificationRepository }) { return juryCertificationRepository.get(certificationCourseId); }; + +export { getJuryCertification }; diff --git a/api/lib/domain/usecases/get-jury-session.js b/api/lib/domain/usecases/get-jury-session.js index 5d11bddb388..b526ddf812a 100644 --- a/api/lib/domain/usecases/get-jury-session.js +++ b/api/lib/domain/usecases/get-jury-session.js @@ -1,4 +1,4 @@ -module.exports = async function getJurySession({ sessionId, jurySessionRepository, supervisorAccessRepository }) { +const getJurySession = async function ({ sessionId, jurySessionRepository, supervisorAccessRepository }) { const jurySession = await jurySessionRepository.get(sessionId); const hasSupervisorAccess = await supervisorAccessRepository.sessionHasSupervisorAccess({ sessionId }); return { @@ -6,3 +6,5 @@ module.exports = async function getJurySession({ sessionId, jurySessionRepositor hasSupervisorAccess, }; }; + +export { getJurySession }; diff --git a/api/lib/domain/usecases/get-last-challenge-id-from-assessment-id.js b/api/lib/domain/usecases/get-last-challenge-id-from-assessment-id.js index 9b4966c571b..d84f444977f 100644 --- a/api/lib/domain/usecases/get-last-challenge-id-from-assessment-id.js +++ b/api/lib/domain/usecases/get-last-challenge-id-from-assessment-id.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../errors.js'); +import { NotFoundError } from '../errors.js'; -module.exports = async function getLastChallengeIdFromAssessmentId({ assessmentId, assessmentRepository }) { +const getLastChallengeIdFromAssessmentId = async function ({ assessmentId, assessmentRepository }) { const assessment = await assessmentRepository.get(assessmentId); if (!assessment) { throw new NotFoundError(`Assessment not found for ID ${assessmentId}`); @@ -8,3 +8,5 @@ module.exports = async function getLastChallengeIdFromAssessmentId({ assessmentI return assessment.lastChallengeId; }; + +export { getLastChallengeIdFromAssessmentId }; diff --git a/api/lib/domain/usecases/get-learning-content-by-target-profile.js b/api/lib/domain/usecases/get-learning-content-by-target-profile.js index 65882ac7868..217e80b7552 100644 --- a/api/lib/domain/usecases/get-learning-content-by-target-profile.js +++ b/api/lib/domain/usecases/get-learning-content-by-target-profile.js @@ -1,7 +1,5 @@ -module.exports = async function getLearningContentByTargetProfile({ - targetProfileId, - language, - learningContentRepository, -}) { +const getLearningContentByTargetProfile = async function ({ targetProfileId, language, learningContentRepository }) { return learningContentRepository.findByTargetProfileId(targetProfileId, language); }; + +export { getLearningContentByTargetProfile }; diff --git a/api/lib/domain/usecases/get-learning-content-for-target-profile-submission.js b/api/lib/domain/usecases/get-learning-content-for-target-profile-submission.js index f0561ca8ec3..92175ede66f 100644 --- a/api/lib/domain/usecases/get-learning-content-for-target-profile-submission.js +++ b/api/lib/domain/usecases/get-learning-content-for-target-profile-submission.js @@ -1,8 +1,10 @@ const AUTHORIZED_FRAMEWORKS = ['Pix']; -module.exports = async function getLearningContentForTargetProfileSubmission({ learningContentRepository, locale }) { +const getLearningContentForTargetProfileSubmission = async function ({ learningContentRepository, locale }) { return learningContentRepository.findByFrameworkNames({ frameworkNames: AUTHORIZED_FRAMEWORKS, locale, }); }; + +export { getLearningContentForTargetProfileSubmission }; diff --git a/api/lib/domain/usecases/get-next-challenge-for-campaign-assessment.js b/api/lib/domain/usecases/get-next-challenge-for-campaign-assessment.js index d45ce814d4f..de5d06b426b 100644 --- a/api/lib/domain/usecases/get-next-challenge-for-campaign-assessment.js +++ b/api/lib/domain/usecases/get-next-challenge-for-campaign-assessment.js @@ -1,7 +1,7 @@ -const { AssessmentEndedError } = require('../errors.js'); -const FlashAssessmentAlgorithm = require('../models/FlashAssessmentAlgorithm'); +import { AssessmentEndedError } from '../errors.js'; +import { FlashAssessmentAlgorithm } from '../models/FlashAssessmentAlgorithm.js'; -module.exports = async function getNextChallengeForCampaignAssessment({ +const getNextChallengeForCampaignAssessment = async function ({ challengeRepository, answerRepository, flashAssessmentResultRepository, @@ -46,3 +46,5 @@ module.exports = async function getNextChallengeForCampaignAssessment({ }); } }; + +export { getNextChallengeForCampaignAssessment }; diff --git a/api/lib/domain/usecases/get-next-challenge-for-certification.js b/api/lib/domain/usecases/get-next-challenge-for-certification.js index 97b3e20b81c..f2eeffc19dc 100644 --- a/api/lib/domain/usecases/get-next-challenge-for-certification.js +++ b/api/lib/domain/usecases/get-next-challenge-for-certification.js @@ -1,4 +1,4 @@ -module.exports = function getNextChallengeForCertification({ +const getNextChallengeForCertification = function ({ certificationChallengeRepository, challengeRepository, assessment, @@ -9,3 +9,5 @@ module.exports = function getNextChallengeForCertification({ return challengeRepository.get(certificationChallenge.challengeId); }); }; + +export { getNextChallengeForCertification }; diff --git a/api/lib/domain/usecases/get-next-challenge-for-competence-evaluation.js b/api/lib/domain/usecases/get-next-challenge-for-competence-evaluation.js index 7454e2fd43a..98e419452cf 100644 --- a/api/lib/domain/usecases/get-next-challenge-for-competence-evaluation.js +++ b/api/lib/domain/usecases/get-next-challenge-for-competence-evaluation.js @@ -1,8 +1,7 @@ -const { AssessmentEndedError, UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { AssessmentEndedError, UserNotAuthorizedToAccessEntityError } from '../errors.js'; +import * as dataFetcher from '../services/algorithm-methods/data-fetcher.js'; -const dataFetcher = require('../services/algorithm-methods/data-fetcher.js'); - -module.exports = async function getNextChallengeForCompetenceEvaluation({ +const getNextChallengeForCompetenceEvaluation = async function ({ pickChallengeService, assessment, userId, @@ -28,6 +27,8 @@ module.exports = async function getNextChallengeForCompetenceEvaluation({ }); }; +export { getNextChallengeForCompetenceEvaluation }; + function _checkIfAssessmentBelongsToUser(assessment, userId) { if (assessment.userId !== userId) { throw new UserNotAuthorizedToAccessEntityError(); diff --git a/api/lib/domain/usecases/get-next-challenge-for-demo.js b/api/lib/domain/usecases/get-next-challenge-for-demo.js index 1841b8554b9..5f7d7d31955 100644 --- a/api/lib/domain/usecases/get-next-challenge-for-demo.js +++ b/api/lib/domain/usecases/get-next-challenge-for-demo.js @@ -1,13 +1,8 @@ -const { AssessmentEndedError } = require('../errors.js'); -const _ = require('../../infrastructure/utils/lodash-utils.js'); -const logger = require('../../infrastructure/logger.js'); +import { AssessmentEndedError } from '../errors.js'; +import { _ } from '../../infrastructure/utils/lodash-utils.js'; +import { logger } from '../../infrastructure/logger.js'; -module.exports = function getNextChallengeForDemo({ - assessment, - answerRepository, - challengeRepository, - courseRepository, -}) { +const getNextChallengeForDemo = function ({ assessment, answerRepository, challengeRepository, courseRepository }) { const courseId = assessment.courseId; const logContext = { @@ -37,6 +32,8 @@ module.exports = function getNextChallengeForDemo({ .then(challengeRepository.get); }; +export { getNextChallengeForDemo }; + function _selectNextChallengeId(course, answers) { const courseChallengeIds = course.challenges; const answeredChallengeIds = _.map(answers, 'challengeId'); diff --git a/api/lib/domain/usecases/get-next-challenge-for-preview.js b/api/lib/domain/usecases/get-next-challenge-for-preview.js index 38d247ed338..7ec310ab4a8 100644 --- a/api/lib/domain/usecases/get-next-challenge-for-preview.js +++ b/api/lib/domain/usecases/get-next-challenge-for-preview.js @@ -1,5 +1,7 @@ -const { AssessmentEndedError } = require('../errors.js'); +import { AssessmentEndedError } from '../errors.js'; -module.exports = function getNextChallengeForPreview() { +const getNextChallengeForPreview = function () { return Promise.reject(new AssessmentEndedError()); }; + +export { getNextChallengeForPreview }; diff --git a/api/lib/domain/usecases/get-organization-invitation.js b/api/lib/domain/usecases/get-organization-invitation.js index 10ec2bfb21a..1aed88602bf 100644 --- a/api/lib/domain/usecases/get-organization-invitation.js +++ b/api/lib/domain/usecases/get-organization-invitation.js @@ -1,6 +1,6 @@ -const { AlreadyExistingInvitationError, CancelledInvitationError } = require('../../domain/errors.js'); +import { AlreadyExistingInvitationError, CancelledInvitationError } from '../../domain/errors.js'; -module.exports = async function getOrganizationInvitation({ +const getOrganizationInvitation = async function ({ organizationInvitationId, organizationInvitationCode, organizationRepository, @@ -24,3 +24,5 @@ module.exports = async function getOrganizationInvitation({ return foundOrganizationInvitation; }; + +export { getOrganizationInvitation }; diff --git a/api/lib/domain/usecases/get-organization-learner-activity.js b/api/lib/domain/usecases/get-organization-learner-activity.js index 37afb725869..443e0d0096b 100644 --- a/api/lib/domain/usecases/get-organization-learner-activity.js +++ b/api/lib/domain/usecases/get-organization-learner-activity.js @@ -1,6 +1,8 @@ -module.exports = async function getOrganizationLearnerActivity({ +const getOrganizationLearnerActivity = async function ({ organizationLearnerId, organizationLearnerActivityRepository, }) { return organizationLearnerActivityRepository.get(organizationLearnerId); }; + +export { getOrganizationLearnerActivity }; diff --git a/api/lib/domain/usecases/get-organization-learner.js b/api/lib/domain/usecases/get-organization-learner.js index 6509f82b744..db4ea3b3274 100644 --- a/api/lib/domain/usecases/get-organization-learner.js +++ b/api/lib/domain/usecases/get-organization-learner.js @@ -1,6 +1,5 @@ -module.exports = async function getOrganizationLearner({ - organizationLearnerId, - organizationLearnerFollowUpRepository, -}) { +const getOrganizationLearner = async function ({ organizationLearnerId, organizationLearnerFollowUpRepository }) { return organizationLearnerFollowUpRepository.get(organizationLearnerId); }; + +export { getOrganizationLearner }; diff --git a/api/lib/domain/usecases/get-organization-learners-csv-template.js b/api/lib/domain/usecases/get-organization-learners-csv-template.js index 691faf1263c..22dfc03667d 100644 --- a/api/lib/domain/usecases/get-organization-learners-csv-template.js +++ b/api/lib/domain/usecases/get-organization-learners-csv-template.js @@ -1,13 +1,8 @@ -const csvSerializer = require('../../infrastructure/serializers/csv/csv-serializer.js'); -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); -const SupOrganizationLearnerImportHeader = require('../../infrastructure/serializers/csv/sup-organization-learner-import-header.js'); - -module.exports = async function getOrganizationLearnersCsvTemplate({ - userId, - organizationId, - i18n, - membershipRepository, -}) { +import * as csvSerializer from '../../infrastructure/serializers/csv/csv-serializer.js'; +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; +import { SupOrganizationLearnerImportHeader } from '../../infrastructure/serializers/csv/sup-organization-learner-import-header.js'; + +const getOrganizationLearnersCsvTemplate = async function ({ userId, organizationId, i18n, membershipRepository }) { const [membership] = await membershipRepository.findByUserIdAndOrganizationId({ userId, organizationId, @@ -23,6 +18,8 @@ module.exports = async function getOrganizationLearnersCsvTemplate({ return _createHeaderOfCSV(header); }; +export { getOrganizationLearnersCsvTemplate }; + function _getCsvColumns(columns) { return columns.map((column) => column.name); } diff --git a/api/lib/domain/usecases/get-organization-members-identity.js b/api/lib/domain/usecases/get-organization-members-identity.js index 3aa61985544..f23dbb61786 100644 --- a/api/lib/domain/usecases/get-organization-members-identity.js +++ b/api/lib/domain/usecases/get-organization-members-identity.js @@ -1,3 +1,5 @@ -module.exports = function getOrganizationMemberIdentities({ organizationId, organizationMemberIdentityRepository }) { +const getOrganizationMemberIdentities = function ({ organizationId, organizationMemberIdentityRepository }) { return organizationMemberIdentityRepository.findAllByOrganizationId({ organizationId }); }; + +export { getOrganizationMemberIdentities }; diff --git a/api/lib/domain/usecases/get-organization-places-capacity.js b/api/lib/domain/usecases/get-organization-places-capacity.js index 73a27076f00..7c49dd2fe31 100644 --- a/api/lib/domain/usecases/get-organization-places-capacity.js +++ b/api/lib/domain/usecases/get-organization-places-capacity.js @@ -1,3 +1,5 @@ -module.exports = function getOrganizationPlacesCapacity({ organizationId, organizationPlacesCapacityRepository }) { +const getOrganizationPlacesCapacity = function ({ organizationId, organizationPlacesCapacityRepository }) { return organizationPlacesCapacityRepository.findByOrganizationId(organizationId); }; + +export { getOrganizationPlacesCapacity }; diff --git a/api/lib/domain/usecases/get-paginated-participants-for-an-organization.js b/api/lib/domain/usecases/get-paginated-participants-for-an-organization.js index dec4c1c0f74..69e8a5a9f5f 100644 --- a/api/lib/domain/usecases/get-paginated-participants-for-an-organization.js +++ b/api/lib/domain/usecases/get-paginated-participants-for-an-organization.js @@ -1,4 +1,4 @@ -module.exports = function getPaginatedParticipantsForAnOrganization({ +const getPaginatedParticipantsForAnOrganization = function ({ organizationId, filters, page, @@ -12,3 +12,5 @@ module.exports = function getPaginatedParticipantsForAnOrganization({ page, }); }; + +export { getPaginatedParticipantsForAnOrganization }; diff --git a/api/lib/domain/usecases/get-participants-division.js b/api/lib/domain/usecases/get-participants-division.js index 99c22e95b44..248c8559a48 100644 --- a/api/lib/domain/usecases/get-participants-division.js +++ b/api/lib/domain/usecases/get-participants-division.js @@ -1,13 +1,10 @@ -const { ForbiddenAccess } = require('../errors.js'); +import { ForbiddenAccess } from '../errors.js'; -module.exports = async function getParticipantsDivision({ - userId, - campaignId, - campaignRepository, - divisionRepository, -}) { +const getParticipantsDivision = async function ({ userId, campaignId, campaignRepository, divisionRepository }) { if (!(await campaignRepository.checkIfUserOrganizationHasAccessToCampaign(campaignId, userId))) { throw new ForbiddenAccess(); } return divisionRepository.findByCampaignId(campaignId); }; + +export { getParticipantsDivision }; diff --git a/api/lib/domain/usecases/get-participants-group.js b/api/lib/domain/usecases/get-participants-group.js index 663c92fd763..d13819a53b9 100644 --- a/api/lib/domain/usecases/get-participants-group.js +++ b/api/lib/domain/usecases/get-participants-group.js @@ -1,8 +1,10 @@ -const { ForbiddenAccess } = require('../errors.js'); +import { ForbiddenAccess } from '../errors.js'; -module.exports = async function getParticipantsGroup({ userId, campaignId, campaignRepository, groupRepository }) { +const getParticipantsGroup = async function ({ userId, campaignId, campaignRepository, groupRepository }) { if (!(await campaignRepository.checkIfUserOrganizationHasAccessToCampaign(campaignId, userId))) { throw new ForbiddenAccess(); } return groupRepository.findByCampaignId(campaignId); }; + +export { getParticipantsGroup }; diff --git a/api/lib/domain/usecases/get-participations-count-by-mastery-rate.js b/api/lib/domain/usecases/get-participations-count-by-mastery-rate.js index 5620518494c..539c9cc79ea 100644 --- a/api/lib/domain/usecases/get-participations-count-by-mastery-rate.js +++ b/api/lib/domain/usecases/get-participations-count-by-mastery-rate.js @@ -1,5 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); -module.exports = async function getParticipationsCountByMasteryRate({ +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; + +const getParticipationsCountByMasteryRate = async function ({ campaignId, userId, campaignParticipationsStatsRepository, @@ -9,6 +10,8 @@ module.exports = async function getParticipationsCountByMasteryRate({ return campaignParticipationsStatsRepository.countParticipationsByMasteryRate({ campaignId }); }; +export { getParticipationsCountByMasteryRate }; + async function _checkUserPermission(campaignId, userId, campaignRepository) { const hasAccess = await campaignRepository.checkIfUserOrganizationHasAccessToCampaign(campaignId, userId); diff --git a/api/lib/domain/usecases/get-pole-emploi-sendings.js b/api/lib/domain/usecases/get-pole-emploi-sendings.js index c7733d67071..8acee0d9ec1 100644 --- a/api/lib/domain/usecases/get-pole-emploi-sendings.js +++ b/api/lib/domain/usecases/get-pole-emploi-sendings.js @@ -1,12 +1,14 @@ -const poleEmploiService = require('../services/pole-emploi-service.js'); +import * as poleEmploiService from '../services/pole-emploi-service.js'; -module.exports = async function getPoleEmploiSendings({ cursor, poleEmploiSendingRepository, filters }) { +const getPoleEmploiSendings = async function ({ cursor, poleEmploiSendingRepository, filters }) { const cursorData = await poleEmploiService.decodeCursor(cursor); const sendings = await poleEmploiSendingRepository.find(cursorData, filters); const link = _generateLink(sendings, filters); return { sendings, link }; }; +export { getPoleEmploiSendings }; + function _generateLink(sendings, filters) { if (!sendings.length) return null; diff --git a/api/lib/domain/usecases/get-prescriber.js b/api/lib/domain/usecases/get-prescriber.js index e5fd54204cf..9d5493f7213 100644 --- a/api/lib/domain/usecases/get-prescriber.js +++ b/api/lib/domain/usecases/get-prescriber.js @@ -1,12 +1,12 @@ -const { UserNotMemberOfOrganizationError } = require('../errors.js'); -const _ = require('lodash'); +import { UserNotMemberOfOrganizationError } from '../errors.js'; +import _ from 'lodash'; function _isCurrentOrganizationInMemberships(userOrgaSettings, memberships) { const currentOrganizationId = userOrgaSettings.currentOrganization.id; return _.find(memberships, { organization: { id: currentOrganizationId } }); } -module.exports = async function getPrescriber({ +const getPrescriber = async function ({ userId, prescriberRepository, membershipRepository, @@ -31,3 +31,5 @@ module.exports = async function getPrescriber({ return prescriberRepository.getPrescriber(userId); }; + +export { getPrescriber }; diff --git a/api/lib/domain/usecases/get-progression.js b/api/lib/domain/usecases/get-progression.js index dd4096429aa..b7845e349ff 100644 --- a/api/lib/domain/usecases/get-progression.js +++ b/api/lib/domain/usecases/get-progression.js @@ -1,6 +1,6 @@ -const Progression = require('../../../lib/domain/models/Progression.js'); +import { Progression } from '../../../lib/domain/models/Progression.js'; -module.exports = async function getProgression({ +const getProgression = async function ({ progressionId, userId, assessmentRepository, @@ -65,3 +65,5 @@ module.exports = async function getProgression({ return progression; }; + +export { getProgression }; diff --git a/api/lib/domain/usecases/get-recently-used-tags.js b/api/lib/domain/usecases/get-recently-used-tags.js index a3768b79bcb..39e840dc990 100644 --- a/api/lib/domain/usecases/get-recently-used-tags.js +++ b/api/lib/domain/usecases/get-recently-used-tags.js @@ -1,3 +1,5 @@ -module.exports = async function getRecentlyUsedTags({ tagId, organizationTagRepository }) { +const getRecentlyUsedTags = async function ({ tagId, organizationTagRepository }) { return organizationTagRepository.getRecentlyUsedTags({ tagId, numberOfRecentTags: 10 }); }; + +export { getRecentlyUsedTags }; diff --git a/api/lib/domain/usecases/get-sco-certification-results-by-division.js b/api/lib/domain/usecases/get-sco-certification-results-by-division.js index 27334a03738..869118687eb 100644 --- a/api/lib/domain/usecases/get-sco-certification-results-by-division.js +++ b/api/lib/domain/usecases/get-sco-certification-results-by-division.js @@ -1,7 +1,10 @@ -const isEmpty = require('lodash/isEmpty'); -const { NoCertificationResultForDivision } = require('../errors.js'); +import lodash from 'lodash'; -module.exports = async function getScoCertificationResultsByDivision({ +const { isEmpty } = lodash; + +import { NoCertificationResultForDivision } from '../errors.js'; + +const getScoCertificationResultsByDivision = async function ({ organizationId, division, scoCertificationCandidateRepository, @@ -24,3 +27,5 @@ module.exports = async function getScoCertificationResultsByDivision({ return certificationResults; }; + +export { getScoCertificationResultsByDivision }; diff --git a/api/lib/domain/usecases/get-scorecard.js b/api/lib/domain/usecases/get-scorecard.js index 30da3fb6d15..6c6d2582d6d 100644 --- a/api/lib/domain/usecases/get-scorecard.js +++ b/api/lib/domain/usecases/get-scorecard.js @@ -1,7 +1,7 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); -const Scorecard = require('../models/Scorecard.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; +import { Scorecard } from '../models/Scorecard.js'; -module.exports = async function getScorecard({ +const getScorecard = async function ({ authenticatedUserId, scorecardId, scorecardService, @@ -27,3 +27,5 @@ module.exports = async function getScorecard({ locale, }); }; + +export { getScorecard }; diff --git a/api/lib/domain/usecases/get-session-certification-candidates.js b/api/lib/domain/usecases/get-session-certification-candidates.js index 5ebc0069d6b..9fb98ee2364 100644 --- a/api/lib/domain/usecases/get-session-certification-candidates.js +++ b/api/lib/domain/usecases/get-session-certification-candidates.js @@ -1,3 +1,5 @@ -module.exports = async function getSessionCertificationCandidates({ sessionId, certificationCandidateRepository }) { +const getSessionCertificationCandidates = async function ({ sessionId, certificationCandidateRepository }) { return certificationCandidateRepository.findBySessionId(sessionId); }; + +export { getSessionCertificationCandidates }; diff --git a/api/lib/domain/usecases/get-session-certification-reports.js b/api/lib/domain/usecases/get-session-certification-reports.js index 34534fe0c63..0ad7b398241 100644 --- a/api/lib/domain/usecases/get-session-certification-reports.js +++ b/api/lib/domain/usecases/get-session-certification-reports.js @@ -1,3 +1,5 @@ -module.exports = async function getSessionCertificationReports({ sessionId, certificationReportRepository }) { +const getSessionCertificationReports = async function ({ sessionId, certificationReportRepository }) { return certificationReportRepository.findBySessionId(sessionId); }; + +export { getSessionCertificationReports }; diff --git a/api/lib/domain/usecases/get-session-for-supervising.js b/api/lib/domain/usecases/get-session-for-supervising.js index 72f122541e5..067d45974bc 100644 --- a/api/lib/domain/usecases/get-session-for-supervising.js +++ b/api/lib/domain/usecases/get-session-for-supervising.js @@ -1,9 +1,9 @@ -const bluebird = require('bluebird'); -const dayjs = require('dayjs'); -const { constants: domainConstants } = require('../constants'); -const { constants: infraConstants } = require('../../infrastructure/constants.js'); +import bluebird from 'bluebird'; +import dayjs from 'dayjs'; +import { constants as domainConstants } from '../constants.js'; +import { constants as infraConstants } from '../../infrastructure/constants.js'; -module.exports = async function getSessionForSupervising({ +const getSessionForSupervising = async function ({ sessionId, sessionForSupervisingRepository, certificationBadgesService, @@ -21,6 +21,8 @@ module.exports = async function getSessionForSupervising({ return sessionForSupervising; }; +export { getSessionForSupervising }; + function _computeComplementaryCertificationEligibility(certificationBadgesService) { return async (candidate) => { if (candidate.enrolledComplementaryCertification?.key) { diff --git a/api/lib/domain/usecases/get-session-results-by-result-recipient-email.js b/api/lib/domain/usecases/get-session-results-by-result-recipient-email.js index 227697596dc..55ce05b2e57 100644 --- a/api/lib/domain/usecases/get-session-results-by-result-recipient-email.js +++ b/api/lib/domain/usecases/get-session-results-by-result-recipient-email.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); +import _ from 'lodash'; -module.exports = async function getSessionResultsByResultRecipientEmail({ +const getSessionResultsByResultRecipientEmail = async function ({ sessionId, resultRecipientEmail, sessionRepository, @@ -18,3 +18,5 @@ module.exports = async function getSessionResultsByResultRecipientEmail({ return { session, certificationResults }; }; + +export { getSessionResultsByResultRecipientEmail }; diff --git a/api/lib/domain/usecases/get-session-results.js b/api/lib/domain/usecases/get-session-results.js index 1624a1e7ab8..3a07ca2f735 100644 --- a/api/lib/domain/usecases/get-session-results.js +++ b/api/lib/domain/usecases/get-session-results.js @@ -1,6 +1,8 @@ -module.exports = async function getSessionResults({ sessionId, sessionRepository, certificationResultRepository }) { +const getSessionResults = async function ({ sessionId, sessionRepository, certificationResultRepository }) { const session = await sessionRepository.get(sessionId); const certificationResults = await certificationResultRepository.findBySessionId({ sessionId }); return { session, certificationResults }; }; + +export { getSessionResults }; diff --git a/api/lib/domain/usecases/get-session.js b/api/lib/domain/usecases/get-session.js index 8feea66705b..df0c22480ca 100644 --- a/api/lib/domain/usecases/get-session.js +++ b/api/lib/domain/usecases/get-session.js @@ -1,4 +1,4 @@ -module.exports = async function getSession({ sessionId, sessionRepository, supervisorAccessRepository }) { +const getSession = async function ({ sessionId, sessionRepository, supervisorAccessRepository }) { const session = await sessionRepository.get(sessionId); const hasSomeCleaAcquired = await sessionRepository.hasSomeCleaAcquired(sessionId); const hasSupervisorAccess = await supervisorAccessRepository.sessionHasSupervisorAccess({ sessionId }); @@ -8,3 +8,5 @@ module.exports = async function getSession({ sessionId, sessionRepository, super hasSomeCleaAcquired, }; }; + +export { getSession }; diff --git a/api/lib/domain/usecases/get-supervisor-kit-session-info.js b/api/lib/domain/usecases/get-supervisor-kit-session-info.js index cf09f0f4e1a..87187d26b76 100644 --- a/api/lib/domain/usecases/get-supervisor-kit-session-info.js +++ b/api/lib/domain/usecases/get-supervisor-kit-session-info.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; -module.exports = async function getSupervisorKitSessionInfo({ +const getSupervisorKitSessionInfo = async function ({ userId, sessionId, sessionRepository, @@ -15,3 +15,5 @@ module.exports = async function getSupervisorKitSessionInfo({ return sessionForSupervisorKit; }; + +export { getSupervisorKitSessionInfo }; diff --git a/api/lib/domain/usecases/get-target-profile-content-as-json.js b/api/lib/domain/usecases/get-target-profile-content-as-json.js index 050c0d2ba17..e061f865fae 100644 --- a/api/lib/domain/usecases/get-target-profile-content-as-json.js +++ b/api/lib/domain/usecases/get-target-profile-content-as-json.js @@ -1,7 +1,7 @@ -const { ForbiddenAccess } = require('../../domain/errors.js'); -const dayjs = require('dayjs'); +import { ForbiddenAccess } from '../../domain/errors.js'; +import dayjs from 'dayjs'; -module.exports = async function getTargetProfileContentAsJson({ +const getTargetProfileContentAsJson = async function ({ userId, targetProfileId, adminMemberRepository, @@ -24,6 +24,8 @@ module.exports = async function getTargetProfileContentAsJson({ }; }; +export { getTargetProfileContentAsJson }; + function _hasAuthorizationToDownloadContent(adminMember) { return adminMember.isMetier || adminMember.isSupport || adminMember.isSuperAdmin; } diff --git a/api/lib/domain/usecases/get-target-profile-for-admin.js b/api/lib/domain/usecases/get-target-profile-for-admin.js index 7e8d699bc8d..4ea3d46af12 100644 --- a/api/lib/domain/usecases/get-target-profile-for-admin.js +++ b/api/lib/domain/usecases/get-target-profile-for-admin.js @@ -1,3 +1,5 @@ -module.exports = async function getTargetProfileForAdmin({ targetProfileId, targetProfileForAdminRepository }) { +const getTargetProfileForAdmin = async function ({ targetProfileId, targetProfileForAdminRepository }) { return targetProfileForAdminRepository.get({ id: targetProfileId }); }; + +export { getTargetProfileForAdmin }; diff --git a/api/lib/domain/usecases/get-training.js b/api/lib/domain/usecases/get-training.js index 3c3dd3efbb7..60b1e192d13 100644 --- a/api/lib/domain/usecases/get-training.js +++ b/api/lib/domain/usecases/get-training.js @@ -1,3 +1,5 @@ -module.exports = function getTraining({ trainingId, trainingRepository }) { +const getTraining = function ({ trainingId, trainingRepository }) { return trainingRepository.getWithTriggersForAdmin({ trainingId }); }; + +export { getTraining }; diff --git a/api/lib/domain/usecases/get-user-by-reset-password-demand.js b/api/lib/domain/usecases/get-user-by-reset-password-demand.js index 3ebb975206d..641099ba446 100644 --- a/api/lib/domain/usecases/get-user-by-reset-password-demand.js +++ b/api/lib/domain/usecases/get-user-by-reset-password-demand.js @@ -1,4 +1,4 @@ -module.exports = async function getUserByResetPasswordDemand({ +const getUserByResetPasswordDemand = async function ({ temporaryKey, resetPasswordService, tokenService, @@ -9,3 +9,5 @@ module.exports = async function getUserByResetPasswordDemand({ const { email } = await resetPasswordService.verifyDemand(temporaryKey, resetPasswordDemandRepository); return userRepository.getByEmail(email); }; + +export { getUserByResetPasswordDemand }; diff --git a/api/lib/domain/usecases/get-user-campaign-assessment-result.js b/api/lib/domain/usecases/get-user-campaign-assessment-result.js index 215ae539c1f..300639bd307 100644 --- a/api/lib/domain/usecases/get-user-campaign-assessment-result.js +++ b/api/lib/domain/usecases/get-user-campaign-assessment-result.js @@ -1,6 +1,6 @@ -const { NotFoundError, NoCampaignParticipationForUserAndCampaign } = require('../errors.js'); +import { NotFoundError, NoCampaignParticipationForUserAndCampaign } from '../errors.js'; -module.exports = async function getUserCampaignAssessmentResult({ +const getUserCampaignAssessmentResult = async function ({ userId, campaignId, locale, @@ -34,6 +34,8 @@ module.exports = async function getUserCampaignAssessmentResult({ } }; +export { getUserCampaignAssessmentResult }; + async function _checkStillValidBadges(campaignId, userId, knowledgeElementRepository, badgeForCalculationRepository) { const knowledgeElements = await knowledgeElementRepository.findUniqByUserId({ userId }); const badges = await badgeForCalculationRepository.findByCampaignId({ campaignId }); diff --git a/api/lib/domain/usecases/get-user-campaign-participation-to-campaign.js b/api/lib/domain/usecases/get-user-campaign-participation-to-campaign.js index fc473d30518..c4461945d71 100644 --- a/api/lib/domain/usecases/get-user-campaign-participation-to-campaign.js +++ b/api/lib/domain/usecases/get-user-campaign-participation-to-campaign.js @@ -1,7 +1,9 @@ -module.exports = async function getUserCampaignParticipationToCampaign({ +const getUserCampaignParticipationToCampaign = async function ({ userId, campaignId, campaignParticipationRepository, }) { return campaignParticipationRepository.findOneByCampaignIdAndUserId({ campaignId, userId }); }; + +export { getUserCampaignParticipationToCampaign }; diff --git a/api/lib/domain/usecases/get-user-certification-eligibility.js b/api/lib/domain/usecases/get-user-certification-eligibility.js index a874502d6c8..2fb1c2b9a0b 100644 --- a/api/lib/domain/usecases/get-user-certification-eligibility.js +++ b/api/lib/domain/usecases/get-user-certification-eligibility.js @@ -1,6 +1,6 @@ -const CertificationEligibility = require('../read-models/CertificationEligibility.js'); +import { CertificationEligibility } from '../read-models/CertificationEligibility.js'; -module.exports = async function getUserCertificationEligibility({ +const getUserCertificationEligibility = async function ({ userId, placementProfileService, certificationBadgesService, @@ -30,3 +30,5 @@ module.exports = async function getUserCertificationEligibility({ eligibleComplementaryCertifications, }); }; + +export { getUserCertificationEligibility }; diff --git a/api/lib/domain/usecases/get-user-details-for-admin.js b/api/lib/domain/usecases/get-user-details-for-admin.js index 05102298dfe..021a445c0c1 100644 --- a/api/lib/domain/usecases/get-user-details-for-admin.js +++ b/api/lib/domain/usecases/get-user-details-for-admin.js @@ -1,3 +1,5 @@ -module.exports = async function getUserDetailsForAdmin({ userId, userRepository }) { +const getUserDetailsForAdmin = async function ({ userId, userRepository }) { return await userRepository.getUserDetailsForAdmin(userId); }; + +export { getUserDetailsForAdmin }; diff --git a/api/lib/domain/usecases/get-user-profile-shared-for-campaign.js b/api/lib/domain/usecases/get-user-profile-shared-for-campaign.js index f619749b03a..c246e8be6af 100644 --- a/api/lib/domain/usecases/get-user-profile-shared-for-campaign.js +++ b/api/lib/domain/usecases/get-user-profile-shared-for-campaign.js @@ -1,8 +1,8 @@ -const SharedProfileForCampaign = require('../read-models/SharedProfileForCampaign.js'); -const { NoCampaignParticipationForUserAndCampaign } = require('../errors.js'); -const { constants } = require('../constants.js'); +import { SharedProfileForCampaign } from '../read-models/SharedProfileForCampaign.js'; +import { NoCampaignParticipationForUserAndCampaign } from '../errors.js'; +import { constants } from '../constants.js'; -module.exports = async function getUserProfileSharedForCampaign({ +const getUserProfileSharedForCampaign = async function ({ userId, campaignId, campaignParticipationRepository, @@ -51,3 +51,5 @@ module.exports = async function getUserProfileSharedForCampaign({ maxReachablePixScore, }); }; + +export { getUserProfileSharedForCampaign }; diff --git a/api/lib/domain/usecases/get-user-profile.js b/api/lib/domain/usecases/get-user-profile.js index 96164448d90..165ade2a62b 100644 --- a/api/lib/domain/usecases/get-user-profile.js +++ b/api/lib/domain/usecases/get-user-profile.js @@ -1,8 +1,8 @@ -const Scorecard = require('../models/Scorecard.js'); -const { constants } = require('../constants.js'); -const _ = require('lodash'); +import { Scorecard } from '../models/Scorecard.js'; +import { constants } from '../constants.js'; +import _ from 'lodash'; -module.exports = async function getUserProfile({ +const getUserProfile = async function ({ userId, competenceRepository, areaRepository, @@ -43,3 +43,5 @@ module.exports = async function getUserProfile({ maxReachableLevel, }; }; + +export { getUserProfile }; diff --git a/api/lib/domain/usecases/handle-badge-acquisition.js b/api/lib/domain/usecases/handle-badge-acquisition.js index 2e6d6c2a500..86cdab440ce 100644 --- a/api/lib/domain/usecases/handle-badge-acquisition.js +++ b/api/lib/domain/usecases/handle-badge-acquisition.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; const handleBadgeAcquisition = async function ({ assessment, @@ -46,4 +46,4 @@ function _fetchPossibleCampaignAssociatedBadges( return badgeForCalculationRepository.findByCampaignParticipationId({ campaignParticipationId, domainTransaction }); } -module.exports = handleBadgeAcquisition; +export { handleBadgeAcquisition }; diff --git a/api/lib/domain/usecases/handle-training-recommendation.js b/api/lib/domain/usecases/handle-training-recommendation.js index fe9ebf5baaf..afa55ee4f5c 100644 --- a/api/lib/domain/usecases/handle-training-recommendation.js +++ b/api/lib/domain/usecases/handle-training-recommendation.js @@ -1,4 +1,4 @@ -module.exports = async function handleTrainingRecommendation({ +const handleTrainingRecommendation = async function ({ locale, assessment, campaignRepository, @@ -42,3 +42,5 @@ module.exports = async function handleTrainingRecommendation({ } return; }; + +export { handleTrainingRecommendation }; diff --git a/api/lib/domain/usecases/import-certification-candidates-from-candidates-import-sheet.js b/api/lib/domain/usecases/import-certification-candidates-from-candidates-import-sheet.js index f67c4952ea3..5d84c8ca6fc 100644 --- a/api/lib/domain/usecases/import-certification-candidates-from-candidates-import-sheet.js +++ b/api/lib/domain/usecases/import-certification-candidates-from-candidates-import-sheet.js @@ -1,8 +1,8 @@ -const { CertificationCandidateAlreadyLinkedToUserError } = require('../../domain/errors.js'); -const bluebird = require('bluebird'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import { CertificationCandidateAlreadyLinkedToUserError } from '../../domain/errors.js'; +import bluebird from 'bluebird'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; -module.exports = async function importCertificationCandidatesFromCandidatesImportSheet({ +const importCertificationCandidatesFromCandidatesImportSheet = async function ({ sessionId, odsBuffer, i18n, @@ -49,3 +49,5 @@ module.exports = async function importCertificationCandidatesFromCandidatesImpor }); }); }; + +export { importCertificationCandidatesFromCandidatesImportSheet }; diff --git a/api/lib/domain/usecases/import-organization-learners-from-siecle.js b/api/lib/domain/usecases/import-organization-learners-from-siecle.js index 28774bdcfdf..0cc58dad379 100644 --- a/api/lib/domain/usecases/import-organization-learners-from-siecle.js +++ b/api/lib/domain/usecases/import-organization-learners-from-siecle.js @@ -1,16 +1,19 @@ -const { FileValidationError, SiecleXmlImportError } = require('../errors.js'); -const fs = require('fs').promises; -const bluebird = require('bluebird'); -const { ORGANIZATION_LEARNER_CHUNK_SIZE } = require('../../infrastructure/constants.js'); -const { isEmpty, chunk } = require('lodash'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import { FileValidationError, SiecleXmlImportError } from '../errors.js'; +import * as fs from 'fs/promises'; + +const { isEmpty, chunk } = lodash; + +import bluebird from 'bluebird'; +import { ORGANIZATION_LEARNER_CHUNK_SIZE } from '../../infrastructure/constants.js'; +import lodash from 'lodash'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; const ERRORS = { EMPTY: 'EMPTY', INVALID_FILE_EXTENSION: 'INVALID_FILE_EXTENSION', }; -module.exports = async function importOrganizationLearnersFromSIECLEFormat({ +const importOrganizationLearnersFromSIECLEFormat = async function ({ organizationId, payload, format, @@ -63,3 +66,5 @@ module.exports = async function importOrganizationLearnersFromSIECLEFormat({ }); }); }; + +export { importOrganizationLearnersFromSIECLEFormat }; diff --git a/api/lib/domain/usecases/import-sup-organization-learners.js b/api/lib/domain/usecases/import-sup-organization-learners.js index b017403497b..5359a9c570c 100644 --- a/api/lib/domain/usecases/import-sup-organization-learners.js +++ b/api/lib/domain/usecases/import-sup-organization-learners.js @@ -1,4 +1,4 @@ -module.exports = async function importSupOrganizationLearners({ +const importSupOrganizationLearners = async function ({ supOrganizationLearnerRepository, supOrganizationLearnerParser, }) { @@ -8,3 +8,5 @@ module.exports = async function importSupOrganizationLearners({ return warnings; }; + +export { importSupOrganizationLearners }; diff --git a/api/lib/domain/usecases/improve-competence-evaluation.js b/api/lib/domain/usecases/improve-competence-evaluation.js index 57db862c90a..c861665a0e6 100644 --- a/api/lib/domain/usecases/improve-competence-evaluation.js +++ b/api/lib/domain/usecases/improve-competence-evaluation.js @@ -1,8 +1,8 @@ -const Assessment = require('../models/Assessment.js'); -const { MAX_REACHABLE_LEVEL } = require('../constants.js'); -const { ImproveCompetenceEvaluationForbiddenError } = require('../errors.js'); +import { Assessment } from '../models/Assessment.js'; +import { MAX_REACHABLE_LEVEL } from '../constants.js'; +import { ImproveCompetenceEvaluationForbiddenError } from '../errors.js'; -module.exports = async function improveCompetenceEvaluation({ +const improveCompetenceEvaluation = async function ({ competenceEvaluationRepository, getCompetenceLevel, assessmentRepository, @@ -39,3 +39,5 @@ module.exports = async function improveCompetenceEvaluation({ return { ...competenceEvaluation, assessmentId }; }; + +export { improveCompetenceEvaluation }; diff --git a/api/lib/domain/usecases/index.js b/api/lib/domain/usecases/index.js index 90b160b96c3..8c661a07687 100644 --- a/api/lib/domain/usecases/index.js +++ b/api/lib/domain/usecases/index.js @@ -1,201 +1,203 @@ -const settings = require('../../config.js'); -const accountRecoveryDemandRepository = require('../../infrastructure/repositories/account-recovery-demand-repository.js'); -const adminMemberRepository = require('../../infrastructure/repositories/admin-member-repository.js'); -const algorithmDataFetcherService = require('../../domain/services/algorithm-methods/data-fetcher.js'); -const answerRepository = require('../../infrastructure/repositories/answer-repository.js'); -const areaRepository = require('../../infrastructure/repositories/area-repository.js'); -const assessmentRepository = require('../../infrastructure/repositories/assessment-repository.js'); -const assessmentResultRepository = require('../../infrastructure/repositories/assessment-result-repository.js'); -const authenticationMethodRepository = require('../../infrastructure/repositories/authentication-method-repository.js'); -const authenticationServiceRegistry = require('../services/authentication/authentication-service-registry.js'); -const authenticationSessionService = require('../../domain/services/authentication/authentication-session-service.js'); -const badgeAcquisitionRepository = require('../../infrastructure/repositories/badge-acquisition-repository.js'); -const badgeCriteriaRepository = require('../../infrastructure/repositories/badge-criteria-repository.js'); -const badgeForCalculationRepository = require('../../infrastructure/repositories/badge-for-calculation-repository.js'); -const badgeRepository = require('../../infrastructure/repositories/badge-repository.js'); -const campaignAdministrationRepository = require('../../infrastructure/repositories/campaigns-administration/campaign-repository.js'); -const campaignAnalysisRepository = require('../../infrastructure/repositories/campaign-analysis-repository.js'); -const campaignAssessmentParticipationRepository = require('../../infrastructure/repositories/campaign-assessment-participation-repository.js'); -const campaignAssessmentParticipationResultListRepository = require('../../infrastructure/repositories/campaign-assessment-participation-result-list-repository.js'); -const campaignAssessmentParticipationResultRepository = require('../../infrastructure/repositories/campaign-assessment-participation-result-repository.js'); -const campaignCreatorRepository = require('../../infrastructure/repositories/campaign-creator-repository.js'); -const campaignForArchivingRepository = require('../../infrastructure/repositories/campaign/campaign-for-archiving-repository.js'); -const campaignParticipantActivityRepository = require('../../infrastructure/repositories/campaign-participant-activity-repository.js'); -const campaignCollectiveResultRepository = require('../../infrastructure/repositories/campaign-collective-result-repository.js'); -const campaignManagementRepository = require('../../infrastructure/repositories/campaign-management-repository.js'); -const campaignParticipationInfoRepository = require('../../infrastructure/repositories/campaign-participation-info-repository.js'); -const campaignParticipantRepository = require('../../infrastructure/repositories/campaign-participant-repository.js'); -const campaignParticipationOverviewRepository = require('../../infrastructure/repositories/campaign-participation-overview-repository.js'); -const campaignParticipationRepository = require('../../infrastructure/repositories/campaign-participation-repository.js'); -const campaignParticipationResultRepository = require('../../infrastructure/repositories/campaign-participation-result-repository.js'); -const campaignParticipationsStatsRepository = require('../../infrastructure/repositories/campaign-participations-stats-repository.js'); -const campaignProfilesCollectionParticipationSummaryRepository = require('../../infrastructure/repositories/campaign-profiles-collection-participation-summary-repository.js'); -const campaignProfileRepository = require('../../infrastructure/repositories/campaign-profile-repository.js'); -const campaignReportRepository = require('../../infrastructure/repositories/campaign-report-repository.js'); -const campaignRepository = require('../../infrastructure/repositories/campaign-repository.js'); -const campaignToJoinRepository = require('../../infrastructure/repositories/campaign-to-join-repository.js'); -const campaignCsvExportService = require('../../domain/services/campaign-csv-export-service.js'); -const certifiableProfileForLearningContentRepository = require('../../infrastructure/repositories/certifiable-profile-for-learning-content-repository'); -const certificateRepository = require('../../infrastructure/repositories/certificate-repository.js'); -const certificationAssessmentRepository = require('../../infrastructure/repositories/certification-assessment-repository.js'); -const certificationAttestationPdf = require('../../infrastructure/utils/pdf/certification-attestation-pdf.js'); -const certificationBadgesService = require('../../domain/services/certification-badges-service.js'); -const certificationCandidateRepository = require('../../infrastructure/repositories/certification-candidate-repository.js'); -const certificationCandidateForSupervisingRepository = require('../../infrastructure/repositories/certification-candidate-for-supervising-repository.js'); -const certificationCandidatesOdsService = require('../../domain/services/certification-candidates-ods-service.js'); -const certificationCenterInvitationRepository = require('../../infrastructure/repositories/certification-center-invitation-repository.js'); -const certificationCenterInvitedUserRepository = require('../../infrastructure/repositories/certification-center-invited-user-repository.js'); -const certificationCenterMembershipRepository = require('../../infrastructure/repositories/certification-center-membership-repository.js'); -const certificationCenterForAdminRepository = require('../../infrastructure/repositories/certification-center-for-admin-repository.js'); -const certificationCenterRepository = require('../../infrastructure/repositories/certification-center-repository.js'); -const certificationChallengeRepository = require('../../infrastructure/repositories/certification-challenge-repository.js'); -const certificationChallengesService = require('../../domain/services/certification-challenges-service.js'); -const certificationCourseRepository = require('../../infrastructure/repositories/certification-course-repository.js'); -const certificationCpfCityRepository = require('../../infrastructure/repositories/certification-cpf-city-repository.js'); -const certificationCpfCountryRepository = require('../../infrastructure/repositories/certification-cpf-country-repository.js'); -const certificationIssueReportRepository = require('../../infrastructure/repositories/certification-issue-report-repository.js'); -const certificationLsRepository = require('../../infrastructure/repositories/certification-livret-scolaire-repository.js'); -const certificationOfficerRepository = require('../../infrastructure/repositories/certification-officer-repository.js'); -const certificationPointOfContactRepository = require('../../infrastructure/repositories/certification-point-of-contact-repository.js'); -const certificationReportRepository = require('../../infrastructure/repositories/certification-report-repository.js'); -const certificationRepository = require('../../infrastructure/repositories/certification-repository.js'); -const certificationCpfService = require('../../domain/services/certification-cpf-service.js'); -const certificationResultRepository = require('../../infrastructure/repositories/certification-result-repository.js'); -const challengeRepository = require('../../infrastructure/repositories/challenge-repository.js'); -const challengeForPixAutoAnswerRepository = require('../../infrastructure/repositories/challenge-for-pix-auto-answer-repository.js'); -const cleaCertifiedCandidateRepository = require('../../infrastructure/repositories/clea-certified-candidate-repository.js'); -const competenceEvaluationRepository = require('../../infrastructure/repositories/competence-evaluation-repository.js'); -const competenceMarkRepository = require('../../infrastructure/repositories/competence-mark-repository.js'); -const competenceRepository = require('../../infrastructure/repositories/competence-repository.js'); -const competenceTreeRepository = require('../../infrastructure/repositories/competence-tree-repository.js'); -const complementaryCertificationHabilitationRepository = require('../../infrastructure/repositories/complementary-certification-habilitation-repository.js'); -const complementaryCertificationRepository = require('../../infrastructure/repositories/complementary-certification-repository.js'); -const complementaryCertificationSubscriptionRepository = require('../../infrastructure/repositories/complementary-certification-subscription-repository.js'); -const complementaryCertificationCourseResultRepository = require('../../infrastructure/repositories/complementary-certification-course-result-repository.js'); -const correctionRepository = require('../../infrastructure/repositories/correction-repository.js'); -const countryRepository = require('../../infrastructure/repositories/country-repository.js'); -const courseRepository = require('../../infrastructure/repositories/course-repository.js'); -const cpfCertificationResultRepository = require('../../infrastructure/repositories/cpf-certification-result-repository.js'); -const dataProtectionOfficerRepository = require('../../infrastructure/repositories/data-protection-officer-repository.js'); -const divisionRepository = require('../../infrastructure/repositories/division-repository.js'); -const encryptionService = require('../../domain/services/encryption-service.js'); -const flashAssessmentResultRepository = require('../../infrastructure/repositories/flash-assessment-result-repository.js'); -const flashAlgorithmService = require('../../domain/services/algorithm-methods/flash.js'); -const frameworkRepository = require('../../infrastructure/repositories/framework-repository.js'); -const getCompetenceLevel = require('../../domain/services/get-competence-level.js'); -const sessionForSupervisorKitRepository = require('../../infrastructure/repositories/sessions/session-for-supervisor-kit-repository.js'); -const groupRepository = require('../../infrastructure/repositories/group-repository.js'); -const finalizedSessionRepository = require('../../infrastructure/repositories/sessions/finalized-session-repository.js'); -const supOrganizationLearnerRepository = require('../../infrastructure/repositories/sup-organization-learner-repository.js'); -const improvementService = require('../../domain/services/improvement-service.js'); -const issueReportCategoryRepository = require('../../infrastructure/repositories/issue-report-category-repository.js'); -const juryCertificationRepository = require('../../infrastructure/repositories/jury-certification-repository.js'); -const juryCertificationSummaryRepository = require('../../infrastructure/repositories/jury-certification-summary-repository.js'); -const jurySessionRepository = require('../../infrastructure/repositories/sessions/jury-session-repository.js'); -const knowledgeElementRepository = require('../../infrastructure/repositories/knowledge-element-repository.js'); -const learningContentRepository = require('../../infrastructure/repositories/learning-content-repository.js'); -const localeService = require('../../domain/services/locale-service.js'); -const mailService = require('../../domain/services/mail-service.js'); -const membershipRepository = require('../../infrastructure/repositories/membership-repository.js'); -const obfuscationService = require('../../domain/services/obfuscation-service.js'); -const organizationMemberIdentityRepository = require('../../infrastructure/repositories/organization-member-identity-repository.js'); -const organizationForAdminRepository = require('../../infrastructure/repositories/organization-for-admin-repository.js'); -const organizationFeatureRepository = require('../../infrastructure/repositories/organizations-administration/organization-feature-repository.js'); -const organizationRepository = require('../../infrastructure/repositories/organization-repository.js'); -const organizationPlacesLotRepository = require('../../infrastructure/repositories/organizations/organization-places-lot-repository.js'); -const organizationPlacesCapacityRepository = require('../../infrastructure/repositories/organization-places-capacity-repository.js'); -const organizationInvitationRepository = require('../../infrastructure/repositories/organization-invitation-repository.js'); -const organizationInvitedUserRepository = require('../../infrastructure/repositories/organization-invited-user-repository.js'); -const organizationTagRepository = require('../../infrastructure/repositories/organization-tag-repository.js'); -const organizationsToAttachToTargetProfileRepository = require('../../infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js'); -const organizationLearnerFollowUpRepository = require('../../infrastructure/repositories/organization-learner-follow-up/organization-learner-repository.js'); -const organizationLearnerRepository = require('../../infrastructure/repositories/organization-learner-repository.js'); -const organizationParticipantRepository = require('../../infrastructure/repositories/organization-participant-repository.js'); -const organizationLearnerActivityRepository = require('../../infrastructure/repositories/organization-learner-activity-repository.js'); -const organizationLearnersCsvService = require('../../domain/services/organization-learners-csv-service.js'); -const organizationLearnersXmlService = require('../../domain/services/organization-learners-xml-service.js'); -const participantResultRepository = require('../../infrastructure/repositories/participant-result-repository.js'); -const participationsForCampaignManagementRepository = require('../../infrastructure/repositories/participations-for-campaign-management-repository.js'); -const participationsForUserManagementRepository = require('../../infrastructure/repositories/participations-for-user-management-repository.js'); -const userOrganizationsForAdminRepository = require('../../infrastructure/repositories/user-organizations-for-admin-repository.js'); -const partnerCertificationScoringRepository = require('../../infrastructure/repositories/partner-certification-scoring-repository.js'); -const passwordGenerator = require('../../domain/services/password-generator.js'); -const pickChallengeService = require('../services/pick-challenge-service.js'); -const pixAuthenticationService = require('../../domain/services/authentication/pix-authentication-service.js'); -const placementProfileService = require('../../domain/services/placement-profile-service.js'); -const poleEmploiSendingRepository = require('../../infrastructure/repositories/pole-emploi-sending-repository.js'); -const prescriberRepository = require('../../infrastructure/repositories/prescriber-repository.js'); -const pseudoRandom = require('../../infrastructure/utils/pseudo-random'); -const resetPasswordService = require('../../domain/services/reset-password-service.js'); -const resetPasswordDemandRepository = require('../../infrastructure/repositories/reset-password-demands-repository.js'); -const scoAccountRecoveryService = require('../services/sco-account-recovery-service.js'); -const scoCertificationCandidateRepository = require('../../infrastructure/repositories/sco-certification-candidate-repository.js'); -const scoOrganizationParticipantRepository = require('../../infrastructure/repositories/sco-organization-participant-repository.js'); -const scorecardService = require('../../domain/services/scorecard-service.js'); -const scoringCertificationService = require('../../domain/services/scoring/scoring-certification-service.js'); -const supOrganizationParticipantRepository = require('../../infrastructure/repositories/sup-organization-participant-repository.js'); -const sessionForAttendanceSheetRepository = require('../../infrastructure/repositories/sessions/session-for-attendance-sheet-repository.js'); -const sessionsImportValidationService = require('../../domain/services/sessions-mass-import/sessions-import-validation-service.js'); -const sessionPublicationService = require('../../domain/services/session-publication-service.js'); -const sessionRepository = require('../../infrastructure/repositories/sessions/session-repository.js'); -const sessionForSupervisingRepository = require('../../infrastructure/repositories/sessions/session-for-supervising-repository.js'); -const sessionJuryCommentRepository = require('../../infrastructure/repositories/sessions/session-jury-comment-repository.js'); -const sessionSummaryRepository = require('../../infrastructure/repositories/sessions/session-summary-repository.js'); -const skillRepository = require('../../infrastructure/repositories/skill-repository.js'); -const skillSetRepository = require('../../infrastructure/repositories/skill-set-repository.js'); -const studentRepository = require('../../infrastructure/repositories/student-repository.js'); -const supervisorAccessRepository = require('../../infrastructure/repositories/supervisor-access-repository.js'); -const tagRepository = require('../../infrastructure/repositories/tag-repository.js'); -const TargetProfileForSpecifierRepository = require('../../infrastructure/repositories/campaign/target-profile-for-specifier-repository.js'); -const targetProfileRepository = require('../../infrastructure/repositories/target-profile-repository.js'); -const targetProfileSummaryForAdminRepository = require('../../infrastructure/repositories/target-profile-summary-for-admin-repository.js'); -const targetProfileForUpdateRepository = require('../../infrastructure/repositories/target-profile-for-update-repository.js'); -const targetProfileShareRepository = require('../../infrastructure/repositories/target-profile-share-repository.js'); -const targetProfileForAdminRepository = require('../../infrastructure/repositories/target-profile-for-admin-repository.js'); -const targetProfileTrainingRepository = require('../../infrastructure/repositories/target-profile-training-repository.js'); -const thematicRepository = require('../../infrastructure/repositories/thematic-repository.js'); -const tokenService = require('../../domain/services/token-service.js'); -const refreshTokenService = require('../../domain/services/refresh-token-service.js'); -const trainingRepository = require('../../infrastructure/repositories/training-repository.js'); -const trainingTriggerRepository = require('../../infrastructure/repositories/training-trigger-repository.js'); -const tubeRepository = require('../../infrastructure/repositories/tube-repository.js'); -const tutorialEvaluationRepository = require('../../infrastructure/repositories/tutorial-evaluation-repository.js'); -const tutorialRepository = require('../../infrastructure/repositories/tutorial-repository.js'); -const userEmailRepository = require('../../infrastructure/repositories/user-email-repository.js'); -const userLoginRepository = require('../../infrastructure/repositories/user-login-repository.js'); -const userOrgaSettingsRepository = require('../../infrastructure/repositories/user-orga-settings-repository.js'); -const userRecommendedTrainingRepository = require('../../infrastructure/repositories/user-recommended-training-repository.js'); -const userReconciliationService = require('../services/user-reconciliation-service.js'); -const userToCreateRepository = require('../../infrastructure/repositories/user-to-create-repository.js'); -const userRepository = require('../../infrastructure/repositories/user-repository.js'); -const userService = require('../../domain/services/user-service.js'); -const userSavedTutorialRepository = require('../../infrastructure/repositories/user-saved-tutorial-repository.js'); -const verifyCertificateCodeService = require('../../domain/services/verify-certificate-code-service.js'); -const participantResultsSharedRepository = require('../../infrastructure/repositories/participant-results-shared-repository.js'); -const poleEmploiNotifier = require('../../infrastructure/externals/pole-emploi/pole-emploi-notifier.js'); -const disabledPoleEmploiNotifier = require('../../infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js'); -const organizationInvitationService = require('../services/organization-invitation-service.js'); -const organizationCreationValidator = require('../validators/organization-creation-validator.js'); -const organizationValidator = require('../validators/organization-with-tags-and-target-profiles-script.js'); -const userValidator = require('../validators/user-validator.js'); -const passwordValidator = require('../validators/password-validator.js'); -const stageCollectionRepository = require('../../infrastructure/repositories/user-campaign-results/stage-collection-repository'); -const campaignValidator = require('../validators/campaign-validator.js'); -const learningContentConversionService = require('../services/learning-content/learning-content-conversion-service.js'); -const temporarySessionsStorageForMassImportService = require('../services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service'); -const sessionValidator = require('../validators/session-validator.js'); -const sessionCodeService = require('../services/session-code-service.js'); -const dateUtils = require('../../infrastructure/utils/date-utils.js'); -const campaignCodeGenerator = require('../services/campaigns/campaign-code-generator.js'); -const smartRandom = require('../../domain/services/algorithm-methods/smart-random.js'); -const codeUtils = require('../../infrastructure/utils/code-utils.js'); -const writeOdsUtils = require('../../infrastructure/utils/ods/write-ods-utils.js'); -const readOdsUtils = require('../../infrastructure/utils/ods/read-ods-utils.js'); -const sessionXmlService = require('../../domain/services/session-xml-service.js'); -const dataFetcher = require('../../domain/services/algorithm-methods/data-fetcher.js'); +import { config } from '../../config.js'; +import * as accountRecoveryDemandRepository from '../../infrastructure/repositories/account-recovery-demand-repository.js'; +import * as adminMemberRepository from '../../infrastructure/repositories/admin-member-repository.js'; +// eslint-disable-next-line import/no-duplicates +import * as dataFetcher from '../../domain/services/algorithm-methods/data-fetcher.js'; +// eslint-disable-next-line import/no-duplicates +import * as algorithmDataFetcherService from '../../domain/services/algorithm-methods/data-fetcher.js'; +import * as answerRepository from '../../infrastructure/repositories/answer-repository.js'; +import * as areaRepository from '../../infrastructure/repositories/area-repository.js'; +import * as assessmentRepository from '../../infrastructure/repositories/assessment-repository.js'; +import * as assessmentResultRepository from '../../infrastructure/repositories/assessment-result-repository.js'; +import * as authenticationMethodRepository from '../../infrastructure/repositories/authentication-method-repository.js'; +import * as authenticationServiceRegistry from '../services/authentication/authentication-service-registry.js'; +import * as authenticationSessionService from '../../domain/services/authentication/authentication-session-service.js'; +import * as badgeAcquisitionRepository from '../../infrastructure/repositories/badge-acquisition-repository.js'; +import * as badgeCriteriaRepository from '../../infrastructure/repositories/badge-criteria-repository.js'; +import * as badgeForCalculationRepository from '../../infrastructure/repositories/badge-for-calculation-repository.js'; +import * as badgeRepository from '../../infrastructure/repositories/badge-repository.js'; +import * as campaignAdministrationRepository from '../../infrastructure/repositories/campaigns-administration/campaign-repository.js'; +import * as campaignAnalysisRepository from '../../infrastructure/repositories/campaign-analysis-repository.js'; +import * as campaignAssessmentParticipationRepository from '../../infrastructure/repositories/campaign-assessment-participation-repository.js'; +import * as campaignAssessmentParticipationResultListRepository from '../../infrastructure/repositories/campaign-assessment-participation-result-list-repository.js'; +import * as campaignAssessmentParticipationResultRepository from '../../infrastructure/repositories/campaign-assessment-participation-result-repository.js'; +import * as campaignCreatorRepository from '../../infrastructure/repositories/campaign-creator-repository.js'; +import * as campaignForArchivingRepository from '../../infrastructure/repositories/campaign/campaign-for-archiving-repository.js'; +import { campaignParticipantActivityRepository } from '../../infrastructure/repositories/campaign-participant-activity-repository.js'; +import * as campaignCollectiveResultRepository from '../../infrastructure/repositories/campaign-collective-result-repository.js'; +import * as campaignManagementRepository from '../../infrastructure/repositories/campaign-management-repository.js'; +import * as campaignParticipationInfoRepository from '../../infrastructure/repositories/campaign-participation-info-repository.js'; +import * as campaignParticipantRepository from '../../infrastructure/repositories/campaign-participant-repository.js'; +import * as campaignParticipationOverviewRepository from '../../infrastructure/repositories/campaign-participation-overview-repository.js'; +import * as campaignParticipationRepository from '../../infrastructure/repositories/campaign-participation-repository.js'; +import { campaignParticipationResultRepository } from '../../infrastructure/repositories/campaign-participation-result-repository.js'; +import { CampaignParticipationsStatsRepository as campaignParticipationsStatsRepository } from '../../infrastructure/repositories/campaign-participations-stats-repository.js'; +import * as campaignProfilesCollectionParticipationSummaryRepository from '../../infrastructure/repositories/campaign-profiles-collection-participation-summary-repository.js'; +import * as campaignProfileRepository from '../../infrastructure/repositories/campaign-profile-repository.js'; +import * as campaignReportRepository from '../../infrastructure/repositories/campaign-report-repository.js'; +import * as campaignRepository from '../../infrastructure/repositories/campaign-repository.js'; +import * as campaignToJoinRepository from '../../infrastructure/repositories/campaign-to-join-repository.js'; +import * as campaignCsvExportService from '../../domain/services/campaign-csv-export-service.js'; +import * as certifiableProfileForLearningContentRepository from '../../infrastructure/repositories/certifiable-profile-for-learning-content-repository.js'; +import * as certificateRepository from '../../infrastructure/repositories/certificate-repository.js'; +import * as certificationAssessmentRepository from '../../infrastructure/repositories/certification-assessment-repository.js'; +import * as certificationAttestationPdf from '../../infrastructure/utils/pdf/certification-attestation-pdf.js'; +import * as certificationBadgesService from '../../domain/services/certification-badges-service.js'; +import * as certificationCandidateRepository from '../../infrastructure/repositories/certification-candidate-repository.js'; +import * as certificationCandidateForSupervisingRepository from '../../infrastructure/repositories/certification-candidate-for-supervising-repository.js'; +import * as certificationCandidatesOdsService from '../../domain/services/certification-candidates-ods-service.js'; +import * as certificationCenterInvitationRepository from '../../infrastructure/repositories/certification-center-invitation-repository.js'; +import * as certificationCenterInvitedUserRepository from '../../infrastructure/repositories/certification-center-invited-user-repository.js'; +import * as certificationCenterMembershipRepository from '../../infrastructure/repositories/certification-center-membership-repository.js'; +import * as certificationCenterForAdminRepository from '../../infrastructure/repositories/certification-center-for-admin-repository.js'; +import * as certificationCenterRepository from '../../infrastructure/repositories/certification-center-repository.js'; +import * as certificationChallengeRepository from '../../infrastructure/repositories/certification-challenge-repository.js'; +import * as certificationChallengesService from '../../domain/services/certification-challenges-service.js'; +import * as certificationCourseRepository from '../../infrastructure/repositories/certification-course-repository.js'; +import * as certificationCpfCityRepository from '../../infrastructure/repositories/certification-cpf-city-repository.js'; +import * as certificationCpfCountryRepository from '../../infrastructure/repositories/certification-cpf-country-repository.js'; +import * as certificationIssueReportRepository from '../../infrastructure/repositories/certification-issue-report-repository.js'; +import * as certificationLsRepository from '../../infrastructure/repositories/certification-livret-scolaire-repository.js'; +import * as certificationOfficerRepository from '../../infrastructure/repositories/certification-officer-repository.js'; +import * as certificationPointOfContactRepository from '../../infrastructure/repositories/certification-point-of-contact-repository.js'; +import * as certificationReportRepository from '../../infrastructure/repositories/certification-report-repository.js'; +import * as certificationRepository from '../../infrastructure/repositories/certification-repository.js'; +import * as certificationCpfService from '../../domain/services/certification-cpf-service.js'; +import * as certificationResultRepository from '../../infrastructure/repositories/certification-result-repository.js'; +import * as challengeRepository from '../../infrastructure/repositories/challenge-repository.js'; +import * as challengeForPixAutoAnswerRepository from '../../infrastructure/repositories/challenge-for-pix-auto-answer-repository.js'; +import * as cleaCertifiedCandidateRepository from '../../infrastructure/repositories/clea-certified-candidate-repository.js'; +import * as competenceEvaluationRepository from '../../infrastructure/repositories/competence-evaluation-repository.js'; +import * as competenceMarkRepository from '../../infrastructure/repositories/competence-mark-repository.js'; +import * as competenceRepository from '../../infrastructure/repositories/competence-repository.js'; +import * as competenceTreeRepository from '../../infrastructure/repositories/competence-tree-repository.js'; +import * as complementaryCertificationHabilitationRepository from '../../infrastructure/repositories/complementary-certification-habilitation-repository.js'; +import * as complementaryCertificationRepository from '../../infrastructure/repositories/complementary-certification-repository.js'; +import * as complementaryCertificationSubscriptionRepository from '../../infrastructure/repositories/complementary-certification-subscription-repository.js'; +import * as complementaryCertificationCourseResultRepository from '../../infrastructure/repositories/complementary-certification-course-result-repository.js'; +import * as correctionRepository from '../../infrastructure/repositories/correction-repository.js'; +import * as countryRepository from '../../infrastructure/repositories/country-repository.js'; +import * as courseRepository from '../../infrastructure/repositories/course-repository.js'; +import * as cpfCertificationResultRepository from '../../infrastructure/repositories/cpf-certification-result-repository.js'; +import * as dataProtectionOfficerRepository from '../../infrastructure/repositories/data-protection-officer-repository.js'; +import * as divisionRepository from '../../infrastructure/repositories/division-repository.js'; +import * as encryptionService from '../../domain/services/encryption-service.js'; +import * as flashAssessmentResultRepository from '../../infrastructure/repositories/flash-assessment-result-repository.js'; +import * as flashAlgorithmService from '../../domain/services/algorithm-methods/flash.js'; +import * as frameworkRepository from '../../infrastructure/repositories/framework-repository.js'; +import { getCompetenceLevel } from '../../domain/services/get-competence-level.js'; +import * as sessionForSupervisorKitRepository from '../../infrastructure/repositories/sessions/session-for-supervisor-kit-repository.js'; +import * as groupRepository from '../../infrastructure/repositories/group-repository.js'; +import * as finalizedSessionRepository from '../../infrastructure/repositories/sessions/finalized-session-repository.js'; +import * as supOrganizationLearnerRepository from '../../infrastructure/repositories/sup-organization-learner-repository.js'; +import * as improvementService from '../../domain/services/improvement-service.js'; +import * as issueReportCategoryRepository from '../../infrastructure/repositories/issue-report-category-repository.js'; +import * as juryCertificationRepository from '../../infrastructure/repositories/jury-certification-repository.js'; +import * as juryCertificationSummaryRepository from '../../infrastructure/repositories/jury-certification-summary-repository.js'; +import * as jurySessionRepository from '../../infrastructure/repositories/sessions/jury-session-repository.js'; +import * as knowledgeElementRepository from '../../infrastructure/repositories/knowledge-element-repository.js'; +import * as learningContentRepository from '../../infrastructure/repositories/learning-content-repository.js'; +import * as localeService from '../../domain/services/locale-service.js'; +import * as mailService from '../../domain/services/mail-service.js'; +import * as membershipRepository from '../../infrastructure/repositories/membership-repository.js'; +import * as obfuscationService from '../../domain/services/obfuscation-service.js'; +import * as organizationMemberIdentityRepository from '../../infrastructure/repositories/organization-member-identity-repository.js'; +import * as organizationForAdminRepository from '../../infrastructure/repositories/organization-for-admin-repository.js'; +import * as organizationFeatureRepository from '../../infrastructure/repositories/organizations-administration/organization-feature-repository.js'; +import * as organizationRepository from '../../infrastructure/repositories/organization-repository.js'; +import * as organizationPlacesLotRepository from '../../infrastructure/repositories/organizations/organization-places-lot-repository.js'; +import * as organizationPlacesCapacityRepository from '../../infrastructure/repositories/organization-places-capacity-repository.js'; +import * as organizationInvitationRepository from '../../infrastructure/repositories/organization-invitation-repository.js'; +import * as organizationInvitedUserRepository from '../../infrastructure/repositories/organization-invited-user-repository.js'; +import * as organizationTagRepository from '../../infrastructure/repositories/organization-tag-repository.js'; +import * as organizationsToAttachToTargetProfileRepository from '../../infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js'; +import * as organizationLearnerFollowUpRepository from '../../infrastructure/repositories/organization-learner-follow-up/organization-learner-repository.js'; +import * as organizationLearnerRepository from '../../infrastructure/repositories/organization-learner-repository.js'; +import * as organizationParticipantRepository from '../../infrastructure/repositories/organization-participant-repository.js'; +import * as organizationLearnerActivityRepository from '../../infrastructure/repositories/organization-learner-activity-repository.js'; +import * as organizationLearnersCsvService from '../../domain/services/organization-learners-csv-service.js'; +import * as organizationLearnersXmlService from '../../domain/services/organization-learners-xml-service.js'; +import * as participantResultRepository from '../../infrastructure/repositories/participant-result-repository.js'; +import * as participationsForCampaignManagementRepository from '../../infrastructure/repositories/participations-for-campaign-management-repository.js'; +import * as participationsForUserManagementRepository from '../../infrastructure/repositories/participations-for-user-management-repository.js'; +import * as userOrganizationsForAdminRepository from '../../infrastructure/repositories/user-organizations-for-admin-repository.js'; +import * as partnerCertificationScoringRepository from '../../infrastructure/repositories/partner-certification-scoring-repository.js'; +import * as passwordGenerator from '../../domain/services/password-generator.js'; +import * as pickChallengeService from '../services/pick-challenge-service.js'; +import * as pixAuthenticationService from '../../domain/services/authentication/pix-authentication-service.js'; +import * as placementProfileService from '../../domain/services/placement-profile-service.js'; +import * as poleEmploiSendingRepository from '../../infrastructure/repositories/pole-emploi-sending-repository.js'; +import * as prescriberRepository from '../../infrastructure/repositories/prescriber-repository.js'; +import * as pseudoRandom from '../../infrastructure/utils/pseudo-random.js'; +import * as resetPasswordService from '../../domain/services/reset-password-service.js'; +import * as resetPasswordDemandRepository from '../../infrastructure/repositories/reset-password-demands-repository.js'; +import * as scoAccountRecoveryService from '../services/sco-account-recovery-service.js'; +import * as scoCertificationCandidateRepository from '../../infrastructure/repositories/sco-certification-candidate-repository.js'; +import * as scoOrganizationParticipantRepository from '../../infrastructure/repositories/sco-organization-participant-repository.js'; +import * as scorecardService from '../../domain/services/scorecard-service.js'; +import * as scoringCertificationService from '../../domain/services/scoring/scoring-certification-service.js'; +import * as supOrganizationParticipantRepository from '../../infrastructure/repositories/sup-organization-participant-repository.js'; +import * as sessionForAttendanceSheetRepository from '../../infrastructure/repositories/sessions/session-for-attendance-sheet-repository.js'; +import * as sessionsImportValidationService from '../../domain/services/sessions-mass-import/sessions-import-validation-service.js'; +import * as sessionPublicationService from '../../domain/services/session-publication-service.js'; +import * as sessionRepository from '../../infrastructure/repositories/sessions/session-repository.js'; +import * as sessionForSupervisingRepository from '../../infrastructure/repositories/sessions/session-for-supervising-repository.js'; +import * as sessionJuryCommentRepository from '../../infrastructure/repositories/sessions/session-jury-comment-repository.js'; +import * as sessionSummaryRepository from '../../infrastructure/repositories/sessions/session-summary-repository.js'; +import * as skillRepository from '../../infrastructure/repositories/skill-repository.js'; +import * as skillSetRepository from '../../infrastructure/repositories/skill-set-repository.js'; +import * as studentRepository from '../../infrastructure/repositories/student-repository.js'; +import * as supervisorAccessRepository from '../../infrastructure/repositories/supervisor-access-repository.js'; +import * as tagRepository from '../../infrastructure/repositories/tag-repository.js'; +import * as TargetProfileForSpecifierRepository from '../../infrastructure/repositories/campaign/target-profile-for-specifier-repository.js'; +import * as targetProfileRepository from '../../infrastructure/repositories/target-profile-repository.js'; +import * as targetProfileSummaryForAdminRepository from '../../infrastructure/repositories/target-profile-summary-for-admin-repository.js'; +import * as targetProfileForUpdateRepository from '../../infrastructure/repositories/target-profile-for-update-repository.js'; +import * as targetProfileShareRepository from '../../infrastructure/repositories/target-profile-share-repository.js'; +import * as targetProfileForAdminRepository from '../../infrastructure/repositories/target-profile-for-admin-repository.js'; +import * as targetProfileTrainingRepository from '../../infrastructure/repositories/target-profile-training-repository.js'; +import * as thematicRepository from '../../infrastructure/repositories/thematic-repository.js'; +import { tokenService } from '../../domain/services/token-service.js'; +import * as refreshTokenService from '../../domain/services/refresh-token-service.js'; +import * as trainingRepository from '../../infrastructure/repositories/training-repository.js'; +import * as trainingTriggerRepository from '../../infrastructure/repositories/training-trigger-repository.js'; +import * as tubeRepository from '../../infrastructure/repositories/tube-repository.js'; +import * as tutorialEvaluationRepository from '../../infrastructure/repositories/tutorial-evaluation-repository.js'; +import * as tutorialRepository from '../../infrastructure/repositories/tutorial-repository.js'; +import * as userEmailRepository from '../../infrastructure/repositories/user-email-repository.js'; +import * as userLoginRepository from '../../infrastructure/repositories/user-login-repository.js'; +import * as userOrgaSettingsRepository from '../../infrastructure/repositories/user-orga-settings-repository.js'; +import * as userRecommendedTrainingRepository from '../../infrastructure/repositories/user-recommended-training-repository.js'; +import * as userReconciliationService from '../services/user-reconciliation-service.js'; +import * as userToCreateRepository from '../../infrastructure/repositories/user-to-create-repository.js'; +import * as userRepository from '../../infrastructure/repositories/user-repository.js'; +import * as userService from '../../domain/services/user-service.js'; +import * as userSavedTutorialRepository from '../../infrastructure/repositories/user-saved-tutorial-repository.js'; +import * as verifyCertificateCodeService from '../../domain/services/verify-certificate-code-service.js'; +import { participantResultsSharedRepository } from '../../infrastructure/repositories/participant-results-shared-repository.js'; +import * as poleEmploiNotifier from '../../infrastructure/externals/pole-emploi/pole-emploi-notifier.js'; +import * as disabledPoleEmploiNotifier from '../../infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js'; +import * as organizationInvitationService from '../services/organization-invitation-service.js'; +import * as organizationCreationValidator from '../validators/organization-creation-validator.js'; +import * as organizationValidator from '../validators/organization-with-tags-and-target-profiles-script.js'; +import * as userValidator from '../validators/user-validator.js'; +import * as passwordValidator from '../validators/password-validator.js'; +import * as stageCollectionRepository from '../../infrastructure/repositories/user-campaign-results/stage-collection-repository.js'; +import * as campaignValidator from '../validators/campaign-validator.js'; +import * as learningContentConversionService from '../services/learning-content/learning-content-conversion-service.js'; +import * as temporarySessionsStorageForMassImportService from '../services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service.js'; +import * as sessionValidator from '../validators/session-validator.js'; +import * as sessionCodeService from '../services/session-code-service.js'; +import * as dateUtils from '../../infrastructure/utils/date-utils.js'; +import * as campaignCodeGenerator from '../services/campaigns/campaign-code-generator.js'; +import * as smartRandom from '../../domain/services/algorithm-methods/smart-random.js'; +import * as codeUtils from '../../infrastructure/utils/code-utils.js'; +import * as writeOdsUtils from '../../infrastructure/utils/ods/write-ods-utils.js'; +import * as readOdsUtils from '../../infrastructure/utils/ods/read-ods-utils.js'; +import * as sessionXmlService from '../../domain/services/session-xml-service.js'; function requirePoleEmploiNotifier() { - if (settings.poleEmploi.pushEnabled) { + if (config.poleEmploi.pushEnabled) { return poleEmploiNotifier; } else { return disabledPoleEmploiNotifier; @@ -353,10 +355,10 @@ const dependencies = { sessionSummaryRepository, sessionValidator, smartRandom, - settings, pseudoRandom, readOdsUtils, sessionXmlService, + config, skillRepository, skillSetRepository, studentRepository, @@ -399,294 +401,292 @@ const dependencies = { writeOdsUtils, }; -const { injectDependencies } = require('../../infrastructure/utils/dependency-injection.js'); - -const abortCertificationCourse = require('./abort-certification-course.js'); -const acceptCertificationCenterInvitation = require('./accept-certification-center-invitation.js'); -const acceptOrganizationInvitation = require('./accept-organization-invitation.js'); -const acceptPixCertifTermsOfService = require('./accept-pix-certif-terms-of-service.js'); -const acceptPixLastTermsOfService = require('./accept-pix-last-terms-of-service.js'); -const acceptPixOrgaTermsOfService = require('./accept-pix-orga-terms-of-service.js'); -const addCertificationCandidateToSession = require('./add-certification-candidate-to-session.js'); -const addPixAuthenticationMethodByEmail = require('./add-pix-authentication-method-by-email.js'); -const addTutorialEvaluation = require('./add-tutorial-evaluation.js'); -const addTutorialToUser = require('./add-tutorial-to-user.js'); -const anonymizeUser = require('./anonymize-user.js'); -const archiveCampaign = require('./archive-campaign.js'); -const archiveOrganization = require('./archive-organization.js'); -const assignCertificationOfficerToJurySession = require('./assign-certification-officer-to-jury-session.js'); -const attachOrganizationsFromExistingTargetProfile = require('./attach-organizations-from-existing-target-profile.js'); -const attachOrganizationsToTargetProfile = require('./attach-organizations-to-target-profile.js'); -const attachTargetProfilesToOrganization = require('./attach-target-profiles-to-organization.js'); -const attachTargetProfilesToTraining = require('./attach-target-profiles-to-training.js'); -const authenticateAnonymousUser = require('./authenticate-anonymous-user.js'); -const authenticateApplication = require('./authenticate-application.js'); -const authenticateExternalUser = require('./authenticate-external-user.js'); -const authenticateOidcUser = require('./authentication/authenticate-oidc-user.js'); -const authenticateUser = require('./authenticate-user.js'); -const authorizeCertificationCandidateToResume = require('./authorize-certification-candidate-to-resume.js'); -const authorizeCertificationCandidateToStart = require('./authorize-certification-candidate-to-start.js'); -const beginCampaignParticipationImprovement = require('./begin-campaign-participation-improvement.js'); -const campaignAdministrationArchiveCampaign = require('./campaigns-administration/archive-campaigns.js'); -const cancelCertificationCenterInvitation = require('./cancel-certification-center-invitation.js'); -const cancelCertificationCourse = require('./cancel-certification-course.js'); -const cancelOrganizationInvitation = require('./cancel-organization-invitation.js'); -const changeUserLang = require('./change-user-lang.js'); -const checkScoAccountRecovery = require('./check-sco-account-recovery.js'); -const commentSessionAsJury = require('./comment-session-as-jury.js'); -const completeAssessment = require('./complete-assessment.js'); -const computeCampaignAnalysis = require('./compute-campaign-analysis.js'); -const computeCampaignCollectiveResult = require('./compute-campaign-collective-result.js'); -const computeCampaignParticipationAnalysis = require('./compute-campaign-participation-analysis.js'); -const correctAnswerThenUpdateAssessment = require('./correct-answer-then-update-assessment.js'); -const correctAnswer = require('./correct-answer.js'); -const correctCandidateIdentityInCertificationCourse = require('./correct-candidate-identity-in-certification-course.js'); -const createAccessTokenFromRefreshToken = require('./create-access-token-from-refresh-token.js'); -const createAndReconcileUserToOrganizationLearner = require('./create-and-reconcile-user-to-organization-learner.js'); -const createBadge = require('./create-badge.js'); -const createCampaign = require('./create-campaign.js'); -const createCertificationCenter = require('./create-certification-center.js'); -const createCertificationCenterMembershipByEmail = require('./create-certification-center-membership-by-email.js'); -const createCertificationCenterMembershipForScoOrganizationMember = require('./create-certification-center-membership-for-sco-organization-member.js'); -const createLcmsRelease = require('./create-lcms-release.js'); -const createMembership = require('./create-membership.js'); -const createOidcUser = require('./create-oidc-user.js'); -const createOrUpdateCertificationCenterInvitationForAdmin = require('./create-or-update-certification-center-invitation-for-admin.js'); -const createOrUpdateTrainingTrigger = require('./create-or-update-training-trigger.js'); -const createOrUpdateUserOrgaSettings = require('./create-or-update-user-orga-settings.js'); -const createOrganization = require('./create-organization.js'); -const createOrganizationInvitationByAdmin = require('./create-organization-invitation-by-admin.js'); -const createOrganizationInvitations = require('./create-organization-invitations.js'); -const resendOrganizationInvitation = require('./resend-organization-invitation.js'); -const createOrganizationPlacesLot = require('./create-organization-places-lot.js'); -const createOrganizationsWithTagsAndTargetProfiles = require('./create-organizations-with-tags-and-target-profiles.js'); -const createPasswordResetDemand = require('./create-password-reset-demand.js'); -const createSession = require('./create-session.js'); -const createSessions = require('./sessions-mass-import/create-sessions.js'); -const createTag = require('./create-tag.js'); -const createTargetProfile = require('./create-target-profile.js'); -const createTraining = require('./create-training.js'); -const createUser = require('./create-user.js'); -const createUserAndReconcileToOrganizationLearnerFromExternalUser = require('./create-user-and-reconcile-to-organization-learner-from-external-user.js'); -const deactivateAdminMember = require('./deactivate-admin-member.js'); -const deleteCampaignParticipation = require('./delete-campaign-participation.js'); -const deleteCampaignParticipationForAdmin = require('./delete-campaign-participation-for-admin.js'); -const deleteCertificationIssueReport = require('./delete-certification-issue-report.js'); -const deleteOrganizationPlaceLot = require('./delete-organization-place-lot.js'); -const deleteSession = require('./delete-session.js'); -const deleteSessionJuryComment = require('./delete-session-jury-comment.js'); -const deleteUnassociatedBadge = require('./delete-unassociated-badge.js'); -const deleteUnlinkedCertificationCandidate = require('./delete-unlinked-certification-candidate.js'); -const deneutralizeChallenge = require('./deneutralize-challenge.js'); -const disableCertificationCenterMembership = require('./disable-certification-center-membership.js'); -const disableMembership = require('./disable-membership.js'); -const dissociateUserFromOrganizationLearner = require('./dissociate-user-from-organization-learner.js'); -const endAssessmentBySupervisor = require('./end-assessment-by-supervisor.js'); -const enrolStudentsToSession = require('./enrol-students-to-session.js'); -const finalizeSession = require('./finalize-session.js'); -const findAllTags = require('./find-all-tags.js'); -const findAnswerByAssessment = require('./find-answer-by-assessment.js'); -const findAnswerByChallengeAndAssessment = require('./find-answer-by-challenge-and-assessment.js'); -const findAssessmentParticipationResultList = require('./find-assessment-participation-result-list.js'); -const findAssociationBetweenUserAndOrganizationLearner = require('./find-association-between-user-and-organization-learner.js'); -const findCampaignParticipationTrainings = require('./find-campaign-participation-trainings.js'); -const findCampaignParticipationsForUserManagement = require('./find-campaign-participations-for-user-management.js'); -const findCampaignProfilesCollectionParticipationSummaries = require('./find-campaign-profiles-collection-participation-summaries.js'); -const findCertificationAttestationsForDivision = require('./certificate/find-certification-attestations-for-division.js'); -const findCertificationCenterMembershipsByCertificationCenter = require('./find-certification-center-memberships-by-certification-center.js'); -const findCertificationCenterMembershipsByUser = require('./find-certification-center-memberships-by-user.js'); -const findCompetenceEvaluationsByAssessment = require('./find-competence-evaluations-by-assessment.js'); -const findComplementaryCertifications = require('./find-complementary-certifications.js'); -const findCountries = require('./find-countries.js'); -const findDivisionsByCertificationCenter = require('./find-divisions-by-certification-center.js'); -const findDivisionsByOrganization = require('./find-divisions-by-organization.js'); -const findFinalizedSessionsToPublish = require('./find-finalized-sessions-to-publish.js'); -const findFinalizedSessionsWithRequiredAction = require('./find-finalized-sessions-with-required-action.js'); -const findGroupsByOrganization = require('./find-groups-by-organization.js'); -const findLatestOngoingUserCampaignParticipations = require('./find-latest-ongoing-user-campaign-participations.js'); -const findOrganizationPlacesLot = require('./find-organization-places-lot.js'); -const findOrganizationTargetProfileSummariesForAdmin = require('./find-organization-target-profile-summaries-for-admin.js'); -const findPaginatedCampaignManagements = require('./find-paginated-campaign-managements.js'); -const findPaginatedCampaignParticipantsActivities = require('./find-paginated-campaign-participants-activities.js'); -const findPaginatedCertificationCenterSessionSummaries = require('./find-paginated-certification-center-session-summaries.js'); -const findPaginatedFilteredCertificationCenters = require('./find-paginated-filtered-certification-centers.js'); -const findPaginatedFilteredOrganizationCampaigns = require('./find-paginated-filtered-organization-campaigns.js'); -const findPaginatedFilteredOrganizationMemberships = require('./find-paginated-filtered-organization-memberships.js'); -const findPaginatedFilteredOrganizations = require('./find-paginated-filtered-organizations.js'); -const findPaginatedFilteredScoParticipants = require('./find-paginated-filtered-sco-participants.js'); -const findPaginatedFilteredSupParticipants = require('./find-paginated-filtered-sup-participants.js'); -const findPaginatedFilteredTargetProfileOrganizations = require('./find-paginated-filtered-target-profile-organizations.js'); -const findPaginatedFilteredTargetProfileSummariesForAdmin = require('./find-paginated-filtered-target-profile-summaries-for-admin.js'); -const findPaginatedFilteredTutorials = require('./find-paginated-filtered-tutorials.js'); -const findPaginatedFilteredUsers = require('./find-paginated-filtered-users.js'); -const findPaginatedParticipationsForCampaignManagement = require('./find-paginated-participations-for-campaign-management.js'); -const findPaginatedTargetProfileTrainingSummaries = require('./find-paginated-target-profile-training-summaries.js'); -const findPaginatedTrainingSummaries = require('./find-paginated-training-summaries.js'); -const findPaginatedUserRecommendedTrainings = require('./find-paginated-user-recommended-trainings.js'); -const findPendingCertificationCenterInvitations = require('./find-pending-certification-center-invitations.js'); -const findPendingOrganizationInvitations = require('./find-pending-organization-invitations.js'); -const findStudentsForEnrolment = require('./find-students-for-enrolment.js'); -const findTargetProfileSummariesForTraining = require('./find-target-profile-summaries-for-training.js'); -const findTutorials = require('./find-tutorials.js'); -const findUserAuthenticationMethods = require('./find-user-authentication-methods.js'); -const findUserCampaignParticipationOverviews = require('./find-user-campaign-participation-overviews.js'); -const findUserForOidcReconciliation = require('./find-user-for-oidc-reconciliation.js'); -const findUserOrganizationsForAdmin = require('./find-user-organizations-for-admin.js'); -const findUserPrivateCertificates = require('./find-user-private-certificates.js'); -const flagSessionResultsAsSentToPrescriber = require('./flag-session-results-as-sent-to-prescriber.js'); -const generateUsername = require('./generate-username.js'); -const generateUsernameWithTemporaryPassword = require('./generate-username-with-temporary-password.js'); -const getAccountRecoveryDetails = require('./account-recovery/get-account-recovery-details.js'); -const getAdminMemberDetails = require('./get-admin-member-details.js'); -const getAdminMembers = require('./get-admin-members.js'); -const getAnswer = require('./get-answer.js'); -const getAssessment = require('./get-assessment.js'); -const getAttendanceSheet = require('./get-attendance-sheet.js'); -const getAvailableTargetProfilesForOrganization = require('./get-available-target-profiles-for-organization.js'); -const getCampaign = require('./get-campaign.js'); -const getCampaignAssessmentParticipation = require('./get-campaign-assessment-participation.js'); -const getCampaignAssessmentParticipationResult = require('./get-campaign-assessment-participation-result.js'); -const getCampaignByCode = require('./get-campaign-by-code.js'); -const getCampaignDetailsManagement = require('./get-campaign-details-management.js'); -const getCampaignParticipationsActivityByDay = require('./get-campaign-participations-activity-by-day.js'); -const getCampaignParticipationsCountByStage = require('./get-campaign-participations-counts-by-stage.js'); -const getCampaignParticipationsCountsByStatus = require('./get-campaign-participations-counts-by-status.js'); -const getCampaignProfile = require('./get-campaign-profile.js'); -const getCandidateImportSheetData = require('./get-candidate-import-sheet-data.js'); -const getCertificationAttestation = require('./certificate/get-certification-attestation.js'); -const getCertificationCandidate = require('./get-certification-candidate.js'); -const getCertificationCandidateSubscription = require('./get-certification-candidate-subscription.js'); -const getCertificationCenter = require('./get-certification-center.js'); -const getCertificationCenterForAdmin = require('./get-certification-center-for-admin.js'); -const getCertificationCenterInvitation = require('./get-certification-center-invitation.js'); -const getCertificationCourse = require('./get-certification-course.js'); -const getCertificationDetails = require('./get-certification-details.js'); -const getCertificationPointOfContact = require('./get-certification-point-of-contact.js'); -const getCertificationsResultsForLS = require('./certificate/get-certifications-results-for-ls.js'); -const getChallengeForPixAutoAnswer = require('./get-challenge-for-pix-auto-answer.js'); -const getCleaCertifiedCandidateBySession = require('./get-clea-certified-candidate-by-session.js'); -const getCorrectionForAnswer = require('./get-correction-for-answer.js'); -const getCurrentUser = require('./get-current-user.js'); -const getExternalAuthenticationRedirectionUrl = require('./get-external-authentication-redirection-url.js'); -const getFrameworkAreas = require('./get-framework-areas.js'); -const getFrameworks = require('./get-frameworks.js'); -const getIdentityProviders = require('./get-identity-providers.js'); -const getImportSessionComplementaryCertificationHabilitationsLabels = require('./get-import-session-complementary-certification-habilitations-labels.js'); -const getJuryCertification = require('./get-jury-certification.js'); -const getJurySession = require('./get-jury-session.js'); -const getLastChallengeIdFromAssessmentId = require('./get-last-challenge-id-from-assessment-id.js'); -const getLearningContentByTargetProfile = require('./get-learning-content-by-target-profile.js'); -const getLearningContentForTargetProfileSubmission = require('./get-learning-content-for-target-profile-submission.js'); -const getNextChallengeForCampaignAssessment = require('./get-next-challenge-for-campaign-assessment.js'); -const getNextChallengeForCertification = require('./get-next-challenge-for-certification.js'); -const getNextChallengeForCompetenceEvaluation = require('./get-next-challenge-for-competence-evaluation.js'); -const getNextChallengeForDemo = require('./get-next-challenge-for-demo.js'); -const getNextChallengeForPreview = require('./get-next-challenge-for-preview.js'); -const getOrganizationInvitation = require('./get-organization-invitation.js'); -const getOrganizationLearner = require('./get-organization-learner.js'); -const getOrganizationLearnerActivity = require('./get-organization-learner-activity.js'); -const getOrganizationLearnersCsvTemplate = require('./get-organization-learners-csv-template.js'); -const getOrganizationMemberIdentities = require('./get-organization-members-identity.js'); -const getOrganizationPlacesCapacity = require('./get-organization-places-capacity.js'); -const getPaginatedParticipantsForAnOrganization = require('./get-paginated-participants-for-an-organization.js'); -const getParticipantsDivision = require('./get-participants-division.js'); -const getParticipantsGroup = require('./get-participants-group.js'); -const getParticipationsCountByMasteryRate = require('./get-participations-count-by-mastery-rate.js'); -const getPoleEmploiSendings = require('./get-pole-emploi-sendings.js'); -const getPrescriber = require('./get-prescriber.js'); -const getPrivateCertificate = require('./certificate/get-private-certificate.js'); -const getProgression = require('./get-progression.js'); -const getRecentlyUsedTags = require('./get-recently-used-tags.js'); -const getScoCertificationResultsByDivision = require('./get-sco-certification-results-by-division.js'); -const getScorecard = require('./get-scorecard.js'); -const getSession = require('./get-session.js'); -const getSessionCertificationCandidates = require('./get-session-certification-candidates.js'); -const getSessionCertificationReports = require('./get-session-certification-reports.js'); -const getSessionForSupervising = require('./get-session-for-supervising.js'); -const getSessionResults = require('./get-session-results.js'); -const getSessionResultsByResultRecipientEmail = require('./get-session-results-by-result-recipient-email.js'); -const getShareableCertificate = require('./certificate/get-shareable-certificate.js'); -const getSupervisorKitSessionInfo = require('./get-supervisor-kit-session-info.js'); -const getTargetProfileContentAsJson = require('./get-target-profile-content-as-json.js'); -const getTargetProfileForAdmin = require('./get-target-profile-for-admin.js'); -const getTraining = require('./get-training.js'); -const getUserByResetPasswordDemand = require('./get-user-by-reset-password-demand.js'); -const getUserCampaignAssessmentResult = require('./get-user-campaign-assessment-result.js'); -const getUserCampaignParticipationToCampaign = require('./get-user-campaign-participation-to-campaign.js'); -const getUserCertificationEligibility = require('./get-user-certification-eligibility.js'); -const getUserDetailsForAdmin = require('./get-user-details-for-admin.js'); -const getUserProfile = require('./get-user-profile.js'); -const getUserProfileSharedForCampaign = require('./get-user-profile-shared-for-campaign.js'); -const handleBadgeAcquisition = require('./handle-badge-acquisition.js'); -const handleTrainingRecommendation = require('./handle-training-recommendation.js'); -const importCertificationCandidatesFromCandidatesImportSheet = require('./import-certification-candidates-from-candidates-import-sheet.js'); -const importOrganizationLearnersFromSIECLEFormat = require('./import-organization-learners-from-siecle.js'); -const importSupOrganizationLearners = require('./import-sup-organization-learners.js'); -const improveCompetenceEvaluation = require('./improve-competence-evaluation.js'); -const linkUserToSessionCertificationCandidate = require('./link-user-to-session-certification-candidate.js'); -const manuallyResolveCertificationIssueReport = require('./manually-resolve-certification-issue-report.js'); -const markTargetProfileAsSimplifiedAccess = require('./mark-target-profile-as-simplified-access.js'); -const neutralizeChallenge = require('./neutralize-challenge.js'); -const outdateTargetProfile = require('./outdate-target-profile.js'); -const publishSession = require('./publish-session.js'); -const publishSessionsInBatch = require('./publish-sessions-in-batch.js'); -const reassignAuthenticationMethodToAnotherUser = require('./reassign-authentication-method-to-another-user.js'); -const reconcileOidcUser = require('./reconcile-oidc-user.js'); -const reconcileScoOrganizationLearnerAutomatically = require('./reconcile-sco-organization-learner-automatically.js'); -const reconcileScoOrganizationLearnerManually = require('./reconcile-sco-organization-learner-manually.js'); -const reconcileSupOrganizationLearner = require('./reconcile-sup-organization-learner.js'); -const rememberUserHasSeenAssessmentInstructions = require('./remember-user-has-seen-assessment-instructions.js'); -const rememberUserHasSeenChallengeTooltip = require('./remember-user-has-seen-challenge-tooltip.js'); -const rememberUserHasSeenLastDataProtectionPolicyInformation = require('./remember-user-has-seen-last-data-protection-policy-information.js'); -const rememberUserHasSeenNewDashboardInfo = require('./remember-user-has-seen-new-dashboard-info.js'); -const removeAuthenticationMethod = require('./remove-authentication-method.js'); -const replaceSupOrganizationLearners = require('./replace-sup-organization-learner.js'); -const resetScorecard = require('./reset-scorecard.js'); -const retrieveLastOrCreateCertificationCourse = require('./retrieve-last-or-create-certification-course.js'); -const revokeRefreshToken = require('./revoke-refresh-token.js'); -const saveAdminMember = require('./save-admin-member.js'); -const saveCertificationIssueReport = require('./save-certification-issue-report.js'); -const saveComputedCampaignParticipationResult = require('./save-computed-campaign-participation-result.js'); -const saveJuryComplementaryCertificationCourseResult = require('./save-jury-complementary-certification-course-result.js'); -const sendEmailForAccountRecovery = require('./account-recovery/send-email-for-account-recovery.js'); -const sendScoInvitation = require('./send-sco-invitation.js'); -const sendSharedParticipationResultsToPoleEmploi = require('./send-shared-participation-results-to-pole-emploi.js'); -const sendVerificationCode = require('./send-verification-code.js'); -const shareCampaignResult = require('./share-campaign-result.js'); -const simulateFlashScoring = require('./simulate-flash-scoring.js'); -const simulateOldScoring = require('./simulate-old-scoring.js'); -const startCampaignParticipation = require('./start-campaign-participation.js'); -const startOrResumeCompetenceEvaluation = require('./start-or-resume-competence-evaluation.js'); -const startWritingCampaignAssessmentResultsToStream = require('./start-writing-campaign-assessment-results-to-stream.js'); -const startWritingCampaignProfilesCollectionResultsToStream = require('./start-writing-campaign-profiles-collection-results-to-stream.js'); -const superviseSession = require('./supervise-session.js'); -const unarchiveCampaign = require('./unarchive-campaign.js'); -const unblockUserAccount = require('./unblock-user-account.js'); -const uncancelCertificationCourse = require('./uncancel-certification-course.js'); -const unpublishSession = require('./unpublish-session.js'); -const updateAdminMember = require('./update-admin-member.js'); -const updateBadge = require('./update-badge.js'); -const updateCampaign = require('./update-campaign.js'); -const updateCampaignDetailsManagement = require('./update-campaign-details-management.js'); -const updateCertificationCenter = require('./update-certification-center.js'); -const updateCertificationCenterReferer = require('./update-certification-center-referer.js'); -const updateExpiredPassword = require('./update-expired-password.js'); -const updateLastQuestionState = require('./update-last-question-state.js'); -const updateMembership = require('./update-membership.js'); -const updateOrganizationLearnerDependentUserPassword = require('./update-organization-learner-dependent-user-password.js'); -const updateParticipantExternalId = require('./update-participant-external-id.js'); -const updateSession = require('./update-session.js'); -const updateStudentNumber = require('./update-student-number.js'); -const updateTargetProfile = require('./update-target-profile.js'); -const updateTraining = require('./update-training.js'); -const updateUserDetailsForAdministration = require('./update-user-details-for-administration.js'); -const updateUserEmailWithValidation = require('./update-user-email-with-validation.js'); -const updateUserForAccountRecovery = require('./account-recovery/update-user-for-account-recovery.js'); -const updateUserPassword = require('./update-user-password.js'); -const validateSessions = require('./sessions-mass-import/validate-sessions.js'); -// organization-administration -const getOrganizationDetails = require('./organizations-administration/get-organization-details.js'); -const updateOrganizationInformation = require('./organizations-administration/update-organization.js'); +import { injectDependencies } from '../../infrastructure/utils/dependency-injection.js'; +import { abortCertificationCourse } from './abort-certification-course.js'; +import { acceptCertificationCenterInvitation } from './accept-certification-center-invitation.js'; +import { acceptOrganizationInvitation } from './accept-organization-invitation.js'; +import { acceptPixCertifTermsOfService } from './accept-pix-certif-terms-of-service.js'; +import { acceptPixLastTermsOfService } from './accept-pix-last-terms-of-service.js'; +import { acceptPixOrgaTermsOfService } from './accept-pix-orga-terms-of-service.js'; +import { addCertificationCandidateToSession } from './add-certification-candidate-to-session.js'; +import { addPixAuthenticationMethodByEmail } from './add-pix-authentication-method-by-email.js'; +import { addTutorialEvaluation } from './add-tutorial-evaluation.js'; +import { addTutorialToUser } from './add-tutorial-to-user.js'; +import { anonymizeUser } from './anonymize-user.js'; +import { archiveCampaign } from './archive-campaign.js'; +import { archiveOrganization } from './archive-organization.js'; +import { assignCertificationOfficerToJurySession } from './assign-certification-officer-to-jury-session.js'; +import { attachOrganizationsFromExistingTargetProfile } from './attach-organizations-from-existing-target-profile.js'; +import { attachOrganizationsToTargetProfile } from './attach-organizations-to-target-profile.js'; +import { attachTargetProfilesToOrganization } from './attach-target-profiles-to-organization.js'; +import { attachTargetProfilesToTraining } from './attach-target-profiles-to-training.js'; +import { authenticateAnonymousUser } from './authenticate-anonymous-user.js'; +import { authenticateApplication } from './authenticate-application.js'; +import { authenticateExternalUser } from './authenticate-external-user.js'; +import { authenticateOidcUser } from './authentication/authenticate-oidc-user.js'; +import { authenticateUser } from './authenticate-user.js'; +import { authorizeCertificationCandidateToResume } from './authorize-certification-candidate-to-resume.js'; +import { authorizeCertificationCandidateToStart } from './authorize-certification-candidate-to-start.js'; +import { beginCampaignParticipationImprovement } from './begin-campaign-participation-improvement.js'; +import { archiveCampaigns } from './campaigns-administration/archive-campaigns.js'; +import { cancelCertificationCenterInvitation } from './cancel-certification-center-invitation.js'; +import { cancelCertificationCourse } from './cancel-certification-course.js'; +import { cancelOrganizationInvitation } from './cancel-organization-invitation.js'; +import { changeUserLang } from './change-user-lang.js'; +import { checkScoAccountRecovery } from './check-sco-account-recovery.js'; +import { commentSessionAsJury } from './comment-session-as-jury.js'; +import { completeAssessment } from './complete-assessment.js'; +import { computeCampaignAnalysis } from './compute-campaign-analysis.js'; +import { computeCampaignCollectiveResult } from './compute-campaign-collective-result.js'; +import { computeCampaignParticipationAnalysis } from './compute-campaign-participation-analysis.js'; +import { correctAnswerThenUpdateAssessment } from './correct-answer-then-update-assessment.js'; +import { correctAnswer } from './correct-answer.js'; +import { correctCandidateIdentityInCertificationCourse } from './correct-candidate-identity-in-certification-course.js'; +import { createAccessTokenFromRefreshToken } from './create-access-token-from-refresh-token.js'; +import { createAndReconcileUserToOrganizationLearner } from './create-and-reconcile-user-to-organization-learner.js'; +import { createBadge } from './create-badge.js'; +import { createCampaign } from './create-campaign.js'; +import { createCertificationCenter } from './create-certification-center.js'; +import { createCertificationCenterMembershipByEmail } from './create-certification-center-membership-by-email.js'; +import { createCertificationCenterMembershipForScoOrganizationMember } from './create-certification-center-membership-for-sco-organization-member.js'; +import { createLcmsRelease } from './create-lcms-release.js'; +import { createMembership } from './create-membership.js'; +import { createOidcUser } from './create-oidc-user.js'; +import { createOrUpdateCertificationCenterInvitationForAdmin } from './create-or-update-certification-center-invitation-for-admin.js'; +import { createOrUpdateTrainingTrigger } from './create-or-update-training-trigger.js'; +import { createOrUpdateUserOrgaSettings } from './create-or-update-user-orga-settings.js'; +import { createOrganization } from './create-organization.js'; +import { createOrganizationInvitationByAdmin } from './create-organization-invitation-by-admin.js'; +import { createOrganizationInvitations } from './create-organization-invitations.js'; +import { resendOrganizationInvitation } from './resend-organization-invitation.js'; +import { createOrganizationPlacesLot } from './create-organization-places-lot.js'; +import { createOrganizationsWithTagsAndTargetProfiles } from './create-organizations-with-tags-and-target-profiles.js'; +import { createPasswordResetDemand } from './create-password-reset-demand.js'; +import { createSession } from './create-session.js'; +import { createSessions } from './sessions-mass-import/create-sessions.js'; +import { createTag } from './create-tag.js'; +import { createTargetProfile } from './create-target-profile.js'; +import { createTraining } from './create-training.js'; +import { createUser } from './create-user.js'; +import { createUserAndReconcileToOrganizationLearnerFromExternalUser } from './create-user-and-reconcile-to-organization-learner-from-external-user.js'; +import { deactivateAdminMember } from './deactivate-admin-member.js'; +import { deleteCampaignParticipation } from './delete-campaign-participation.js'; +import { deleteCampaignParticipationForAdmin } from './delete-campaign-participation-for-admin.js'; +import { deleteCertificationIssueReport } from './delete-certification-issue-report.js'; +import { deleteOrganizationPlaceLot } from './delete-organization-place-lot.js'; +import { deleteSession } from './delete-session.js'; +import { deleteSessionJuryComment } from './delete-session-jury-comment.js'; +import { deleteUnassociatedBadge } from './delete-unassociated-badge.js'; +import { deleteUnlinkedCertificationCandidate } from './delete-unlinked-certification-candidate.js'; +import { deneutralizeChallenge } from './deneutralize-challenge.js'; +import { disableCertificationCenterMembership } from './disable-certification-center-membership.js'; +import { disableMembership } from './disable-membership.js'; +import { dissociateUserFromOrganizationLearner } from './dissociate-user-from-organization-learner.js'; +import { endAssessmentBySupervisor } from './end-assessment-by-supervisor.js'; +import { enrolStudentsToSession } from './enrol-students-to-session.js'; +import { finalizeSession } from './finalize-session.js'; +import { findAllTags } from './find-all-tags.js'; +import { findAnswerByAssessment } from './find-answer-by-assessment.js'; +import { findAnswerByChallengeAndAssessment } from './find-answer-by-challenge-and-assessment.js'; +import { findAssessmentParticipationResultList } from './find-assessment-participation-result-list.js'; +import { findAssociationBetweenUserAndOrganizationLearner } from './find-association-between-user-and-organization-learner.js'; +import { findCampaignParticipationTrainings } from './find-campaign-participation-trainings.js'; +import { findCampaignParticipationsForUserManagement } from './find-campaign-participations-for-user-management.js'; +import { findCampaignProfilesCollectionParticipationSummaries } from './find-campaign-profiles-collection-participation-summaries.js'; +import { findCertificationAttestationsForDivision } from './certificate/find-certification-attestations-for-division.js'; +import { findCertificationCenterMembershipsByCertificationCenter } from './find-certification-center-memberships-by-certification-center.js'; +import { findCertificationCenterMembershipsByUser } from './find-certification-center-memberships-by-user.js'; +import { findCompetenceEvaluationsByAssessment } from './find-competence-evaluations-by-assessment.js'; +import { findComplementaryCertifications } from './find-complementary-certifications.js'; +import { findCountries } from './find-countries.js'; +import { findDivisionsByCertificationCenter } from './find-divisions-by-certification-center.js'; +import { findDivisionsByOrganization } from './find-divisions-by-organization.js'; +import { findFinalizedSessionsToPublish } from './find-finalized-sessions-to-publish.js'; +import { findFinalizedSessionsWithRequiredAction } from './find-finalized-sessions-with-required-action.js'; +import { findGroupsByOrganization } from './find-groups-by-organization.js'; +import { findLatestOngoingUserCampaignParticipations } from './find-latest-ongoing-user-campaign-participations.js'; +import { findOrganizationPlacesLot } from './find-organization-places-lot.js'; +import { findOrganizationTargetProfileSummariesForAdmin } from './find-organization-target-profile-summaries-for-admin.js'; +import { findPaginatedCampaignManagements } from './find-paginated-campaign-managements.js'; +import { findPaginatedCampaignParticipantsActivities } from './find-paginated-campaign-participants-activities.js'; +import { findPaginatedCertificationCenterSessionSummaries } from './find-paginated-certification-center-session-summaries.js'; +import { findPaginatedFilteredCertificationCenters } from './find-paginated-filtered-certification-centers.js'; +import { findPaginatedFilteredOrganizationCampaigns } from './find-paginated-filtered-organization-campaigns.js'; +import { findPaginatedFilteredOrganizationMemberships } from './find-paginated-filtered-organization-memberships.js'; +import { findPaginatedFilteredOrganizations } from './find-paginated-filtered-organizations.js'; +import { findPaginatedFilteredScoParticipants } from './find-paginated-filtered-sco-participants.js'; +import { findPaginatedFilteredSupParticipants } from './find-paginated-filtered-sup-participants.js'; +import { findTargetProfileOrganizations as findPaginatedFilteredTargetProfileOrganizations } from './find-paginated-filtered-target-profile-organizations.js'; +import { findPaginatedFilteredTargetProfileSummariesForAdmin } from './find-paginated-filtered-target-profile-summaries-for-admin.js'; +import { findPaginatedFilteredTutorials } from './find-paginated-filtered-tutorials.js'; +import { findPaginatedFilteredUsers } from './find-paginated-filtered-users.js'; +import { findPaginatedParticipationsForCampaignManagement } from './find-paginated-participations-for-campaign-management.js'; +import { findPaginatedTargetProfileTrainingSummaries } from './find-paginated-target-profile-training-summaries.js'; +import { findPaginatedTrainingSummaries } from './find-paginated-training-summaries.js'; +import { findPaginatedUserRecommendedTrainings } from './find-paginated-user-recommended-trainings.js'; +import { findPendingCertificationCenterInvitations } from './find-pending-certification-center-invitations.js'; +import { findPendingOrganizationInvitations } from './find-pending-organization-invitations.js'; +import { findStudentsForEnrolment } from './find-students-for-enrolment.js'; +import { findTargetProfileSummariesForTraining } from './find-target-profile-summaries-for-training.js'; +import { findTutorials } from './find-tutorials.js'; +import { findUserAuthenticationMethods } from './find-user-authentication-methods.js'; +import { findUserCampaignParticipationOverviews } from './find-user-campaign-participation-overviews.js'; +import { findUserForOidcReconciliation } from './find-user-for-oidc-reconciliation.js'; +import { findUserOrganizationsForAdmin } from './find-user-organizations-for-admin.js'; +import { findUserPrivateCertificates } from './find-user-private-certificates.js'; +import { flagSessionResultsAsSentToPrescriber } from './flag-session-results-as-sent-to-prescriber.js'; +import { generateUsername } from './generate-username.js'; +import { generateUsernameWithTemporaryPassword } from './generate-username-with-temporary-password.js'; +import { getAccountRecoveryDetails } from './account-recovery/get-account-recovery-details.js'; +import { getAdminMemberDetails } from './get-admin-member-details.js'; +import { getAdminMembers } from './get-admin-members.js'; +import { getAnswer } from './get-answer.js'; +import { getAssessment } from './get-assessment.js'; +import { getAttendanceSheet } from './get-attendance-sheet.js'; +import { getAvailableTargetProfilesForOrganization } from './get-available-target-profiles-for-organization.js'; +import { getCampaign } from './get-campaign.js'; +import { getCampaignAssessmentParticipation } from './get-campaign-assessment-participation.js'; +import { getCampaignAssessmentParticipationResult } from './get-campaign-assessment-participation-result.js'; +import { getCampaignByCode } from './get-campaign-by-code.js'; +import { getCampaignManagement as getCampaignDetailsManagement } from './get-campaign-details-management.js'; +import { getCampaignParticipationsActivityByDay } from './get-campaign-participations-activity-by-day.js'; +import { getCampaignParticipationsCountByStage } from './get-campaign-participations-counts-by-stage.js'; +import { getCampaignParticipationsCountsByStatus } from './get-campaign-participations-counts-by-status.js'; +import { getCampaignProfile } from './get-campaign-profile.js'; +import { getCandidateImportSheetData } from './get-candidate-import-sheet-data.js'; +import { getCertificationAttestation } from './certificate/get-certification-attestation.js'; +import { getCertificationCandidate } from './get-certification-candidate.js'; +import { getCertificationCandidateSubscription } from './get-certification-candidate-subscription.js'; +import { getCertificationCenter } from './get-certification-center.js'; +import { getCertificationCenterForAdmin } from './get-certification-center-for-admin.js'; +import { getCertificationCenterInvitation } from './get-certification-center-invitation.js'; +import { getCertificationCourse } from './get-certification-course.js'; +import { getCertificationDetails } from './get-certification-details.js'; +import { getCertificationPointOfContact } from './get-certification-point-of-contact.js'; +import { getCertificationsResultsForLS } from './certificate/get-certifications-results-for-ls.js'; +import { getChallengeForPixAutoAnswer } from './get-challenge-for-pix-auto-answer.js'; +import { getCleaCertifiedCandidateBySession } from './get-clea-certified-candidate-by-session.js'; +import { getCorrectionForAnswer } from './get-correction-for-answer.js'; +import { getCurrentUser } from './get-current-user.js'; +import { getExternalAuthenticationRedirectionUrl } from './get-external-authentication-redirection-url.js'; +import { getFrameworkAreas } from './get-framework-areas.js'; +import { getFrameworks } from './get-frameworks.js'; +import { getIdentityProviders } from './get-identity-providers.js'; +import { getImportSessionComplementaryCertificationHabilitationsLabels } from './get-import-session-complementary-certification-habilitations-labels.js'; +import { getJuryCertification } from './get-jury-certification.js'; +import { getJurySession } from './get-jury-session.js'; +import { getLastChallengeIdFromAssessmentId } from './get-last-challenge-id-from-assessment-id.js'; +import { getLearningContentByTargetProfile } from './get-learning-content-by-target-profile.js'; +import { getLearningContentForTargetProfileSubmission } from './get-learning-content-for-target-profile-submission.js'; +import { getNextChallengeForCampaignAssessment } from './get-next-challenge-for-campaign-assessment.js'; +import { getNextChallengeForCertification } from './get-next-challenge-for-certification.js'; +import { getNextChallengeForCompetenceEvaluation } from './get-next-challenge-for-competence-evaluation.js'; +import { getNextChallengeForDemo } from './get-next-challenge-for-demo.js'; +import { getNextChallengeForPreview } from './get-next-challenge-for-preview.js'; +import { getOrganizationInvitation } from './get-organization-invitation.js'; +import { getOrganizationLearner } from './get-organization-learner.js'; +import { getOrganizationLearnerActivity } from './get-organization-learner-activity.js'; +import { getOrganizationLearnersCsvTemplate } from './get-organization-learners-csv-template.js'; +import { getOrganizationMemberIdentities } from './get-organization-members-identity.js'; +import { getOrganizationPlacesCapacity } from './get-organization-places-capacity.js'; +import { getPaginatedParticipantsForAnOrganization } from './get-paginated-participants-for-an-organization.js'; +import { getParticipantsDivision } from './get-participants-division.js'; +import { getParticipantsGroup } from './get-participants-group.js'; +import { getParticipationsCountByMasteryRate } from './get-participations-count-by-mastery-rate.js'; +import { getPoleEmploiSendings } from './get-pole-emploi-sendings.js'; +import { getPrescriber } from './get-prescriber.js'; +import { getPrivateCertificate } from './certificate/get-private-certificate.js'; +import { getProgression } from './get-progression.js'; +import { getRecentlyUsedTags } from './get-recently-used-tags.js'; +import { getScoCertificationResultsByDivision } from './get-sco-certification-results-by-division.js'; +import { getScorecard } from './get-scorecard.js'; +import { getSession } from './get-session.js'; +import { getSessionCertificationCandidates } from './get-session-certification-candidates.js'; +import { getSessionCertificationReports } from './get-session-certification-reports.js'; +import { getSessionForSupervising } from './get-session-for-supervising.js'; +import { getSessionResults } from './get-session-results.js'; +import { getSessionResultsByResultRecipientEmail } from './get-session-results-by-result-recipient-email.js'; +import { getShareableCertificate } from './certificate/get-shareable-certificate.js'; +import { getSupervisorKitSessionInfo } from './get-supervisor-kit-session-info.js'; +import { getTargetProfileContentAsJson } from './get-target-profile-content-as-json.js'; +import { getTargetProfileForAdmin } from './get-target-profile-for-admin.js'; +import { getTraining } from './get-training.js'; +import { getUserByResetPasswordDemand } from './get-user-by-reset-password-demand.js'; +import { getUserCampaignAssessmentResult } from './get-user-campaign-assessment-result.js'; +import { getUserCampaignParticipationToCampaign } from './get-user-campaign-participation-to-campaign.js'; +import { getUserCertificationEligibility } from './get-user-certification-eligibility.js'; +import { getUserDetailsForAdmin } from './get-user-details-for-admin.js'; +import { getUserProfile } from './get-user-profile.js'; +import { getUserProfileSharedForCampaign } from './get-user-profile-shared-for-campaign.js'; +import { handleBadgeAcquisition } from './handle-badge-acquisition.js'; +import { handleTrainingRecommendation } from './handle-training-recommendation.js'; +import { importCertificationCandidatesFromCandidatesImportSheet } from './import-certification-candidates-from-candidates-import-sheet.js'; +import { importOrganizationLearnersFromSIECLEFormat } from './import-organization-learners-from-siecle.js'; +import { importSupOrganizationLearners } from './import-sup-organization-learners.js'; +import { improveCompetenceEvaluation } from './improve-competence-evaluation.js'; +import { linkUserToSessionCertificationCandidate } from './link-user-to-session-certification-candidate.js'; +import { manuallyResolveCertificationIssueReport } from './manually-resolve-certification-issue-report.js'; +import { markTargetProfileAsSimplifiedAccess } from './mark-target-profile-as-simplified-access.js'; +import { neutralizeChallenge } from './neutralize-challenge.js'; +import { outdateTargetProfile } from './outdate-target-profile.js'; +import { publishSession } from './publish-session.js'; +import { publishSessionsInBatch } from './publish-sessions-in-batch.js'; +import { reassignAuthenticationMethodToAnotherUser } from './reassign-authentication-method-to-another-user.js'; +import { reconcileOidcUser } from './reconcile-oidc-user.js'; +import { reconcileScoOrganizationLearnerAutomatically } from './reconcile-sco-organization-learner-automatically.js'; +import { reconcileScoOrganizationLearnerManually } from './reconcile-sco-organization-learner-manually.js'; +import { reconcileSupOrganizationLearner } from './reconcile-sup-organization-learner.js'; +import { rememberUserHasSeenAssessmentInstructions } from './remember-user-has-seen-assessment-instructions.js'; +import { rememberUserHasSeenChallengeTooltip } from './remember-user-has-seen-challenge-tooltip.js'; +import { rememberUserHasSeenLastDataProtectionPolicyInformation } from './remember-user-has-seen-last-data-protection-policy-information.js'; +import { rememberUserHasSeenNewDashboardInfo } from './remember-user-has-seen-new-dashboard-info.js'; +import { removeAuthenticationMethod } from './remove-authentication-method.js'; +import { replaceSupOrganizationLearners } from './replace-sup-organization-learner.js'; +import { resetScorecard } from './reset-scorecard.js'; +import { retrieveLastOrCreateCertificationCourse } from './retrieve-last-or-create-certification-course.js'; +import { revokeRefreshToken } from './revoke-refresh-token.js'; +import { saveAdminMember } from './save-admin-member.js'; +import { saveCertificationIssueReport } from './save-certification-issue-report.js'; +import { saveComputedCampaignParticipationResult } from './save-computed-campaign-participation-result.js'; +import { saveJuryComplementaryCertificationCourseResult } from './save-jury-complementary-certification-course-result.js'; +import { sendEmailForAccountRecovery } from './account-recovery/send-email-for-account-recovery.js'; +import { sendScoInvitation } from './send-sco-invitation.js'; +import { sendSharedParticipationResultsToPoleEmploi } from './send-shared-participation-results-to-pole-emploi.js'; +import { sendVerificationCode } from './send-verification-code.js'; +import { shareCampaignResult } from './share-campaign-result.js'; +import { simulateFlashScoring } from './simulate-flash-scoring.js'; +import { simulateOldScoring } from './simulate-old-scoring.js'; +import { startCampaignParticipation } from './start-campaign-participation.js'; +import { startOrResumeCompetenceEvaluation } from './start-or-resume-competence-evaluation.js'; +import { startWritingCampaignAssessmentResultsToStream } from './start-writing-campaign-assessment-results-to-stream.js'; +import { startWritingCampaignProfilesCollectionResultsToStream } from './start-writing-campaign-profiles-collection-results-to-stream.js'; +import { superviseSession } from './supervise-session.js'; +import { unarchiveCampaign } from './unarchive-campaign.js'; +import { unblockUserAccount } from './unblock-user-account.js'; +import { uncancelCertificationCourse } from './uncancel-certification-course.js'; +import { unpublishSession } from './unpublish-session.js'; +import { updateAdminMember } from './update-admin-member.js'; +import { updateBadge } from './update-badge.js'; +import { updateCampaign } from './update-campaign.js'; +import { updateCampaignDetailsManagement } from './update-campaign-details-management.js'; +import { updateCertificationCenter } from './update-certification-center.js'; +import { updateCertificationCenterReferer } from './update-certification-center-referer.js'; +import { updateExpiredPassword } from './update-expired-password.js'; +import { updateLastQuestionState } from './update-last-question-state.js'; +import { updateMembership } from './update-membership.js'; +import { updateOrganizationLearnerDependentUserPassword } from './update-organization-learner-dependent-user-password.js'; +import { updateParticipantExternalId } from './update-participant-external-id.js'; +import { updateSession } from './update-session.js'; +import { updateStudentNumber } from './update-student-number.js'; +import { updateTargetProfile } from './update-target-profile.js'; +import { updateTraining } from './update-training.js'; +import { updateUserDetailsForAdministration } from './update-user-details-for-administration.js'; +import { updateUserEmailWithValidation } from './update-user-email-with-validation.js'; +import { updateUserForAccountRecovery } from './account-recovery/update-user-for-account-recovery.js'; +import { updateUserPassword } from './update-user-password.js'; +import { validateSessions } from './sessions-mass-import/validate-sessions.js'; +import { getOrganizationDetails } from './organizations-administration/get-organization-details.js'; +import { updateOrganizationInformation } from './organizations-administration/update-organization.js'; const usecasesWithoutInjectedDependencies = { abortCertificationCourse, @@ -715,7 +715,7 @@ const usecasesWithoutInjectedDependencies = { authorizeCertificationCandidateToResume, authorizeCertificationCandidateToStart, beginCampaignParticipationImprovement, - campaignAdministrationArchiveCampaign, + archiveCampaigns, cancelCertificationCenterInvitation, cancelCertificationCourse, cancelOrganizationInvitation, @@ -978,4 +978,4 @@ const usecasesWithoutInjectedDependencies = { const usecases = injectDependencies(usecasesWithoutInjectedDependencies, dependencies); -module.exports = usecases; +export { usecases }; diff --git a/api/lib/domain/usecases/link-user-to-session-certification-candidate.js b/api/lib/domain/usecases/link-user-to-session-certification-candidate.js index 01c84c580db..4ee08e72666 100644 --- a/api/lib/domain/usecases/link-user-to-session-certification-candidate.js +++ b/api/lib/domain/usecases/link-user-to-session-certification-candidate.js @@ -1,17 +1,19 @@ -const _ = require('lodash'); -const CertificationCandidate = require('../models/CertificationCandidate.js'); -const { +import _ from 'lodash'; +import { CertificationCandidate } from '../models/CertificationCandidate.js'; + +import { CertificationCandidateByPersonalInfoNotFoundError, MatchingReconciledStudentNotFoundError, CertificationCandidateByPersonalInfoTooManyMatchesError, UserAlreadyLinkedToCandidateInSessionError, SessionNotAccessible, UnexpectedUserAccountError, -} = require('../errors.js'); -const UserLinkedToCertificationCandidate = require('../events/UserLinkedToCertificationCandidate.js'); -const UserAlreadyLinkedToCertificationCandidate = require('../events/UserAlreadyLinkedToCertificationCandidate.js'); +} from '../errors.js'; + +import { UserLinkedToCertificationCandidate } from '../events/UserLinkedToCertificationCandidate.js'; +import { UserAlreadyLinkedToCertificationCandidate } from '../events/UserAlreadyLinkedToCertificationCandidate.js'; -module.exports = async function linkUserToSessionCertificationCandidate({ +const linkUserToSessionCertificationCandidate = async function ({ userId, sessionId, firstName, @@ -71,6 +73,8 @@ module.exports = async function linkUserToSessionCertificationCandidate({ } }; +export { linkUserToSessionCertificationCandidate }; + async function _getSessionCertificationCandidateByPersonalInfo({ sessionId, participatingCertificationCandidate, diff --git a/api/lib/domain/usecases/manually-resolve-certification-issue-report.js b/api/lib/domain/usecases/manually-resolve-certification-issue-report.js index 35b88f53b97..67f249a0d27 100644 --- a/api/lib/domain/usecases/manually-resolve-certification-issue-report.js +++ b/api/lib/domain/usecases/manually-resolve-certification-issue-report.js @@ -1,6 +1,6 @@ -const { CertificationIssueReportAutomaticallyResolvedShouldNotBeUpdatedManually } = require('../errors.js'); +import { CertificationIssueReportAutomaticallyResolvedShouldNotBeUpdatedManually } from '../errors.js'; -module.exports = async function manuallyResolveCertificationIssueReport({ +const manuallyResolveCertificationIssueReport = async function ({ certificationIssueReportId, resolution, certificationIssueReportRepository, @@ -13,3 +13,5 @@ module.exports = async function manuallyResolveCertificationIssueReport({ certificationIssueReport.resolveManually(resolution); await certificationIssueReportRepository.save(certificationIssueReport); }; + +export { manuallyResolveCertificationIssueReport }; diff --git a/api/lib/domain/usecases/mark-target-profile-as-simplified-access.js b/api/lib/domain/usecases/mark-target-profile-as-simplified-access.js index 127e8c7a0f2..08596b4e17e 100644 --- a/api/lib/domain/usecases/mark-target-profile-as-simplified-access.js +++ b/api/lib/domain/usecases/mark-target-profile-as-simplified-access.js @@ -1,3 +1,5 @@ -module.exports = async function markTargetProfileAsSimplifiedAccess({ id, targetProfileRepository }) { +const markTargetProfileAsSimplifiedAccess = async function ({ id, targetProfileRepository }) { return targetProfileRepository.update({ id, isSimplifiedAccess: true }); }; + +export { markTargetProfileAsSimplifiedAccess }; diff --git a/api/lib/domain/usecases/neutralize-challenge.js b/api/lib/domain/usecases/neutralize-challenge.js index b2a850796ec..629a6bd7ac4 100644 --- a/api/lib/domain/usecases/neutralize-challenge.js +++ b/api/lib/domain/usecases/neutralize-challenge.js @@ -1,6 +1,6 @@ -const ChallengeNeutralized = require('../events/ChallengeNeutralized.js'); +import { ChallengeNeutralized } from '../events/ChallengeNeutralized.js'; -module.exports = async function neutralizeChallenge({ +const neutralizeChallenge = async function ({ certificationAssessmentRepository, certificationCourseId, challengeRecId, @@ -13,3 +13,5 @@ module.exports = async function neutralizeChallenge({ await certificationAssessmentRepository.save(certificationAssessment); return new ChallengeNeutralized({ certificationCourseId, juryId }); }; + +export { neutralizeChallenge }; diff --git a/api/lib/domain/usecases/organizations-administration/get-organization-details.js b/api/lib/domain/usecases/organizations-administration/get-organization-details.js index 3a99bafed07..3d5b99e5a12 100644 --- a/api/lib/domain/usecases/organizations-administration/get-organization-details.js +++ b/api/lib/domain/usecases/organizations-administration/get-organization-details.js @@ -1,3 +1,5 @@ -module.exports = function getOrganizationDetails({ organizationId, organizationForAdminRepository }) { +const getOrganizationDetails = function ({ organizationId, organizationForAdminRepository }) { return organizationForAdminRepository.get(organizationId); }; + +export { getOrganizationDetails }; diff --git a/api/lib/domain/usecases/organizations-administration/update-organization.js b/api/lib/domain/usecases/organizations-administration/update-organization.js index 6682ebc001a..9f2f09c6207 100644 --- a/api/lib/domain/usecases/organizations-administration/update-organization.js +++ b/api/lib/domain/usecases/organizations-administration/update-organization.js @@ -1,9 +1,8 @@ -const bluebird = require('bluebird'); -const _ = require('lodash'); -const OrganizationTag = require('../../models/OrganizationTag.js'); -const DataProtectionOfficer = require('../../models/DataProtectionOfficer.js'); - -const apps = require('../../constants.js'); +import bluebird from 'bluebird'; +import _ from 'lodash'; +import { OrganizationTag } from '../../models/OrganizationTag.js'; +import { DataProtectionOfficer } from '../../models/DataProtectionOfficer.js'; +import * as apps from '../../constants.js'; async function _updateOrganizationTags({ organization, @@ -32,7 +31,7 @@ async function _updateOrganizationTags({ organizationId: organization.id, tagId: tag.id, }); - await organizationTagRepository.delete({ organizationTagId: organizationTag.id }); + await organizationTagRepository.remove({ organizationTagId: organizationTag.id }); }); } } @@ -68,7 +67,7 @@ async function _enablingOrganizationFeature(organization, organizationFeatureRep } } -module.exports = async function updateOrganizationInformation({ +const updateOrganizationInformation = async function ({ organization, dataProtectionOfficerRepository, organizationFeatureRepository, @@ -111,3 +110,5 @@ module.exports = async function updateOrganizationInformation({ return updatedOrganization; }; + +export { updateOrganizationInformation }; diff --git a/api/lib/domain/usecases/outdate-target-profile.js b/api/lib/domain/usecases/outdate-target-profile.js index d34d89a350f..75ffe9b4e4b 100644 --- a/api/lib/domain/usecases/outdate-target-profile.js +++ b/api/lib/domain/usecases/outdate-target-profile.js @@ -1,3 +1,5 @@ -module.exports = async function outdateTargetProfile({ id, targetProfileRepository }) { +const outdateTargetProfile = async function ({ id, targetProfileRepository }) { await targetProfileRepository.update({ id, outdated: true }); }; + +export { outdateTargetProfile }; diff --git a/api/lib/domain/usecases/publish-session.js b/api/lib/domain/usecases/publish-session.js index 1906e12a36a..d33e0caf39a 100644 --- a/api/lib/domain/usecases/publish-session.js +++ b/api/lib/domain/usecases/publish-session.js @@ -1,4 +1,4 @@ -module.exports = async function publishSession({ +const publishSession = async function ({ i18n, sessionId, certificationRepository, @@ -20,3 +20,5 @@ module.exports = async function publishSession({ return sessionRepository.get(sessionId); }; + +export { publishSession }; diff --git a/api/lib/domain/usecases/publish-sessions-in-batch.js b/api/lib/domain/usecases/publish-sessions-in-batch.js index 68f2c93fb78..e39fd790653 100644 --- a/api/lib/domain/usecases/publish-sessions-in-batch.js +++ b/api/lib/domain/usecases/publish-sessions-in-batch.js @@ -1,7 +1,8 @@ -const { v4: uuidv4 } = require('uuid'); -const { SessionPublicationBatchResult } = require('../models/SessionPublicationBatchResult.js'); +import { v4 as uuidv4 } from 'uuid'; -module.exports = async function publishSessionsInBatch({ +import { SessionPublicationBatchResult } from '../models/SessionPublicationBatchResult.js'; + +const publishSessionsInBatch = async function ({ sessionIds, certificationCenterRepository, certificationRepository, @@ -28,3 +29,5 @@ module.exports = async function publishSessionsInBatch({ } return result; }; + +export { publishSessionsInBatch }; diff --git a/api/lib/domain/usecases/reassign-authentication-method-to-another-user.js b/api/lib/domain/usecases/reassign-authentication-method-to-another-user.js index b05caf09413..984a643345e 100644 --- a/api/lib/domain/usecases/reassign-authentication-method-to-another-user.js +++ b/api/lib/domain/usecases/reassign-authentication-method-to-another-user.js @@ -1,6 +1,6 @@ -const { AuthenticationMethodAlreadyExistsError } = require('../errors.js'); +import { AuthenticationMethodAlreadyExistsError } from '../errors.js'; -module.exports = async function reassignAuthenticationMethodToAnotherUser({ +const reassignAuthenticationMethodToAnotherUser = async function ({ originUserId, targetUserId, authenticationMethodId, @@ -28,6 +28,8 @@ module.exports = async function reassignAuthenticationMethodToAnotherUser({ }); }; +export { reassignAuthenticationMethodToAnotherUser }; + async function _checkIfTargetUserExists({ targetUserId, userRepository }) { await userRepository.get(targetUserId); } diff --git a/api/lib/domain/usecases/reconcile-oidc-user.js b/api/lib/domain/usecases/reconcile-oidc-user.js index cb03321b192..478ee57260e 100644 --- a/api/lib/domain/usecases/reconcile-oidc-user.js +++ b/api/lib/domain/usecases/reconcile-oidc-user.js @@ -1,7 +1,7 @@ -const { AuthenticationKeyExpired, MissingUserAccountError } = require('../errors.js'); -const AuthenticationMethod = require('../models/AuthenticationMethod.js'); +import { AuthenticationKeyExpired, MissingUserAccountError } from '../errors.js'; +import { AuthenticationMethod } from '../models/AuthenticationMethod.js'; -module.exports = async function reconcileOidcUser({ +const reconcileOidcUser = async function ({ authenticationKey, oidcAuthenticationService, authenticationSessionService, @@ -39,3 +39,5 @@ module.exports = async function reconcileOidcUser({ return { accessToken, logoutUrlUUID }; }; + +export { reconcileOidcUser }; diff --git a/api/lib/domain/usecases/reconcile-sco-organization-learner-automatically.js b/api/lib/domain/usecases/reconcile-sco-organization-learner-automatically.js index 532120ec407..7983c0b691f 100644 --- a/api/lib/domain/usecases/reconcile-sco-organization-learner-automatically.js +++ b/api/lib/domain/usecases/reconcile-sco-organization-learner-automatically.js @@ -1,7 +1,7 @@ -const { CampaignCodeError, UserCouldNotBeReconciledError } = require('../../domain/errors.js'); -const _ = require('lodash'); +import { CampaignCodeError, UserCouldNotBeReconciledError } from '../../domain/errors.js'; +import _ from 'lodash'; -module.exports = async function reconcileScoOrganizationLearnerAutomatically({ +const reconcileScoOrganizationLearnerAutomatically = async function ({ campaignCode, userId, campaignRepository, @@ -27,3 +27,5 @@ module.exports = async function reconcileScoOrganizationLearnerAutomatically({ organizationId: campaign.organizationId, }); }; + +export { reconcileScoOrganizationLearnerAutomatically }; diff --git a/api/lib/domain/usecases/reconcile-sco-organization-learner-manually.js b/api/lib/domain/usecases/reconcile-sco-organization-learner-manually.js index 39ea21920ea..7bfbe87707e 100644 --- a/api/lib/domain/usecases/reconcile-sco-organization-learner-manually.js +++ b/api/lib/domain/usecases/reconcile-sco-organization-learner-manually.js @@ -1,12 +1,15 @@ -const { +import { CampaignCodeError, OrganizationLearnerAlreadyLinkedToUserError, UserShouldNotBeReconciledOnAnotherAccountError, -} = require('../errors.js'); -const { STUDENT_RECONCILIATION_ERRORS } = require('../constants.js'); -const isEmpty = require('lodash/isEmpty'); +} from '../errors.js'; -module.exports = async function reconcileScoOrganizationLearnerManually({ +import { STUDENT_RECONCILIATION_ERRORS } from '../constants.js'; +import lodash from 'lodash'; + +const { isEmpty } = lodash; + +const reconcileScoOrganizationLearnerManually = async function ({ campaignCode, reconciliationInfo, withReconciliation, @@ -56,6 +59,8 @@ module.exports = async function reconcileScoOrganizationLearnerManually({ } }; +export { reconcileScoOrganizationLearnerManually }; + async function _checkIfAnotherStudentIsAlreadyReconciledWithTheSameOrganizationAndUser( userId, organizationId, diff --git a/api/lib/domain/usecases/reconcile-sup-organization-learner.js b/api/lib/domain/usecases/reconcile-sup-organization-learner.js index 8407fe24913..dd828b92212 100644 --- a/api/lib/domain/usecases/reconcile-sup-organization-learner.js +++ b/api/lib/domain/usecases/reconcile-sup-organization-learner.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../errors.js'); +import { NotFoundError } from '../errors.js'; -module.exports = async function reconcileSupOrganizationLearner({ +const reconcileSupOrganizationLearner = async function ({ campaignCode, reconciliationInfo: { userId, studentNumber, firstName, lastName, birthdate }, campaignRepository, @@ -25,3 +25,5 @@ module.exports = async function reconcileSupOrganizationLearner({ organizationLearnerId: matchedOrganizationLearner.id, }); }; + +export { reconcileSupOrganizationLearner }; diff --git a/api/lib/domain/usecases/remember-user-has-seen-assessment-instructions.js b/api/lib/domain/usecases/remember-user-has-seen-assessment-instructions.js index 42e9e1295b5..b07d728e80b 100644 --- a/api/lib/domain/usecases/remember-user-has-seen-assessment-instructions.js +++ b/api/lib/domain/usecases/remember-user-has-seen-assessment-instructions.js @@ -1,3 +1,5 @@ -module.exports = function rememberUserHasSeenAssessmentInstructions({ userId, userRepository }) { +const rememberUserHasSeenAssessmentInstructions = function ({ userId, userRepository }) { return userRepository.updateHasSeenAssessmentInstructionsToTrue(userId); }; + +export { rememberUserHasSeenAssessmentInstructions }; diff --git a/api/lib/domain/usecases/remember-user-has-seen-challenge-tooltip.js b/api/lib/domain/usecases/remember-user-has-seen-challenge-tooltip.js index 88527ab0df9..18738ff2d2a 100644 --- a/api/lib/domain/usecases/remember-user-has-seen-challenge-tooltip.js +++ b/api/lib/domain/usecases/remember-user-has-seen-challenge-tooltip.js @@ -1,3 +1,5 @@ -module.exports = function rememberUserHasSeenChallengeTooltip({ userId, challengeType, userRepository }) { +const rememberUserHasSeenChallengeTooltip = function ({ userId, challengeType, userRepository }) { return userRepository.updateHasSeenChallengeTooltip({ userId, challengeType }); }; + +export { rememberUserHasSeenChallengeTooltip }; diff --git a/api/lib/domain/usecases/remember-user-has-seen-last-data-protection-policy-information.js b/api/lib/domain/usecases/remember-user-has-seen-last-data-protection-policy-information.js index 5fe81460a77..966783167a6 100644 --- a/api/lib/domain/usecases/remember-user-has-seen-last-data-protection-policy-information.js +++ b/api/lib/domain/usecases/remember-user-has-seen-last-data-protection-policy-information.js @@ -1,3 +1,5 @@ -module.exports = function rememberUserHasSeenLastDataProtectionPolicyInformation({ userId, userRepository }) { +const rememberUserHasSeenLastDataProtectionPolicyInformation = function ({ userId, userRepository }) { return userRepository.updateLastDataProtectionPolicySeenAt({ userId }); }; + +export { rememberUserHasSeenLastDataProtectionPolicyInformation }; diff --git a/api/lib/domain/usecases/remember-user-has-seen-new-dashboard-info.js b/api/lib/domain/usecases/remember-user-has-seen-new-dashboard-info.js index ae93cfbe6a4..2b5b1a159d7 100644 --- a/api/lib/domain/usecases/remember-user-has-seen-new-dashboard-info.js +++ b/api/lib/domain/usecases/remember-user-has-seen-new-dashboard-info.js @@ -1,3 +1,5 @@ -module.exports = function rememberUserHasSeenNewDashboardInfo({ userId, userRepository }) { +const rememberUserHasSeenNewDashboardInfo = function ({ userId, userRepository }) { return userRepository.updateHasSeenNewDashboardInfoToTrue(userId); }; + +export { rememberUserHasSeenNewDashboardInfo }; diff --git a/api/lib/domain/usecases/remove-authentication-method.js b/api/lib/domain/usecases/remove-authentication-method.js index 5d7b4f3be40..da78c1f6766 100644 --- a/api/lib/domain/usecases/remove-authentication-method.js +++ b/api/lib/domain/usecases/remove-authentication-method.js @@ -1,13 +1,8 @@ -const AuthenticationMethod = require('../models/AuthenticationMethod.js'); -const { UserNotAuthorizedToRemoveAuthenticationMethod } = require('../errors.js'); -const OidcIdentityProviders = require('../constants/oidc-identity-providers.js'); +import { AuthenticationMethod } from '../models/AuthenticationMethod.js'; +import { UserNotAuthorizedToRemoveAuthenticationMethod } from '../errors.js'; +import * as OidcIdentityProviders from '../constants/oidc-identity-providers.js'; -module.exports = async function removeAuthenticationMethod({ - userId, - type, - userRepository, - authenticationMethodRepository, -}) { +const removeAuthenticationMethod = async function ({ userId, type, userRepository, authenticationMethodRepository }) { const user = await userRepository.get(userId); if (type === 'EMAIL') { @@ -53,6 +48,8 @@ module.exports = async function removeAuthenticationMethod({ } }; +export { removeAuthenticationMethod }; + async function _removeAuthenticationMethod(userId, identityProvider, authenticationMethodRepository) { const authenticationMethods = await authenticationMethodRepository.findByUserId({ userId }); diff --git a/api/lib/domain/usecases/replace-sup-organization-learner.js b/api/lib/domain/usecases/replace-sup-organization-learner.js index eabad660a9b..3d5c1a948ef 100644 --- a/api/lib/domain/usecases/replace-sup-organization-learner.js +++ b/api/lib/domain/usecases/replace-sup-organization-learner.js @@ -1,4 +1,4 @@ -module.exports = async function replaceSupOrganizationLearners({ +const replaceSupOrganizationLearners = async function ({ organizationId, supOrganizationLearnerRepository, supOrganizationLearnerParser, @@ -9,3 +9,5 @@ module.exports = async function replaceSupOrganizationLearners({ return warnings; }; + +export { replaceSupOrganizationLearners }; diff --git a/api/lib/domain/usecases/resend-organization-invitation.js b/api/lib/domain/usecases/resend-organization-invitation.js index dc28111cc88..0fb555b05cb 100644 --- a/api/lib/domain/usecases/resend-organization-invitation.js +++ b/api/lib/domain/usecases/resend-organization-invitation.js @@ -1,4 +1,4 @@ -module.exports = async function resendOrganizationInvitation({ +const resendOrganizationInvitation = async function ({ organizationId, email, locale, @@ -14,3 +14,5 @@ module.exports = async function resendOrganizationInvitation({ locale, }); }; + +export { resendOrganizationInvitation }; diff --git a/api/lib/domain/usecases/reset-scorecard.js b/api/lib/domain/usecases/reset-scorecard.js index c599d703ffc..ed9614b945e 100644 --- a/api/lib/domain/usecases/reset-scorecard.js +++ b/api/lib/domain/usecases/reset-scorecard.js @@ -1,8 +1,8 @@ -const Scorecard = require('../models/Scorecard.js'); -const { CompetenceResetError } = require('../errors.js'); -const _ = require('lodash'); +import { Scorecard } from '../models/Scorecard.js'; +import { CompetenceResetError } from '../errors.js'; +import _ from 'lodash'; -module.exports = async function resetScorecard({ +const resetScorecard = async function ({ userId, competenceId, scorecardService, @@ -57,3 +57,5 @@ module.exports = async function resetScorecard({ locale, }); }; + +export { resetScorecard }; diff --git a/api/lib/domain/usecases/retrieve-last-or-create-certification-course.js b/api/lib/domain/usecases/retrieve-last-or-create-certification-course.js index 893169dff1a..935559538db 100644 --- a/api/lib/domain/usecases/retrieve-last-or-create-certification-course.js +++ b/api/lib/domain/usecases/retrieve-last-or-create-certification-course.js @@ -1,18 +1,22 @@ -const CertificationCourse = require('../models/CertificationCourse.js'); -const Assessment = require('../models/Assessment.js'); -const ComplementaryCertificationCourse = require('../models/ComplementaryCertificationCourse.js'); -const { +import { CertificationCourse } from '../models/CertificationCourse.js'; +import { Assessment } from '../models/Assessment.js'; +import { ComplementaryCertificationCourse } from '../models/ComplementaryCertificationCourse.js'; + +import { UserNotAuthorizedToCertifyError, NotFoundError, SessionNotAccessible, CandidateNotAuthorizedToJoinSessionError, CandidateNotAuthorizedToResumeCertificationTestError, UnexpectedUserAccountError, -} = require('../errors.js'); -const { features } = require('../../config.js'); -const bluebird = require('bluebird'); +} from '../errors.js'; + +import { config } from '../../config.js'; +import bluebird from 'bluebird'; -module.exports = async function retrieveLastOrCreateCertificationCourse({ +const { features } = config; + +const retrieveLastOrCreateCertificationCourse = async function ({ domainTransaction, accessCode, sessionId, @@ -88,6 +92,8 @@ module.exports = async function retrieveLastOrCreateCertificationCourse({ }); }; +export { retrieveLastOrCreateCertificationCourse }; + async function _startNewCertification({ domainTransaction, sessionId, diff --git a/api/lib/domain/usecases/revoke-refresh-token.js b/api/lib/domain/usecases/revoke-refresh-token.js index 2bf26eec7fb..0382741ba5a 100644 --- a/api/lib/domain/usecases/revoke-refresh-token.js +++ b/api/lib/domain/usecases/revoke-refresh-token.js @@ -1,3 +1,5 @@ -module.exports = async function revokeRefreshToken({ refreshToken, refreshTokenService }) { +const revokeRefreshToken = async function ({ refreshToken, refreshTokenService }) { await refreshTokenService.revokeRefreshToken({ refreshToken }); }; + +export { revokeRefreshToken }; diff --git a/api/lib/domain/usecases/save-admin-member.js b/api/lib/domain/usecases/save-admin-member.js index a00170865d8..3ed36218d16 100644 --- a/api/lib/domain/usecases/save-admin-member.js +++ b/api/lib/domain/usecases/save-admin-member.js @@ -1,7 +1,7 @@ -const { AlreadyExistingAdminMemberError } = require('../errors.js'); -const AdminMember = require('../models/AdminMember.js'); +import { AlreadyExistingAdminMemberError } from '../errors.js'; +import { AdminMember } from '../models/AdminMember.js'; -module.exports = async function saveAdminMember({ email, role, userRepository, adminMemberRepository }) { +const saveAdminMember = async function ({ email, role, userRepository, adminMemberRepository }) { const { id: userId, firstName, lastName } = await userRepository.getByEmail(email); const adminMember = await adminMemberRepository.get({ userId }); @@ -21,3 +21,5 @@ module.exports = async function saveAdminMember({ email, role, userRepository, a throw new AlreadyExistingAdminMemberError(); }; + +export { saveAdminMember }; diff --git a/api/lib/domain/usecases/save-certification-issue-report.js b/api/lib/domain/usecases/save-certification-issue-report.js index 3e3a9dd4bc8..750c305d6ea 100644 --- a/api/lib/domain/usecases/save-certification-issue-report.js +++ b/api/lib/domain/usecases/save-certification-issue-report.js @@ -1,6 +1,6 @@ -const CertificationIssueReport = require('../models/CertificationIssueReport.js'); +import { CertificationIssueReport } from '../models/CertificationIssueReport.js'; -module.exports = async function saveCertificationIssueReport({ +const saveCertificationIssueReport = async function ({ certificationIssueReportDTO, certificationIssueReportRepository, issueReportCategoryRepository, @@ -16,3 +16,5 @@ module.exports = async function saveCertificationIssueReport({ return certificationIssueReportRepository.save(certificationIssueReport); }; + +export { saveCertificationIssueReport }; diff --git a/api/lib/domain/usecases/save-computed-campaign-participation-result.js b/api/lib/domain/usecases/save-computed-campaign-participation-result.js index ce8d885b64d..226298d2b29 100644 --- a/api/lib/domain/usecases/save-computed-campaign-participation-result.js +++ b/api/lib/domain/usecases/save-computed-campaign-participation-result.js @@ -1,7 +1,9 @@ -module.exports = async function saveComputedCampaignParticipationResult({ +const saveComputedCampaignParticipationResult = async function ({ participantResultsSharedRepository, campaignParticipationId, }) { const participantResultsShared = await participantResultsSharedRepository.get(campaignParticipationId); return participantResultsSharedRepository.save(participantResultsShared); }; + +export { saveComputedCampaignParticipationResult }; diff --git a/api/lib/domain/usecases/save-jury-complementary-certification-course-result.js b/api/lib/domain/usecases/save-jury-complementary-certification-course-result.js index d1fe26c96d3..52b8cd16a88 100644 --- a/api/lib/domain/usecases/save-jury-complementary-certification-course-result.js +++ b/api/lib/domain/usecases/save-jury-complementary-certification-course-result.js @@ -1,7 +1,7 @@ -const { NotFoundError, InvalidJuryLevelError } = require('../errors.js'); -const ComplementaryCertificationCourseResult = require('../models/ComplementaryCertificationCourseResult.js'); +import { NotFoundError, InvalidJuryLevelError } from '../errors.js'; +import { ComplementaryCertificationCourseResult } from '../models/ComplementaryCertificationCourseResult.js'; -module.exports = async function saveJuryComplementaryCertificationCourseResult({ +const saveJuryComplementaryCertificationCourseResult = async function ({ complementaryCertificationCourseId, juryLevel, complementaryCertificationCourseResultRepository, @@ -35,3 +35,5 @@ module.exports = async function saveJuryComplementaryCertificationCourseResult({ return complementaryCertificationCourseResultRepository.save(externalComplementaryCertificationCourseResult); }; + +export { saveJuryComplementaryCertificationCourseResult }; diff --git a/api/lib/domain/usecases/send-sco-invitation.js b/api/lib/domain/usecases/send-sco-invitation.js index 37726b40ab0..7eca83a2c4f 100644 --- a/api/lib/domain/usecases/send-sco-invitation.js +++ b/api/lib/domain/usecases/send-sco-invitation.js @@ -1,12 +1,13 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { OrganizationNotFoundError, OrganizationWithoutEmailError, ManyOrganizationsFoundError, OrganizationArchivedError, -} = require('../errors.js'); +} from '../errors.js'; -module.exports = async function sendScoInvitation({ +const sendScoInvitation = async function ({ uai, firstName, lastName, @@ -30,6 +31,8 @@ module.exports = async function sendScoInvitation({ }); }; +export { sendScoInvitation }; + async function _getOrganizationWithGivenUAI({ uai, organizationRepository }) { const organizationsFound = await organizationRepository.findScoOrganizationsByUai({ uai: uai.trim() }); _ensureThereIsNoMoreThanOneOrganization({ organizationCount: organizationsFound.length, uai }); diff --git a/api/lib/domain/usecases/send-shared-participation-results-to-pole-emploi.js b/api/lib/domain/usecases/send-shared-participation-results-to-pole-emploi.js index 9b3d2f4b270..86e29d40705 100644 --- a/api/lib/domain/usecases/send-shared-participation-results-to-pole-emploi.js +++ b/api/lib/domain/usecases/send-shared-participation-results-to-pole-emploi.js @@ -1,7 +1,7 @@ -const PoleEmploiPayload = require('../../infrastructure/externals/pole-emploi/PoleEmploiPayload.js'); -const PoleEmploiSending = require('../models/PoleEmploiSending.js'); +import { PoleEmploiPayload } from '../../infrastructure/externals/pole-emploi/PoleEmploiPayload.js'; +import { PoleEmploiSending } from '../models/PoleEmploiSending.js'; -module.exports = async function sendSharedParticipationResultsToPoleEmploi({ +const sendSharedParticipationResultsToPoleEmploi = async function ({ badgeRepository, badgeAcquisitionRepository, campaignParticipationId, @@ -52,3 +52,5 @@ module.exports = async function sendSharedParticipationResultsToPoleEmploi({ return poleEmploiSendingRepository.create({ poleEmploiSending }); } }; + +export { sendSharedParticipationResultsToPoleEmploi }; diff --git a/api/lib/domain/usecases/send-verification-code.js b/api/lib/domain/usecases/send-verification-code.js index 3e19ef82c31..032da0507be 100644 --- a/api/lib/domain/usecases/send-verification-code.js +++ b/api/lib/domain/usecases/send-verification-code.js @@ -1,8 +1,10 @@ -const AuthenticationMethod = require('../models/AuthenticationMethod.js'); -const { InvalidPasswordForUpdateEmailError, UserNotAuthorizedToUpdateEmailError } = require('../errors.js'); -const get = require('lodash/get'); +import { AuthenticationMethod } from '../models/AuthenticationMethod.js'; +import { InvalidPasswordForUpdateEmailError, UserNotAuthorizedToUpdateEmailError } from '../errors.js'; +import lodash from 'lodash'; -module.exports = async function sendVerificationCode({ +const { get } = lodash; + +const sendVerificationCode = async function ({ i18n, locale, newEmail, @@ -43,3 +45,5 @@ module.exports = async function sendVerificationCode({ await userEmailRepository.saveEmailModificationDemand({ userId, code, newEmail }); await mailService.sendVerificationCodeEmail({ code, locale, translate: i18n.__, email: newEmail }); }; + +export { sendVerificationCode }; diff --git a/api/lib/domain/usecases/sessions-mass-import/create-sessions.js b/api/lib/domain/usecases/sessions-mass-import/create-sessions.js index 19f3538beb5..e17acb403c3 100644 --- a/api/lib/domain/usecases/sessions-mass-import/create-sessions.js +++ b/api/lib/domain/usecases/sessions-mass-import/create-sessions.js @@ -1,10 +1,10 @@ -const { NotFoundError } = require('../../errors'); -const bluebird = require('bluebird'); -const DomainTransaction = require('../../../infrastructure/DomainTransaction.js'); -const Session = require('../../models/Session'); -const CertificationCandidate = require('../../models/CertificationCandidate'); +import { NotFoundError } from '../../errors.js'; +import bluebird from 'bluebird'; +import { DomainTransaction } from '../../../infrastructure/DomainTransaction.js'; +import { Session } from '../../models/Session.js'; +import { CertificationCandidate } from '../../models/CertificationCandidate.js'; -module.exports = async function createSessions({ +const createSessions = async function ({ userId, cachedValidatedSessionsKey, certificationCandidateRepository, @@ -47,12 +47,14 @@ module.exports = async function createSessions({ }); }); - await temporarySessionsStorageForMassImportService.delete({ + await temporarySessionsStorageForMassImportService.remove({ cachedValidatedSessionsKey, userId, }); }; +export { createSessions }; + function _hasCandidates(certificationCandidates) { return certificationCandidates.length > 0; } diff --git a/api/lib/domain/usecases/sessions-mass-import/validate-sessions.js b/api/lib/domain/usecases/sessions-mass-import/validate-sessions.js index 4a6cb3ef0b4..7dff09ae69a 100644 --- a/api/lib/domain/usecases/sessions-mass-import/validate-sessions.js +++ b/api/lib/domain/usecases/sessions-mass-import/validate-sessions.js @@ -1,9 +1,9 @@ -const Session = require('../../models/Session'); -const SessionMassImportReport = require('../../models/SessionMassImportReport'); -const CertificationCandidate = require('../../models/CertificationCandidate'); -const bluebird = require('bluebird'); +import { Session } from '../../models/Session.js'; +import { SessionMassImportReport } from '../../models/SessionMassImportReport.js'; +import { CertificationCandidate } from '../../models/CertificationCandidate.js'; +import bluebird from 'bluebird'; -module.exports = async function validateSessions({ +const validateSessions = async function ({ sessions, userId, certificationCenterId, @@ -77,6 +77,8 @@ module.exports = async function validateSessions({ return sessionsMassImportReport; }; +export { validateSessions }; + async function _createValidCertificationCandidates({ certificationCandidates, sessionId, diff --git a/api/lib/domain/usecases/share-campaign-result.js b/api/lib/domain/usecases/share-campaign-result.js index 32d1206fd09..a182110bde2 100644 --- a/api/lib/domain/usecases/share-campaign-result.js +++ b/api/lib/domain/usecases/share-campaign-result.js @@ -1,7 +1,7 @@ -const { UserNotAuthorizedToAccessEntityError } = require('../errors.js'); -const CampaignParticipationResultsShared = require('../events/CampaignParticipationResultsShared.js'); +import { UserNotAuthorizedToAccessEntityError } from '../errors.js'; +import { CampaignParticipationResultsShared } from '../events/CampaignParticipationResultsShared.js'; -module.exports = async function shareCampaignResult({ +const shareCampaignResult = async function ({ userId, campaignParticipationId, campaignParticipationRepository, @@ -19,6 +19,8 @@ module.exports = async function shareCampaignResult({ }); }; +export { shareCampaignResult }; + function _checkUserIsOwnerOfCampaignParticipation(campaignParticipation, userId) { if (campaignParticipation.userId !== userId) { throw new UserNotAuthorizedToAccessEntityError('User does not have an access to this campaign participation'); diff --git a/api/lib/domain/usecases/simulate-flash-scoring.js b/api/lib/domain/usecases/simulate-flash-scoring.js index 475b726146e..c684d32f771 100644 --- a/api/lib/domain/usecases/simulate-flash-scoring.js +++ b/api/lib/domain/usecases/simulate-flash-scoring.js @@ -1,6 +1,6 @@ -const ScoringSimulationResult = require('../models/ScoringSimulationResult.js'); +import { ScoringSimulationResult } from '../models/ScoringSimulationResult.js'; -module.exports = async function simulateFlashScoring({ +const simulateFlashScoring = async function ({ challengeRepository, flashAlgorithmService, simulations, @@ -62,3 +62,5 @@ module.exports = async function simulateFlashScoring({ return new ScoringSimulationResult({ id, estimatedLevel: finalEstimatedLevel, pixScore, pixScoreByCompetence }); }); }; + +export { simulateFlashScoring }; diff --git a/api/lib/domain/usecases/simulate-old-scoring.js b/api/lib/domain/usecases/simulate-old-scoring.js index 40557c630d8..79ad3a67e90 100644 --- a/api/lib/domain/usecases/simulate-old-scoring.js +++ b/api/lib/domain/usecases/simulate-old-scoring.js @@ -1,8 +1,10 @@ -const ScoringSimulationResult = require('../models/ScoringSimulationResult.js'); -const fp = require('lodash/fp'); -const { sortBy } = require('lodash'); +import { ScoringSimulationResult } from '../models/ScoringSimulationResult.js'; +import lodash from 'lodash'; -module.exports = async function simulateOldScoring({ challengeRepository, simulations }) { +const { sortBy } = lodash; +import fp from 'lodash/fp.js'; + +const simulateOldScoring = async function ({ challengeRepository, simulations }) { const challenges = await challengeRepository.findOperative(); const challengesById = new Map(challenges.map((challenge) => [challenge.id, challenge])); @@ -68,3 +70,5 @@ module.exports = async function simulateOldScoring({ challengeRepository, simula return simulationResults; }; + +export { simulateOldScoring }; diff --git a/api/lib/domain/usecases/start-campaign-participation.js b/api/lib/domain/usecases/start-campaign-participation.js index 5f145c8f32a..d748b5c3145 100644 --- a/api/lib/domain/usecases/start-campaign-participation.js +++ b/api/lib/domain/usecases/start-campaign-participation.js @@ -1,6 +1,6 @@ -const CampaignParticipationStarted = require('../events/CampaignParticipationStarted.js'); +import { CampaignParticipationStarted } from '../events/CampaignParticipationStarted.js'; -module.exports = async function startCampaignParticipation({ +const startCampaignParticipation = async function ({ campaignParticipation, userId, campaignParticipantRepository, @@ -27,3 +27,5 @@ module.exports = async function startCampaignParticipation({ campaignParticipation: createdCampaignParticipation, }; }; + +export { startCampaignParticipation }; diff --git a/api/lib/domain/usecases/start-or-resume-competence-evaluation.js b/api/lib/domain/usecases/start-or-resume-competence-evaluation.js index b2e823cfee7..f6b3503603e 100644 --- a/api/lib/domain/usecases/start-or-resume-competence-evaluation.js +++ b/api/lib/domain/usecases/start-or-resume-competence-evaluation.js @@ -1,8 +1,8 @@ -const Assessment = require('../models/Assessment.js'); -const CompetenceEvaluation = require('../models/CompetenceEvaluation.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import { Assessment } from '../models/Assessment.js'; +import { CompetenceEvaluation } from '../models/CompetenceEvaluation.js'; +import { NotFoundError } from '../../domain/errors.js'; -module.exports = async function startOrResumeCompetenceEvaluation({ +const startOrResumeCompetenceEvaluation = async function ({ competenceId, userId, competenceEvaluationRepository, @@ -32,6 +32,8 @@ module.exports = async function startOrResumeCompetenceEvaluation({ } }; +export { startOrResumeCompetenceEvaluation }; + function _checkCompetenceExists(competenceId, competenceRepository) { return competenceRepository.get({ id: competenceId }); } diff --git a/api/lib/domain/usecases/start-writing-campaign-assessment-results-to-stream.js b/api/lib/domain/usecases/start-writing-campaign-assessment-results-to-stream.js index 242386e6a1b..253bd7899cb 100644 --- a/api/lib/domain/usecases/start-writing-campaign-assessment-results-to-stream.js +++ b/api/lib/domain/usecases/start-writing-campaign-assessment-results-to-stream.js @@ -1,18 +1,17 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); - -const dayjs = require('dayjs'); -const utc = require('dayjs/plugin/utc'); -const timezone = require('dayjs/plugin/timezone'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import dayjs from 'dayjs'; +import utc from 'dayjs/plugin/utc.js'; +import timezone from 'dayjs/plugin/timezone.js'; dayjs.extend(utc); dayjs.extend(timezone); -const { constants } = require('../../infrastructure/constants.js'); -const { UserNotAuthorizedToGetCampaignResultsError, CampaignTypeError } = require('../errors.js'); -const csvSerializer = require('../../infrastructure/serializers/csv/csv-serializer.js'); -const CampaignLearningContent = require('../models/CampaignLearningContent.js'); +import { CONCURRENCY_HEAVY_OPERATIONS, CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING } from '../../infrastructure/constants.js'; +import { UserNotAuthorizedToGetCampaignResultsError, CampaignTypeError } from '../errors.js'; +import * as csvSerializer from '../../infrastructure/serializers/csv/csv-serializer.js'; +import { CampaignLearningContent } from '../models/CampaignLearningContent.js'; -module.exports = async function startWritingCampaignAssessmentResultsToStream({ +const startWritingCampaignAssessmentResultsToStream = async function ({ userId, campaignId, writableStream, @@ -66,10 +65,7 @@ module.exports = async function startWritingCampaignAssessmentResultsToStream({ // after this function's returned promise resolves. If we await the map // function, node will keep all the data in memory until the end of the // complete operation. - const campaignParticipationInfoChunks = _.chunk( - campaignParticipationInfos, - constants.CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING - ); + const campaignParticipationInfoChunks = _.chunk(campaignParticipationInfos, CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING); bluebird .map( campaignParticipationInfoChunks, @@ -125,7 +121,7 @@ module.exports = async function startWritingCampaignAssessmentResultsToStream({ writableStream.write(csvLines); }, - { concurrency: constants.CONCURRENCY_HEAVY_OPERATIONS } + { concurrency: CONCURRENCY_HEAVY_OPERATIONS } ) .then(() => { writableStream.end(); @@ -143,6 +139,8 @@ module.exports = async function startWritingCampaignAssessmentResultsToStream({ return { fileName }; }; +export { startWritingCampaignAssessmentResultsToStream }; + async function _checkCreatorHasAccessToCampaignOrganization(userId, organizationId, userRepository) { const user = await userRepository.getWithMemberships(userId); diff --git a/api/lib/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream.js b/api/lib/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream.js index 851b99f8c5f..4b58fb30382 100644 --- a/api/lib/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream.js +++ b/api/lib/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream.js @@ -1,11 +1,11 @@ -const dayjs = require('dayjs'); -const utc = require('dayjs/plugin/utc'); -const timezone = require('dayjs/plugin/timezone'); +import dayjs from 'dayjs'; +import utc from 'dayjs/plugin/utc.js'; +import timezone from 'dayjs/plugin/timezone.js'; dayjs.extend(utc); dayjs.extend(timezone); -const { UserNotAuthorizedToGetCampaignResultsError, CampaignTypeError } = require('../errors.js'); -const CampaignProfilesCollectionExport = require('../../infrastructure/serializers/csv/campaign-profiles-collection-export.js'); +import { UserNotAuthorizedToGetCampaignResultsError, CampaignTypeError } from '../errors.js'; +import { CampaignProfilesCollectionExport } from '../../infrastructure/serializers/csv/campaign-profiles-collection-export.js'; async function _checkCreatorHasAccessToCampaignOrganization(userId, organizationId, userRepository) { const user = await userRepository.getWithMemberships(userId); @@ -17,7 +17,7 @@ async function _checkCreatorHasAccessToCampaignOrganization(userId, organization } } -module.exports = async function startWritingCampaignProfilesCollectionResultsToStream({ +const startWritingCampaignProfilesCollectionResultsToStream = async function ({ userId, campaignId, writableStream, @@ -74,3 +74,5 @@ module.exports = async function startWritingCampaignProfilesCollectionResultsToS return { fileName }; }; + +export { startWritingCampaignProfilesCollectionResultsToStream }; diff --git a/api/lib/domain/usecases/supervise-session.js b/api/lib/domain/usecases/supervise-session.js index 8362969ddb2..f83aabd4744 100644 --- a/api/lib/domain/usecases/supervise-session.js +++ b/api/lib/domain/usecases/supervise-session.js @@ -1,5 +1,6 @@ -const { SessionNotAccessible, InvalidSessionSupervisingLoginError } = require('../errors.js'); -module.exports = async function superviseSession({ +import { SessionNotAccessible, InvalidSessionSupervisingLoginError } from '../errors.js'; + +const superviseSession = async function ({ sessionId, supervisorPassword, userId, @@ -15,3 +16,5 @@ module.exports = async function superviseSession({ } await supervisorAccessRepository.create({ sessionId, userId }); }; + +export { superviseSession }; diff --git a/api/lib/domain/usecases/unarchive-campaign.js b/api/lib/domain/usecases/unarchive-campaign.js index ca5a401f108..bc4cf83b98c 100644 --- a/api/lib/domain/usecases/unarchive-campaign.js +++ b/api/lib/domain/usecases/unarchive-campaign.js @@ -1,6 +1,8 @@ -module.exports = async function unarchiveCampaign({ campaignId, campaignForArchivingRepository }) { +const unarchiveCampaign = async function ({ campaignId, campaignForArchivingRepository }) { const campaign = await campaignForArchivingRepository.get(campaignId); campaign.unarchive(); await campaignForArchivingRepository.save(campaign); return campaign; }; + +export { unarchiveCampaign }; diff --git a/api/lib/domain/usecases/unblock-user-account.js b/api/lib/domain/usecases/unblock-user-account.js index ad04030fed8..a10fbeb2a08 100644 --- a/api/lib/domain/usecases/unblock-user-account.js +++ b/api/lib/domain/usecases/unblock-user-account.js @@ -1,6 +1,8 @@ -module.exports = async function unblockUserAccount({ userId, userLoginRepository }) { +const unblockUserAccount = async function ({ userId, userLoginRepository }) { const userLogin = await userLoginRepository.findByUserId(userId); userLogin.resetUserBlocking(); return await userLoginRepository.update(userLogin); }; + +export { unblockUserAccount }; diff --git a/api/lib/domain/usecases/uncancel-certification-course.js b/api/lib/domain/usecases/uncancel-certification-course.js index 42f9997abb3..7b8c9b1a17e 100644 --- a/api/lib/domain/usecases/uncancel-certification-course.js +++ b/api/lib/domain/usecases/uncancel-certification-course.js @@ -1,5 +1,7 @@ -module.exports = async function uncancelCertificationCourse({ certificationCourseId, certificationCourseRepository }) { +const uncancelCertificationCourse = async function ({ certificationCourseId, certificationCourseRepository }) { const certificationCourse = await certificationCourseRepository.get(certificationCourseId); certificationCourse.uncancel(); await certificationCourseRepository.update(certificationCourse); }; + +export { uncancelCertificationCourse }; diff --git a/api/lib/domain/usecases/unpublish-session.js b/api/lib/domain/usecases/unpublish-session.js index 33b27bf843e..30c2a17079a 100644 --- a/api/lib/domain/usecases/unpublish-session.js +++ b/api/lib/domain/usecases/unpublish-session.js @@ -1,4 +1,4 @@ -module.exports = async function unpublishSession({ +const unpublishSession = async function ({ sessionId, certificationRepository, sessionRepository, @@ -17,6 +17,8 @@ module.exports = async function unpublishSession({ return sessionRepository.getWithCertificationCandidates(sessionId); }; +export { unpublishSession }; + async function _updateFinalizedSession(finalizedSessionRepository, sessionId) { const finalizedSession = await finalizedSessionRepository.get({ sessionId }); finalizedSession.unpublish(); diff --git a/api/lib/domain/usecases/update-admin-member.js b/api/lib/domain/usecases/update-admin-member.js index ef0e792db6f..40674301d86 100644 --- a/api/lib/domain/usecases/update-admin-member.js +++ b/api/lib/domain/usecases/update-admin-member.js @@ -1,4 +1,6 @@ -module.exports = async function updateAdminMember({ id, role, adminMemberRepository }) { +const updateAdminMember = async function ({ id, role, adminMemberRepository }) { const attributesToUpdate = { role }; return await adminMemberRepository.update({ id, attributesToUpdate }); }; + +export { updateAdminMember }; diff --git a/api/lib/domain/usecases/update-badge.js b/api/lib/domain/usecases/update-badge.js index 1a79b357f5a..68b38f5125e 100644 --- a/api/lib/domain/usecases/update-badge.js +++ b/api/lib/domain/usecases/update-badge.js @@ -1,4 +1,4 @@ -module.exports = async function updateBadge({ badgeId, badge, badgeRepository }) { +const updateBadge = async function ({ badgeId, badge, badgeRepository }) { const existingBadge = await badgeRepository.get(badgeId); if (badge.message) existingBadge.message = badge.message; @@ -11,3 +11,5 @@ module.exports = async function updateBadge({ badgeId, badge, badgeRepository }) return badgeRepository.update(existingBadge); }; + +export { updateBadge }; diff --git a/api/lib/domain/usecases/update-campaign-details-management.js b/api/lib/domain/usecases/update-campaign-details-management.js index 68039446a5b..474aa7187b3 100644 --- a/api/lib/domain/usecases/update-campaign-details-management.js +++ b/api/lib/domain/usecases/update-campaign-details-management.js @@ -1,6 +1,6 @@ -const { EntityValidationError } = require('../errors.js'); +import { EntityValidationError } from '../errors.js'; -module.exports = async function updateCampaignDetailsManagement({ +const updateCampaignDetailsManagement = async function ({ campaignId, name, title, @@ -42,3 +42,5 @@ module.exports = async function updateCampaignDetailsManagement({ }; return campaignManagementRepository.update({ campaignId, campaignAttributes }); }; + +export { updateCampaignDetailsManagement }; diff --git a/api/lib/domain/usecases/update-campaign.js b/api/lib/domain/usecases/update-campaign.js index 8b7a0facdb5..b6bf3304fd9 100644 --- a/api/lib/domain/usecases/update-campaign.js +++ b/api/lib/domain/usecases/update-campaign.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { UserNotAuthorizedToUpdateResourceError, EntityValidationError } = require('../errors.js'); -const campaignValidator = require('../validators/campaign-validator.js'); +import _ from 'lodash'; +import { UserNotAuthorizedToUpdateResourceError, EntityValidationError } from '../errors.js'; +import * as campaignValidator from '../validators/campaign-validator.js'; -module.exports = async function updateCampaign({ +const updateCampaign = async function ({ userId, campaignId, name, @@ -52,3 +52,5 @@ module.exports = async function updateCampaign({ return campaign; }; + +export { updateCampaign }; diff --git a/api/lib/domain/usecases/update-certification-center-data-protection-officer-information.js b/api/lib/domain/usecases/update-certification-center-data-protection-officer-information.js index f05d013ca38..53640bff2dd 100644 --- a/api/lib/domain/usecases/update-certification-center-data-protection-officer-information.js +++ b/api/lib/domain/usecases/update-certification-center-data-protection-officer-information.js @@ -1,4 +1,4 @@ -module.exports = async function updateCertificationCenterDataProtectionOfficerInformation({ +const updateCertificationCenterDataProtectionOfficerInformation = async function ({ dataProtectionOfficer, dataProtectionOfficerRepository, }) { @@ -11,3 +11,5 @@ module.exports = async function updateCertificationCenterDataProtectionOfficerIn return dataProtectionOfficerRepository.update(dataProtectionOfficer); }; + +export { updateCertificationCenterDataProtectionOfficerInformation }; diff --git a/api/lib/domain/usecases/update-certification-center-referer.js b/api/lib/domain/usecases/update-certification-center-referer.js index 11997dd47d2..11263aaf85f 100644 --- a/api/lib/domain/usecases/update-certification-center-referer.js +++ b/api/lib/domain/usecases/update-certification-center-referer.js @@ -1,4 +1,4 @@ -module.exports = async function updateCertificationCenterReferer({ +const updateCertificationCenterReferer = async function ({ userId, isReferer, certificationCenterId, @@ -22,3 +22,5 @@ module.exports = async function updateCertificationCenterReferer({ isReferer, }); }; + +export { updateCertificationCenterReferer }; diff --git a/api/lib/domain/usecases/update-certification-center.js b/api/lib/domain/usecases/update-certification-center.js index 78b2c78b514..b2fa341da10 100644 --- a/api/lib/domain/usecases/update-certification-center.js +++ b/api/lib/domain/usecases/update-certification-center.js @@ -1,8 +1,8 @@ -const bluebird = require('bluebird'); -const certificationCenterCreationValidator = require('../validators/certification-center-creation-validator.js'); -const ComplementaryCertificationHabilitation = require('../../domain/models/ComplementaryCertificationHabilitation.js'); -const DataProtectionOfficer = require('../models/DataProtectionOfficer.js'); -const ComplementaryCertification = require('../models/ComplementaryCertification.js'); +import bluebird from 'bluebird'; +import * as certificationCenterCreationValidator from '../validators/certification-center-creation-validator.js'; +import { ComplementaryCertificationHabilitation } from '../../domain/models/ComplementaryCertificationHabilitation.js'; +import { DataProtectionOfficer } from '../models/DataProtectionOfficer.js'; +import { ComplementaryCertification } from '../models/ComplementaryCertification.js'; async function _addOrUpdateDataProtectionOfficer({ certificationCenter, dataProtectionOfficerRepository }) { const dataProtectionOfficer = new DataProtectionOfficer({ @@ -21,7 +21,7 @@ async function _addOrUpdateDataProtectionOfficer({ certificationCenter, dataProt return dataProtectionOfficerRepository.create(dataProtectionOfficer); } -module.exports = async function updateCertificationCenter({ +const updateCertificationCenter = async function ({ certificationCenter, complementaryCertificationIds, certificationCenterForAdminRepository, @@ -67,3 +67,5 @@ module.exports = async function updateCertificationCenter({ return updatedCertificationCenter; }; + +export { updateCertificationCenter }; diff --git a/api/lib/domain/usecases/update-expired-password.js b/api/lib/domain/usecases/update-expired-password.js index 1e400a3610c..32fdfa7eaec 100644 --- a/api/lib/domain/usecases/update-expired-password.js +++ b/api/lib/domain/usecases/update-expired-password.js @@ -1,10 +1,12 @@ -const get = require('lodash/get'); -const AuthenticationMethod = require('../../domain/models/AuthenticationMethod.js'); -const { ForbiddenAccess } = require('../../domain/errors.js'); -const { UserNotFoundError } = require('../../domain/errors.js'); -const logger = require('../../../lib/infrastructure/logger.js'); +import lodash from 'lodash'; -module.exports = async function updateExpiredPassword({ +const { get } = lodash; + +import { AuthenticationMethod } from '../../domain/models/AuthenticationMethod.js'; +import { ForbiddenAccess, UserNotFoundError } from '../../domain/errors.js'; +import { logger } from '../../../lib/infrastructure/logger.js'; + +const updateExpiredPassword = async function ({ passwordResetToken, newPassword, encryptionService, @@ -44,3 +46,5 @@ module.exports = async function updateExpiredPassword({ return foundUser.username ?? foundUser.email; }; + +export { updateExpiredPassword }; diff --git a/api/lib/domain/usecases/update-last-question-state.js b/api/lib/domain/usecases/update-last-question-state.js index bd260ae4467..d8438b22c25 100644 --- a/api/lib/domain/usecases/update-last-question-state.js +++ b/api/lib/domain/usecases/update-last-question-state.js @@ -1,7 +1,7 @@ -const logger = require('../../infrastructure/logger.js'); -const Assessment = require('../models/Assessment.js'); +import { logger } from '../../infrastructure/logger.js'; +import { Assessment } from '../models/Assessment.js'; -module.exports = async function updateLastQuestionState({ +const updateLastQuestionState = async function ({ assessmentId, lastQuestionState, challengeId, @@ -45,3 +45,5 @@ module.exports = async function updateLastQuestionState({ domainTransaction, }); }; + +export { updateLastQuestionState }; diff --git a/api/lib/domain/usecases/update-membership.js b/api/lib/domain/usecases/update-membership.js index 8006dd17fac..77553f69470 100644 --- a/api/lib/domain/usecases/update-membership.js +++ b/api/lib/domain/usecases/update-membership.js @@ -1,6 +1,8 @@ -module.exports = async function updateMembership({ membership, membershipRepository }) { +const updateMembership = async function ({ membership, membershipRepository }) { membership.validateRole(); const existingMembership = await membershipRepository.get(membership.id); return membershipRepository.updateById({ id: existingMembership.id, membership }); }; + +export { updateMembership }; diff --git a/api/lib/domain/usecases/update-organization-data-protection-officer-information.js b/api/lib/domain/usecases/update-organization-data-protection-officer-information.js index daa38319e9f..ef4f703b948 100644 --- a/api/lib/domain/usecases/update-organization-data-protection-officer-information.js +++ b/api/lib/domain/usecases/update-organization-data-protection-officer-information.js @@ -1,4 +1,4 @@ -module.exports = async function updateOrganizationDataProtectionOfficerInformation({ +const updateOrganizationDataProtectionOfficerInformation = async function ({ dataProtectionOfficer, dataProtectionOfficerRepository, }) { @@ -11,3 +11,5 @@ module.exports = async function updateOrganizationDataProtectionOfficerInformati return dataProtectionOfficerRepository.update(dataProtectionOfficer); }; + +export { updateOrganizationDataProtectionOfficerInformation }; diff --git a/api/lib/domain/usecases/update-organization-learner-dependent-user-password.js b/api/lib/domain/usecases/update-organization-learner-dependent-user-password.js index 215cc215024..3cf9b7ff1db 100644 --- a/api/lib/domain/usecases/update-organization-learner-dependent-user-password.js +++ b/api/lib/domain/usecases/update-organization-learner-dependent-user-password.js @@ -1,8 +1,10 @@ -const isEmpty = require('lodash/isEmpty'); +import lodash from 'lodash'; -const { UserNotAuthorizedToUpdatePasswordError } = require('../errors.js'); +const { isEmpty } = lodash; -module.exports = async function updateOrganizationLearnerDependentUserPassword({ +import { UserNotAuthorizedToUpdatePasswordError } from '../errors.js'; + +const updateOrganizationLearnerDependentUserPassword = async function ({ organizationId, organizationLearnerId, userId, @@ -41,3 +43,5 @@ module.exports = async function updateOrganizationLearnerDependentUserPassword({ return generatedPassword; }; + +export { updateOrganizationLearnerDependentUserPassword }; diff --git a/api/lib/domain/usecases/update-participant-external-id.js b/api/lib/domain/usecases/update-participant-external-id.js index 45ae712c0bb..bd48966233a 100644 --- a/api/lib/domain/usecases/update-participant-external-id.js +++ b/api/lib/domain/usecases/update-participant-external-id.js @@ -1,4 +1,4 @@ -module.exports = async function updateParticipantExternalId({ +const updateParticipantExternalId = async function ({ campaignParticipationId, participantExternalId, participationsForCampaignManagementRepository, @@ -8,3 +8,5 @@ module.exports = async function updateParticipantExternalId({ participantExternalId, }); }; + +export { updateParticipantExternalId }; diff --git a/api/lib/domain/usecases/update-session.js b/api/lib/domain/usecases/update-session.js index 2053340d772..12e7597a6de 100644 --- a/api/lib/domain/usecases/update-session.js +++ b/api/lib/domain/usecases/update-session.js @@ -1,7 +1,9 @@ -module.exports = async function updateSession({ session, sessionRepository, sessionValidator }) { +const updateSession = async function ({ session, sessionRepository, sessionValidator }) { sessionValidator.validate(session); const sessionToUpdate = await sessionRepository.get(session.id); Object.assign(sessionToUpdate, session); return sessionRepository.updateSessionInfo(sessionToUpdate); }; + +export { updateSession }; diff --git a/api/lib/domain/usecases/update-student-number.js b/api/lib/domain/usecases/update-student-number.js index 9b8376587f8..38d3fccedf2 100644 --- a/api/lib/domain/usecases/update-student-number.js +++ b/api/lib/domain/usecases/update-student-number.js @@ -1,6 +1,6 @@ -const { AlreadyExistingEntityError } = require('../../domain/errors.js'); +import { AlreadyExistingEntityError } from '../../domain/errors.js'; -module.exports = async function updateStudentNumber({ +const updateStudentNumber = async function ({ organizationLearnerId, studentNumber, organizationId, @@ -17,3 +17,5 @@ module.exports = async function updateStudentNumber({ await supOrganizationLearnerRepository.updateStudentNumber(organizationLearnerId, studentNumber); }; + +export { updateStudentNumber }; diff --git a/api/lib/domain/usecases/update-target-profile.js b/api/lib/domain/usecases/update-target-profile.js index a28ed20ce78..9249220018f 100644 --- a/api/lib/domain/usecases/update-target-profile.js +++ b/api/lib/domain/usecases/update-target-profile.js @@ -1,6 +1,6 @@ -const { validate } = require('../validators/target-profile/base-validation.js'); +import { validate } from '../validators/target-profile/base-validation.js'; -module.exports = async function updateTargetProfile({ +const updateTargetProfile = async function ({ id, name, imageUrl, @@ -19,3 +19,5 @@ module.exports = async function updateTargetProfile({ category, }); }; + +export { updateTargetProfile }; diff --git a/api/lib/domain/usecases/update-training.js b/api/lib/domain/usecases/update-training.js index bbb1c0e1a86..7d8fc062559 100644 --- a/api/lib/domain/usecases/update-training.js +++ b/api/lib/domain/usecases/update-training.js @@ -1,4 +1,4 @@ -module.exports = async function updateTraining({ training, trainingRepository }) { +const updateTraining = async function ({ training, trainingRepository }) { const trainingId = training.id; await trainingRepository.get({ trainingId }); @@ -7,3 +7,5 @@ module.exports = async function updateTraining({ training, trainingRepository }) attributesToUpdate: training, }); }; + +export { updateTraining }; diff --git a/api/lib/domain/usecases/update-user-details-for-administration.js b/api/lib/domain/usecases/update-user-details-for-administration.js index 366c665e8d6..9f3a0f60819 100644 --- a/api/lib/domain/usecases/update-user-details-for-administration.js +++ b/api/lib/domain/usecases/update-user-details-for-administration.js @@ -1,15 +1,14 @@ -const has = require('lodash/has'); -const { +import lodash from 'lodash'; + +const { has } = lodash; + +import { AlreadyRegisteredEmailAndUsernameError, AlreadyRegisteredEmailError, AlreadyRegisteredUsernameError, -} = require('../errors.js'); +} from '../errors.js'; -module.exports = async function updateUserDetailsForAdministration({ - userId, - userDetailsForAdministration, - userRepository, -}) { +const updateUserDetailsForAdministration = async function ({ userId, userDetailsForAdministration, userRepository }) { const { email, username } = userDetailsForAdministration; const foundUsersWithEmailAlreadyUsed = email && (await userRepository.findAnotherUserByEmail(userId, email)); @@ -31,6 +30,8 @@ module.exports = async function updateUserDetailsForAdministration({ return userRepository.getUserDetailsForAdmin(userId); }; +export { updateUserDetailsForAdministration }; + async function _checkEmailAndUsernameAreAvailable({ usersWithEmail, usersWithUsername }) { const isEmailAlreadyUsed = has(usersWithEmail, '[0].email'); const isUsernameAlreadyUsed = has(usersWithUsername, '[0].username'); diff --git a/api/lib/domain/usecases/update-user-email-with-validation.js b/api/lib/domain/usecases/update-user-email-with-validation.js index 764bc321653..8ddf8db4277 100644 --- a/api/lib/domain/usecases/update-user-email-with-validation.js +++ b/api/lib/domain/usecases/update-user-email-with-validation.js @@ -1,10 +1,10 @@ -const { +import { UserNotAuthorizedToUpdateEmailError, InvalidVerificationCodeError, EmailModificationDemandNotFoundOrExpiredError, -} = require('../errors.js'); +} from '../errors.js'; -module.exports = async function updateUserEmailWithValidation({ code, userId, userEmailRepository, userRepository }) { +const updateUserEmailWithValidation = async function ({ code, userId, userEmailRepository, userRepository }) { const user = await userRepository.get(userId); if (!user.email) { throw new UserNotAuthorizedToUpdateEmailError(); @@ -31,3 +31,5 @@ module.exports = async function updateUserEmailWithValidation({ code, userId, us return { email: emailModificationDemand.newEmail }; }; + +export { updateUserEmailWithValidation }; diff --git a/api/lib/domain/usecases/update-user-password.js b/api/lib/domain/usecases/update-user-password.js index cfc74abc4bc..92dc6139062 100644 --- a/api/lib/domain/usecases/update-user-password.js +++ b/api/lib/domain/usecases/update-user-password.js @@ -1,6 +1,6 @@ -const { UserNotAuthorizedToUpdatePasswordError } = require('../errors.js'); +import { UserNotAuthorizedToUpdatePasswordError } from '../errors.js'; -module.exports = async function updateUserPassword({ +const updateUserPassword = async function ({ userId, password, temporaryKey, @@ -26,3 +26,5 @@ module.exports = async function updateUserPassword({ return updatedUser; }; + +export { updateUserPassword }; diff --git a/api/lib/domain/validators/campaign-creation-validator.js b/api/lib/domain/validators/campaign-creation-validator.js index 89fb8036070..a52c15c92de 100644 --- a/api/lib/domain/validators/campaign-creation-validator.js +++ b/api/lib/domain/validators/campaign-creation-validator.js @@ -1,8 +1,9 @@ -const Joi = require('joi'); -const { first } = require('lodash'); -const { EntityValidationError } = require('../errors.js'); -const CampaignTypes = require('../models/CampaignTypes.js'); +import Joi from 'joi'; +import lodash from 'lodash'; +import { EntityValidationError } from '../errors.js'; +import { CampaignTypes } from '../models/CampaignTypes.js'; +const { first } = lodash; const schema = Joi.object({ type: Joi.string() .valid(CampaignTypes.ASSESSMENT, CampaignTypes.PROFILES_COLLECTION) @@ -78,4 +79,4 @@ function validate(campaign) { return true; } -module.exports = validate; +export { validate }; diff --git a/api/lib/domain/validators/campaign-validator.js b/api/lib/domain/validators/campaign-validator.js index 627615fc44b..d86740c8c1d 100644 --- a/api/lib/domain/validators/campaign-validator.js +++ b/api/lib/domain/validators/campaign-validator.js @@ -1,7 +1,10 @@ -const Joi = require('joi'); -const { first } = require('lodash'); -const { EntityValidationError } = require('../errors.js'); -const CampaignTypes = require('../models/CampaignTypes.js'); +import Joi from 'joi'; +import lodash from 'lodash'; + +const { first } = lodash; + +import { EntityValidationError } from '../errors.js'; +import { CampaignTypes } from '../models/CampaignTypes.js'; const validationConfiguration = { abortEarly: false, allowUnknown: true }; @@ -103,12 +106,12 @@ const campaignValidationJoiSchema = Joi.object({ }), }); -module.exports = { - validate(campaign) { - const { error } = campaignValidationJoiSchema.validate(campaign, validationConfiguration); - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - return true; - }, +const validate = function (campaign) { + const { error } = campaignValidationJoiSchema.validate(campaign, validationConfiguration); + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } + return true; }; + +export { validate }; diff --git a/api/lib/domain/validators/certification-center-creation-validator.js b/api/lib/domain/validators/certification-center-creation-validator.js index 9110bfc2f09..b59b8465380 100644 --- a/api/lib/domain/validators/certification-center-creation-validator.js +++ b/api/lib/domain/validators/certification-center-creation-validator.js @@ -1,5 +1,5 @@ -const Joi = require('joi'); -const { EntityValidationError } = require('../errors.js'); +import Joi from 'joi'; +import { EntityValidationError } from '../errors.js'; const validationConfiguration = { abortEarly: false, allowUnknown: true }; @@ -21,12 +21,12 @@ const certificationCenterSchema = Joi.object({ }), }); -module.exports = { - validate(certificationCenter) { - const { error } = certificationCenterSchema.validate(certificationCenter, validationConfiguration); - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - return true; - }, +const validate = function (certificationCenter) { + const { error } = certificationCenterSchema.validate(certificationCenter, validationConfiguration); + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } + return true; }; + +export { validate }; diff --git a/api/lib/domain/validators/entity-validator.js b/api/lib/domain/validators/entity-validator.js index c6327101a01..5a993bde6e2 100644 --- a/api/lib/domain/validators/entity-validator.js +++ b/api/lib/domain/validators/entity-validator.js @@ -1,10 +1,10 @@ -const { ObjectValidationError } = require('../errors.js'); +import { ObjectValidationError } from '../errors.js'; -module.exports = { - validateEntity(schema, entity) { - const { error } = schema.validate(entity); - if (error) { - throw new ObjectValidationError(error); - } - }, +const validateEntity = function (schema, entity) { + const { error } = schema.validate(entity); + if (error) { + throw new ObjectValidationError(error); + } }; + +export { validateEntity }; diff --git a/api/lib/domain/validators/organization-creation-validator.js b/api/lib/domain/validators/organization-creation-validator.js index b94023cee4d..b299121419c 100644 --- a/api/lib/domain/validators/organization-creation-validator.js +++ b/api/lib/domain/validators/organization-creation-validator.js @@ -1,5 +1,5 @@ -const Joi = require('joi'); -const { EntityValidationError } = require('../errors.js'); +import Joi from 'joi'; +import { EntityValidationError } from '../errors.js'; const validationConfiguration = { abortEarly: false, allowUnknown: true }; @@ -18,12 +18,12 @@ const organizationValidationJoiSchema = Joi.object({ }), }); -module.exports = { - validate(organizationCreationParams) { - const { error } = organizationValidationJoiSchema.validate(organizationCreationParams, validationConfiguration); - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - return true; - }, +const validate = function (organizationCreationParams) { + const { error } = organizationValidationJoiSchema.validate(organizationCreationParams, validationConfiguration); + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } + return true; }; + +export { validate }; diff --git a/api/lib/domain/validators/organization-learner-validator.js b/api/lib/domain/validators/organization-learner-validator.js index 7585ee223e5..f973aaf7527 100644 --- a/api/lib/domain/validators/organization-learner-validator.js +++ b/api/lib/domain/validators/organization-learner-validator.js @@ -1,8 +1,8 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { EntityValidationError } = require('../errors.js'); -const OrganizationLearner = require('../models/OrganizationLearner.js'); +import { EntityValidationError } from '../errors.js'; +import { OrganizationLearner } from '../models/OrganizationLearner.js'; const { STUDENT, APPRENTICE } = OrganizationLearner.STATUS; const validationConfiguration = { allowUnknown: true }; @@ -88,7 +88,4 @@ const checkValidation = function (organizationLearner) { } }; -module.exports = { - FRANCE_COUNTRY_CODE, - checkValidation, -}; +export { FRANCE_COUNTRY_CODE, checkValidation }; diff --git a/api/lib/domain/validators/organization-places-lot-validator.js b/api/lib/domain/validators/organization-places-lot-validator.js index b7c68034754..d38eb39153e 100644 --- a/api/lib/domain/validators/organization-places-lot-validator.js +++ b/api/lib/domain/validators/organization-places-lot-validator.js @@ -1,8 +1,8 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { EntityValidationError } = require('../errors.js'); -const categories = require('../constants/organization-places-categories.js'); +import { EntityValidationError } from '../errors.js'; +import * as categories from '../constants/organization-places-categories.js'; const schema = Joi.object({ organizationId: Joi.number().integer().required().messages({ @@ -47,4 +47,4 @@ function validate(organizationPlaces) { return true; } -module.exports = validate; +export { validate }; diff --git a/api/lib/domain/validators/organization-with-tags-and-target-profiles-script.js b/api/lib/domain/validators/organization-with-tags-and-target-profiles-script.js index ee0b312079b..214278777f8 100644 --- a/api/lib/domain/validators/organization-with-tags-and-target-profiles-script.js +++ b/api/lib/domain/validators/organization-with-tags-and-target-profiles-script.js @@ -1,8 +1,8 @@ -const Joi = require('joi'); -const { EntityValidationError } = require('../errors.js'); -const Organization = require('../models/Organization.js'); -const Membership = require('../models/Membership.js'); -const OidcIdentityProviders = require('../../../lib/domain/constants/oidc-identity-providers.js'); +import Joi from 'joi'; +import { EntityValidationError } from '../errors.js'; +import { Organization } from '../models/Organization.js'; +import { Membership } from '../models/Membership.js'; +import * as OidcIdentityProviders from '../../../lib/domain/constants/oidc-identity-providers.js'; const validProviders = Object.values(OidcIdentityProviders).map((provider) => provider.service.code); @@ -58,12 +58,12 @@ const schema = Joi.object({ }), }); -module.exports = { - validate(organization) { - const { error } = schema.validate(organization, { abortEarly: false, allowUnknown: true }); - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - return true; - }, +const validate = function (organization) { + const { error } = schema.validate(organization, { abortEarly: false, allowUnknown: true }); + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } + return true; }; + +export { validate }; diff --git a/api/lib/domain/validators/password-validator.js b/api/lib/domain/validators/password-validator.js index b541931dcb8..5b853300feb 100644 --- a/api/lib/domain/validators/password-validator.js +++ b/api/lib/domain/validators/password-validator.js @@ -1,8 +1,11 @@ -const Joi = require('joi'); -const XRegExp = require('xregexp'); +import Joi from 'joi'; +import XRegExp from 'xregexp'; -const { passwordValidationPattern } = require('../../config.js').account; -const { EntityValidationError } = require('../errors.js'); +import { config } from '../../config.js'; + +const { passwordValidationPattern } = config.account; + +import { EntityValidationError } from '../errors.js'; const pattern = XRegExp(passwordValidationPattern); @@ -16,12 +19,12 @@ const passwordValidationJoiSchema = Joi.object({ }), }); -module.exports = { - validate(password) { - const { error } = passwordValidationJoiSchema.validate({ password }); - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - return true; - }, +const validate = function (password) { + const { error } = passwordValidationJoiSchema.validate({ password }); + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } + return true; }; + +export { validate }; diff --git a/api/lib/domain/validators/session-validator.js b/api/lib/domain/validators/session-validator.js index 1a5ba54b94b..86f863fbc86 100644 --- a/api/lib/domain/validators/session-validator.js +++ b/api/lib/domain/validators/session-validator.js @@ -1,12 +1,11 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { statuses } = require('../models/Session.js'); -const { types } = require('../models/CertificationCenter.js'); -const { CERTIFICATION_SESSIONS_ERRORS } = require('../constants/sessions-errors'); - -const { EntityValidationError } = require('../errors.js'); -const identifiersType = require('../../domain/types/identifiers-type.js'); +import { statuses } from '../models/Session.js'; +import { types } from '../models/CertificationCenter.js'; +import { CERTIFICATION_SESSIONS_ERRORS } from '../constants/sessions-errors.js'; +import { EntityValidationError } from '../errors.js'; +import { identifiersType } from '../../domain/types/identifiers-type.js'; const validationConfiguration = { abortEarly: false, allowUnknown: true }; @@ -84,28 +83,28 @@ const sessionFiltersValidationSchema = Joi.object({ certificationCenterType: Joi.string().trim().valid(types.SUP, types.SCO, types.PRO).optional(), }); -module.exports = { - validate(session) { - const { error } = sessionValidationJoiSchema.validate(session, validationConfiguration); - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - }, - - validateForMassSessionImport(session) { - const { error } = sessionValidationForMassImportJoiSchema.validate(session, validationConfiguration); - if (error) { - return error.details.map(({ message }) => message); - } - }, - - validateAndNormalizeFilters(filters) { - const { value, error } = sessionFiltersValidationSchema.validate(filters, { abortEarly: true }); - - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - - return value; - }, +const validate = function (session) { + const { error } = sessionValidationJoiSchema.validate(session, validationConfiguration); + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } +}; + +const validateForMassSessionImport = function (session) { + const { error } = sessionValidationForMassImportJoiSchema.validate(session, validationConfiguration); + if (error) { + return error.details.map(({ message }) => message); + } +}; + +const validateAndNormalizeFilters = function (filters) { + const { value, error } = sessionFiltersValidationSchema.validate(filters, { abortEarly: true }); + + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } + + return value; }; + +export { validate, validateForMassSessionImport, validateAndNormalizeFilters }; diff --git a/api/lib/domain/validators/stage-validator.js b/api/lib/domain/validators/stage-validator.js index 31dc9376a04..9eca7398bfa 100644 --- a/api/lib/domain/validators/stage-validator.js +++ b/api/lib/domain/validators/stage-validator.js @@ -1,5 +1,5 @@ -const Joi = require('joi'); -const { EntityValidationError } = require('../errors.js'); +import Joi from 'joi'; +import { EntityValidationError } from '../errors.js'; const validationConfiguration = { abortEarly: false, allowUnknown: true }; @@ -18,12 +18,12 @@ const stageValidationJoiSchema = Joi.object({ }), }); -module.exports = { - validate({ stage }) { - const { error } = stageValidationJoiSchema.validate(stage, { ...validationConfiguration }); - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - return true; - }, +const validate = function ({ stage }) { + const { error } = stageValidationJoiSchema.validate(stage, { ...validationConfiguration }); + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } + return true; }; + +export { validate }; diff --git a/api/lib/domain/validators/sup-organization-learner-set-validator.js b/api/lib/domain/validators/sup-organization-learner-set-validator.js index ad8d38114d3..9003a47c4ab 100644 --- a/api/lib/domain/validators/sup-organization-learner-set-validator.js +++ b/api/lib/domain/validators/sup-organization-learner-set-validator.js @@ -1,21 +1,21 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { EntityValidationError } = require('../errors.js'); +import { EntityValidationError } from '../errors.js'; const validationConfiguration = { allowUnknown: true }; const validationSchema = Joi.array().unique('studentNumber'); -module.exports = { - checkValidation(organizationLearnerSet) { - const { error } = validationSchema.validate(organizationLearnerSet.learners, validationConfiguration); +const checkValidation = function (organizationLearnerSet) { + const { error } = validationSchema.validate(organizationLearnerSet.learners, validationConfiguration); - if (error) { - const err = EntityValidationError.fromJoiErrors(error.details); - err.key = 'studentNumber'; - err.why = 'uniqueness'; - throw err; - } - }, + if (error) { + const err = EntityValidationError.fromJoiErrors(error.details); + err.key = 'studentNumber'; + err.why = 'uniqueness'; + throw err; + } }; + +export { checkValidation }; diff --git a/api/lib/domain/validators/sup-organization-learner-validator.js b/api/lib/domain/validators/sup-organization-learner-validator.js index 918feb8b3d5..2adf5747066 100644 --- a/api/lib/domain/validators/sup-organization-learner-validator.js +++ b/api/lib/domain/validators/sup-organization-learner-validator.js @@ -1,7 +1,7 @@ -const BaseJoi = require('joi'); -const JoiDate = require('@joi/date'); +import BaseJoi from 'joi'; +import JoiDate from '@joi/date'; const Joi = BaseJoi.extend(JoiDate); -const { EntityValidationError } = require('../errors.js'); +import { EntityValidationError } from '../errors.js'; const validationConfiguration = { allowUnknown: true }; const MAX_LENGTH = 255; @@ -26,39 +26,39 @@ const validationSchema = Joi.object({ organizationId: Joi.number().integer().required(), }); -module.exports = { - checkValidation(supOrganizationLearner) { - const { error } = validationSchema.validate(supOrganizationLearner, validationConfiguration); - if (error) { - const err = EntityValidationError.fromJoiErrors(error.details); - err.key = error.details[0].context.key; - const { type, context } = error.details[0]; - if (type === 'any.required') { - err.why = 'required'; - } - if (type === 'string.max') { - err.why = 'max_length'; - err.limit = context.limit; - } - if (type === 'date.format') { - err.why = 'date_format'; - } - if (type === 'string.email') { - err.why = 'email_format'; - } - if (type === 'string.base') { - err.why = 'not_a_string'; - } - if (type === 'number.base' || type === 'number.integer') { - err.why = 'not_an_integer'; - } - if (type === 'boolean.base') { - err.why = 'not_a_boolean'; - } - if (err.key === 'studentNumber' && type === 'string.pattern.base') { - err.why = 'student_number_format'; - } - throw err; +const checkValidation = function (supOrganizationLearner) { + const { error } = validationSchema.validate(supOrganizationLearner, validationConfiguration); + if (error) { + const err = EntityValidationError.fromJoiErrors(error.details); + err.key = error.details[0].context.key; + const { type, context } = error.details[0]; + if (type === 'any.required') { + err.why = 'required'; } - }, + if (type === 'string.max') { + err.why = 'max_length'; + err.limit = context.limit; + } + if (type === 'date.format') { + err.why = 'date_format'; + } + if (type === 'string.email') { + err.why = 'email_format'; + } + if (type === 'string.base') { + err.why = 'not_a_string'; + } + if (type === 'number.base' || type === 'number.integer') { + err.why = 'not_an_integer'; + } + if (type === 'boolean.base') { + err.why = 'not_a_boolean'; + } + if (err.key === 'studentNumber' && type === 'string.pattern.base') { + err.why = 'student_number_format'; + } + throw err; + } }; + +export { checkValidation }; diff --git a/api/lib/domain/validators/target-profile/base-validation.js b/api/lib/domain/validators/target-profile/base-validation.js index e79e66bcc89..de37d106003 100644 --- a/api/lib/domain/validators/target-profile/base-validation.js +++ b/api/lib/domain/validators/target-profile/base-validation.js @@ -1,7 +1,10 @@ -const Joi = require('joi'); -const { first } = require('lodash'); -const { EntityValidationError } = require('../../errors.js'); -const TargetProfile = require('../../models/TargetProfile.js'); +import Joi from 'joi'; +import lodash from 'lodash'; + +const { first } = lodash; + +import { EntityValidationError } from '../../errors.js'; +import { TargetProfile } from '../../models/TargetProfile.js'; const categories = TargetProfile.categories; @@ -43,7 +46,4 @@ function validate(targetProfile) { return true; } -module.exports = { - validate, - schema, -}; +export { validate, schema }; diff --git a/api/lib/domain/validators/target-profile/creation-command-validation.js b/api/lib/domain/validators/target-profile/creation-command-validation.js index 4d923e33410..d805868bd40 100644 --- a/api/lib/domain/validators/target-profile/creation-command-validation.js +++ b/api/lib/domain/validators/target-profile/creation-command-validation.js @@ -1,6 +1,6 @@ -const Joi = require('joi'); -const { schema: base } = require('./base-validation.js'); -const { EntityValidationError } = require('../../errors.js'); +import Joi from 'joi'; +import { schema as base } from './base-validation.js'; +import { EntityValidationError } from '../../errors.js'; const schema = base.keys({ description: Joi.string().allow(null), @@ -25,6 +25,4 @@ function validate(creationCommand) { return true; } -module.exports = { - validate, -}; +export { validate }; diff --git a/api/lib/domain/validators/user-validator.js b/api/lib/domain/validators/user-validator.js index 49587dd0b96..de5ef8bb2de 100644 --- a/api/lib/domain/validators/user-validator.js +++ b/api/lib/domain/validators/user-validator.js @@ -1,6 +1,6 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const { EntityValidationError } = require('../errors.js'); +import { EntityValidationError } from '../errors.js'; const validationConfiguration = { abortEarly: false, allowUnknown: true }; const userValidationJoiSchema = Joi.object({ @@ -47,12 +47,12 @@ const userValidationJoiSchema = Joi.object({ 'object.missing': 'FILL_USERNAME_OR_EMAIL', }); -module.exports = { - validate({ user, cguRequired = true }) { - const { error } = userValidationJoiSchema.validate(user, { ...validationConfiguration, context: { cguRequired } }); - if (error) { - throw EntityValidationError.fromJoiErrors(error.details); - } - return true; - }, +const validate = function ({ user, cguRequired = true }) { + const { error } = userValidationJoiSchema.validate(user, { ...validationConfiguration, context: { cguRequired } }); + if (error) { + throw EntityValidationError.fromJoiErrors(error.details); + } + return true; }; + +export { validate }; diff --git a/api/lib/infrastructure/DomainTransaction.js b/api/lib/infrastructure/DomainTransaction.js index b1ecdf924b8..89282052a7d 100644 --- a/api/lib/infrastructure/DomainTransaction.js +++ b/api/lib/infrastructure/DomainTransaction.js @@ -1,4 +1,4 @@ -const { knex } = require('../../db/knex-database-connection.js'); +import { knex } from '../../db/knex-database-connection.js'; class DomainTransaction { constructor(knexTransaction) { @@ -15,4 +15,4 @@ class DomainTransaction { return new DomainTransaction(null); } } -module.exports = DomainTransaction; +export { DomainTransaction }; diff --git a/api/lib/infrastructure/adapters/answer-status-database-adapter.js b/api/lib/infrastructure/adapters/answer-status-database-adapter.js index 5443b475e01..0da9974d02d 100644 --- a/api/lib/infrastructure/adapters/answer-status-database-adapter.js +++ b/api/lib/infrastructure/adapters/answer-status-database-adapter.js @@ -1,4 +1,4 @@ -const AnswerStatus = require('../../domain/models/AnswerStatus.js'); +import { AnswerStatus } from '../../domain/models/AnswerStatus.js'; const UNIMPLEMENTED = 'unimplemented'; const TIMEDOUT = 'timedout'; @@ -8,47 +8,44 @@ const FOCUSEDOUT = 'focusedOut'; const OK = 'ok'; const KO = 'ko'; -module.exports = { - /** - * @deprecated use toSQLString instead - */ - adapt(answerStatus) { - return this.toSQLString(answerStatus); - }, +const adapt = function (answerStatus) { + return this.toSQLString(answerStatus); +}; - toSQLString(answerStatus) { - if (answerStatus.isOK()) { - return OK; - } else if (answerStatus.isKO()) { - return KO; - } else if (answerStatus.isSKIPPED()) { - return SKIPPED; - } else if (answerStatus.isPARTIALLY()) { - return PARTIALLY; - } else if (answerStatus.isTIMEDOUT()) { - return TIMEDOUT; - } else if (answerStatus.isFOCUSEDOUT()) { - return FOCUSEDOUT; - } else { - return UNIMPLEMENTED; - } - }, +const toSQLString = function (answerStatus) { + if (answerStatus.isOK()) { + return OK; + } else if (answerStatus.isKO()) { + return KO; + } else if (answerStatus.isSKIPPED()) { + return SKIPPED; + } else if (answerStatus.isPARTIALLY()) { + return PARTIALLY; + } else if (answerStatus.isTIMEDOUT()) { + return TIMEDOUT; + } else if (answerStatus.isFOCUSEDOUT()) { + return FOCUSEDOUT; + } else { + return UNIMPLEMENTED; + } +}; - fromSQLString(answerStatusString) { - if (answerStatusString === OK) { - return AnswerStatus.OK; - } else if (answerStatusString === KO) { - return AnswerStatus.KO; - } else if (answerStatusString === PARTIALLY) { - return AnswerStatus.PARTIALLY; - } else if (answerStatusString === TIMEDOUT) { - return AnswerStatus.TIMEDOUT; - } else if (answerStatusString === SKIPPED) { - return AnswerStatus.SKIPPED; - } else if (answerStatusString === FOCUSEDOUT) { - return AnswerStatus.FOCUSEDOUT; - } else if (answerStatusString === UNIMPLEMENTED) { - return AnswerStatus.UNIMPLEMENTED; - } - }, +const fromSQLString = function (answerStatusString) { + if (answerStatusString === OK) { + return AnswerStatus.OK; + } else if (answerStatusString === KO) { + return AnswerStatus.KO; + } else if (answerStatusString === PARTIALLY) { + return AnswerStatus.PARTIALLY; + } else if (answerStatusString === TIMEDOUT) { + return AnswerStatus.TIMEDOUT; + } else if (answerStatusString === SKIPPED) { + return AnswerStatus.SKIPPED; + } else if (answerStatusString === FOCUSEDOUT) { + return AnswerStatus.FOCUSEDOUT; + } else if (answerStatusString === UNIMPLEMENTED) { + return AnswerStatus.UNIMPLEMENTED; + } }; + +export { adapt, toSQLString, fromSQLString }; diff --git a/api/lib/infrastructure/adapters/answer-status-json-api-adapter.js b/api/lib/infrastructure/adapters/answer-status-json-api-adapter.js index d3d39856ce2..345dc098248 100644 --- a/api/lib/infrastructure/adapters/answer-status-json-api-adapter.js +++ b/api/lib/infrastructure/adapters/answer-status-json-api-adapter.js @@ -26,4 +26,4 @@ const AnswerStatusJsonApiAdapter = { }, }; -module.exports = AnswerStatusJsonApiAdapter; +export { AnswerStatusJsonApiAdapter }; diff --git a/api/lib/infrastructure/adapters/skill-adapter.js b/api/lib/infrastructure/adapters/skill-adapter.js index 79f5c8d7e5e..77297b8bbb5 100644 --- a/api/lib/infrastructure/adapters/skill-adapter.js +++ b/api/lib/infrastructure/adapters/skill-adapter.js @@ -1,16 +1,16 @@ -const Skill = require('../../domain/models/Skill.js'); +import { Skill } from '../../domain/models/Skill.js'; -module.exports = { - fromDatasourceObject(datasourceObject) { - return new Skill({ - id: datasourceObject.id, - name: datasourceObject.name, - pixValue: datasourceObject.pixValue, - competenceId: datasourceObject.competenceId, - tutorialIds: datasourceObject.tutorialIds, - tubeId: datasourceObject.tubeId, - version: datasourceObject.version, - difficulty: datasourceObject.level, - }); - }, +const fromDatasourceObject = function (datasourceObject) { + return new Skill({ + id: datasourceObject.id, + name: datasourceObject.name, + pixValue: datasourceObject.pixValue, + competenceId: datasourceObject.competenceId, + tutorialIds: datasourceObject.tutorialIds, + tubeId: datasourceObject.tubeId, + version: datasourceObject.version, + difficulty: datasourceObject.level, + }); }; + +export { fromDatasourceObject }; diff --git a/api/lib/infrastructure/adapters/solution-adapter.js b/api/lib/infrastructure/adapters/solution-adapter.js index e8f3843b672..e38eadf1cdd 100644 --- a/api/lib/infrastructure/adapters/solution-adapter.js +++ b/api/lib/infrastructure/adapters/solution-adapter.js @@ -1,5 +1,5 @@ -const Solution = require('../../domain/models/Solution.js'); -const _ = require('../../../lib/infrastructure/utils/lodash-utils.js'); +import { Solution } from '../../domain/models/Solution.js'; +import { _ } from '../../../lib/infrastructure/utils/lodash-utils.js'; function statusToBoolean(value) { if (typeof value === 'boolean') { @@ -33,19 +33,19 @@ function _extractTypeOfQroc(datasourceObject) { return qrocBlocksTypes; } -module.exports = { - fromDatasourceObject(datasourceObject) { - const scoring = _.ensureString(datasourceObject.scoring).replace(/@/g, ''); // XXX YAML ne supporte pas @ - const qrocBlocksTypes = _extractTypeOfQroc(datasourceObject); - return new Solution({ - id: datasourceObject.id, - isT1Enabled: statusToBoolean(datasourceObject.t1Status), - isT2Enabled: statusToBoolean(datasourceObject.t2Status), - isT3Enabled: statusToBoolean(datasourceObject.t3Status), - type: datasourceObject.type, - value: datasourceObject.solution, - scoring, - qrocBlocksTypes, - }); - }, +const fromDatasourceObject = function (datasourceObject) { + const scoring = _.ensureString(datasourceObject.scoring).replace(/@/g, ''); // XXX YAML ne supporte pas @ + const qrocBlocksTypes = _extractTypeOfQroc(datasourceObject); + return new Solution({ + id: datasourceObject.id, + isT1Enabled: statusToBoolean(datasourceObject.t1Status), + isT2Enabled: statusToBoolean(datasourceObject.t2Status), + isT3Enabled: statusToBoolean(datasourceObject.t3Status), + type: datasourceObject.type, + value: datasourceObject.solution, + scoring, + qrocBlocksTypes, + }); }; + +export { fromDatasourceObject }; diff --git a/api/lib/infrastructure/adapters/target-profile-adapter.js b/api/lib/infrastructure/adapters/target-profile-adapter.js index 4e664b247a7..3a04f5741ce 100644 --- a/api/lib/infrastructure/adapters/target-profile-adapter.js +++ b/api/lib/infrastructure/adapters/target-profile-adapter.js @@ -1,24 +1,24 @@ -const TargetProfile = require('../../domain/models/TargetProfile.js'); -const Badge = require('../../domain/models/Badge.js'); -const skillAdapter = require('./skill-adapter.js'); +import { TargetProfile } from '../../domain/models/TargetProfile.js'; +import { Badge } from '../../domain/models/Badge.js'; +import * as skillAdapter from './skill-adapter.js'; -module.exports = { - fromDatasourceObjects({ bookshelfTargetProfile, associatedSkillDatasourceObjects = [] }) { - const skills = associatedSkillDatasourceObjects.map(skillAdapter.fromDatasourceObject); - const targetProfileBadges = bookshelfTargetProfile.related('badges'); - const badges = targetProfileBadges?.models?.map((badge) => new Badge(badge.attributes)) ?? []; +const fromDatasourceObjects = function ({ bookshelfTargetProfile, associatedSkillDatasourceObjects = [] }) { + const skills = associatedSkillDatasourceObjects.map(skillAdapter.fromDatasourceObject); + const targetProfileBadges = bookshelfTargetProfile.related('badges'); + const badges = targetProfileBadges?.models?.map((badge) => new Badge(badge.attributes)) ?? []; - return new TargetProfile({ - id: bookshelfTargetProfile.get('id'), - name: bookshelfTargetProfile.get('name'), - imageUrl: bookshelfTargetProfile.get('imageUrl'), - isPublic: Boolean(bookshelfTargetProfile.get('isPublic')), - isSimplifiedAccess: Boolean(bookshelfTargetProfile.get('isSimplifiedAccess')), - ownerOrganizationId: bookshelfTargetProfile.get('ownerOrganizationId'), - outdated: bookshelfTargetProfile.get('outdated'), - skills, - stages: [], - badges, - }); - }, + return new TargetProfile({ + id: bookshelfTargetProfile.get('id'), + name: bookshelfTargetProfile.get('name'), + imageUrl: bookshelfTargetProfile.get('imageUrl'), + isPublic: Boolean(bookshelfTargetProfile.get('isPublic')), + isSimplifiedAccess: Boolean(bookshelfTargetProfile.get('isSimplifiedAccess')), + ownerOrganizationId: bookshelfTargetProfile.get('ownerOrganizationId'), + outdated: bookshelfTargetProfile.get('outdated'), + skills, + stages: [], + badges, + }); }; + +export { fromDatasourceObjects }; diff --git a/api/lib/infrastructure/authentication.js b/api/lib/infrastructure/authentication.js index 361b01bd443..216738d2c75 100644 --- a/api/lib/infrastructure/authentication.js +++ b/api/lib/infrastructure/authentication.js @@ -1,8 +1,11 @@ -const { find } = require('lodash'); -const boom = require('@hapi/boom'); +import lodash from 'lodash'; -const tokenService = require('../domain/services/token-service.js'); -const config = require('../../lib/config.js'); +const { find } = lodash; + +import boom from '@hapi/boom'; + +import { tokenService } from '../domain/services/token-service.js'; +import { config } from '../../lib/config.js'; async function _checkIsAuthenticated(request, h, { key, validate }) { if (!request.headers.authorization) { @@ -49,7 +52,7 @@ function validateClientApplication(decoded) { return { isValid: true, credentials: { client_id: decoded.clientId, scope: decoded.scope, source: decoded.source } }; } -const autentication = { +const authentication = { schemeName: 'jwt-scheme', scheme(_, { key, validate }) { @@ -83,4 +86,4 @@ const autentication = { defaultStrategy: 'jwt-user', }; -module.exports = autentication; +export { authentication }; diff --git a/api/lib/infrastructure/bookshelf.js b/api/lib/infrastructure/bookshelf.js index e499105181b..ba803f79937 100644 --- a/api/lib/infrastructure/bookshelf.js +++ b/api/lib/infrastructure/bookshelf.js @@ -1,8 +1,8 @@ -const validator = require('validator'); -const _ = require('lodash'); +import validator from 'validator'; +import _ from 'lodash'; -const { knex } = require('../../db/knex-database-connection.js'); -const bookshelf = require('bookshelf'); +import { knex } from '../../db/knex-database-connection.js'; +import bookshelf from 'bookshelf'; const bookshelfWithKnex = bookshelf(knex); validator.isRequired = function (value) { @@ -18,4 +18,4 @@ bookshelfWithKnex.plugin('bookshelf-validate', { validator: validator, }); -module.exports = bookshelfWithKnex; +export { bookshelfWithKnex as Bookshelf, knex }; diff --git a/api/lib/infrastructure/caches/Cache.js b/api/lib/infrastructure/caches/Cache.js index 7ef7fbde004..8b733cac24c 100644 --- a/api/lib/infrastructure/caches/Cache.js +++ b/api/lib/infrastructure/caches/Cache.js @@ -12,4 +12,4 @@ class Cache { } } -module.exports = Cache; +export { Cache }; diff --git a/api/lib/infrastructure/caches/DistributedCache.js b/api/lib/infrastructure/caches/DistributedCache.js index dbe275f2622..98402758b72 100644 --- a/api/lib/infrastructure/caches/DistributedCache.js +++ b/api/lib/infrastructure/caches/DistributedCache.js @@ -1,5 +1,5 @@ -const Cache = require('./Cache.js'); -const RedisClient = require('../utils/RedisClient.js'); +import { Cache } from './Cache.js'; +import { RedisClient } from '../utils/RedisClient.js'; class DistributedCache extends Cache { constructor(underlyingCache, redisUrl, channel) { @@ -40,4 +40,4 @@ class DistributedCache extends Cache { } } -module.exports = DistributedCache; +export { DistributedCache }; diff --git a/api/lib/infrastructure/caches/InMemoryCache.js b/api/lib/infrastructure/caches/InMemoryCache.js index 6b5af805838..5d99f54e5ba 100644 --- a/api/lib/infrastructure/caches/InMemoryCache.js +++ b/api/lib/infrastructure/caches/InMemoryCache.js @@ -1,5 +1,5 @@ -const NodeCache = require('node-cache'); -const Cache = require('./Cache.js'); +import NodeCache from 'node-cache'; +import { Cache } from './Cache.js'; class InMemoryCache extends Cache { constructor() { @@ -54,4 +54,4 @@ class InMemoryCache extends Cache { } } -module.exports = InMemoryCache; +export { InMemoryCache }; diff --git a/api/lib/infrastructure/caches/LayeredCache.js b/api/lib/infrastructure/caches/LayeredCache.js index d76efbde4ad..441acb11d83 100644 --- a/api/lib/infrastructure/caches/LayeredCache.js +++ b/api/lib/infrastructure/caches/LayeredCache.js @@ -1,4 +1,4 @@ -const Cache = require('./Cache.js'); +import { Cache } from './Cache.js'; class LayeredCache extends Cache { constructor(firstLevelCache, secondLevelCache) { @@ -29,4 +29,4 @@ class LayeredCache extends Cache { } } -module.exports = LayeredCache; +export { LayeredCache }; diff --git a/api/lib/infrastructure/caches/RedisCache.js b/api/lib/infrastructure/caches/RedisCache.js index 0fe5c8816c2..f2056c3e36e 100644 --- a/api/lib/infrastructure/caches/RedisCache.js +++ b/api/lib/infrastructure/caches/RedisCache.js @@ -1,9 +1,12 @@ -const { using } = require('bluebird'); -const Redlock = require('redlock'); -const Cache = require('./Cache.js'); -const RedisClient = require('../utils/RedisClient.js'); -const logger = require('../logger.js'); -const settings = require('../../config.js'); +import bluebird from 'bluebird'; + +const { using } = bluebird; + +import Redlock from 'redlock'; +import { Cache } from './Cache.js'; +import { RedisClient } from '../utils/RedisClient.js'; +import { logger } from '../logger.js'; +import { config } from '../../config.js'; const REDIS_LOCK_PREFIX = 'locks:'; @@ -35,13 +38,13 @@ class RedisCache extends Cache { const unlockErrorHandler = (err) => logger.error({ key }, 'Error while trying to unlock Redis key', err); try { - const locker = this._client.lockDisposer(keyToLock, settings.caching.redisCacheKeyLockTTL, unlockErrorHandler); + const locker = this._client.lockDisposer(keyToLock, config.caching.redisCacheKeyLockTTL, unlockErrorHandler); const value = await using(locker, retrieveAndSetValue); return value; } catch (err) { if (err instanceof Redlock.LockError) { logger.trace({ keyToLock }, 'Could not lock Redis key, waiting'); - await new Promise((resolve) => setTimeout(resolve, settings.caching.redisCacheLockedWaitBeforeRetry)); + await new Promise((resolve) => setTimeout(resolve, config.caching.redisCacheLockedWaitBeforeRetry)); return this.get(key, generator); } logger.error({ err }, 'Error while trying to update value in Redis cache'); @@ -70,4 +73,4 @@ class RedisCache extends Cache { } } -module.exports = RedisCache; +export { RedisCache }; diff --git a/api/lib/infrastructure/caches/learning-content-cache.js b/api/lib/infrastructure/caches/learning-content-cache.js index 4d391fe6e73..9a9b1469341 100644 --- a/api/lib/infrastructure/caches/learning-content-cache.js +++ b/api/lib/infrastructure/caches/learning-content-cache.js @@ -1,9 +1,9 @@ -const Cache = require('./Cache.js'); -const DistributedCache = require('./DistributedCache.js'); -const InMemoryCache = require('./InMemoryCache.js'); -const LayeredCache = require('./LayeredCache.js'); -const RedisCache = require('./RedisCache.js'); -const settings = require('../../config.js'); +import { Cache } from './Cache.js'; +import { DistributedCache } from './DistributedCache.js'; +import { InMemoryCache } from './InMemoryCache.js'; +import { LayeredCache } from './LayeredCache.js'; +import { RedisCache } from './RedisCache.js'; +import { config } from '../../config.js'; const LEARNING_CONTENT_CHANNEL = 'Learning content'; const LEARNING_CONTENT_CACHE_KEY = 'LearningContent'; @@ -11,13 +11,13 @@ const LEARNING_CONTENT_CACHE_KEY = 'LearningContent'; class LearningContentCache extends Cache { constructor() { super(); - if (settings.caching.redisUrl) { + if (config.caching.redisUrl) { this.distributedCache = new DistributedCache( new InMemoryCache(), - settings.caching.redisUrl, + config.caching.redisUrl, LEARNING_CONTENT_CHANNEL ); - this.redisCache = new RedisCache(settings.caching.redisUrl); + this.redisCache = new RedisCache(config.caching.redisUrl); this._underlyingCache = new LayeredCache(this.distributedCache, this.redisCache); } else { @@ -44,4 +44,4 @@ class LearningContentCache extends Cache { const learningContentCache = new LearningContentCache(); -module.exports = { learningContentCache }; +export { learningContentCache }; diff --git a/api/lib/infrastructure/constants.js b/api/lib/infrastructure/constants.js index f921ad6cbcb..238fc3e4ecd 100644 --- a/api/lib/infrastructure/constants.js +++ b/api/lib/infrastructure/constants.js @@ -1,8 +1,8 @@ -const settings = require('../config.js'); +import { config } from '../config.js'; -const CONCURRENCY_HEAVY_OPERATIONS = settings.infra.concurrencyForHeavyOperations; -const CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING = settings.infra.chunkSizeForCampaignResultProcessing; -const ORGANIZATION_LEARNER_CHUNK_SIZE = settings.infra.chunkSizeForOrganizationLearnerDataProcessing; +const CONCURRENCY_HEAVY_OPERATIONS = config.infra.concurrencyForHeavyOperations; +const CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING = config.infra.chunkSizeForCampaignResultProcessing; +const ORGANIZATION_LEARNER_CHUNK_SIZE = config.infra.chunkSizeForOrganizationLearnerDataProcessing; const constants = { CONCURRENCY_HEAVY_OPERATIONS, @@ -10,7 +10,7 @@ const constants = { ORGANIZATION_LEARNER_CHUNK_SIZE, }; -module.exports = { +export { constants, CONCURRENCY_HEAVY_OPERATIONS, CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING, diff --git a/api/lib/infrastructure/datasources/learning-content/LearningContentResourceNotFound.js b/api/lib/infrastructure/datasources/learning-content/LearningContentResourceNotFound.js index 6908bf1a924..eb3a2236a78 100644 --- a/api/lib/infrastructure/datasources/learning-content/LearningContentResourceNotFound.js +++ b/api/lib/infrastructure/datasources/learning-content/LearningContentResourceNotFound.js @@ -4,4 +4,4 @@ class LearningContentResourceNotFound extends Error { } } -module.exports = LearningContentResourceNotFound; +export { LearningContentResourceNotFound }; diff --git a/api/lib/infrastructure/datasources/learning-content/area-datasource.js b/api/lib/infrastructure/datasources/learning-content/area-datasource.js index 9b07eb1e362..8ed27e85384 100644 --- a/api/lib/infrastructure/datasources/learning-content/area-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/area-datasource.js @@ -1,4 +1,4 @@ -const datasource = require('./datasource.js'); +import * as datasource from './datasource.js'; const areaDatasource = datasource.extend({ modelName: 'areas', @@ -13,4 +13,4 @@ const areaDatasource = datasource.extend({ }, }); -module.exports = { areaDatasource }; +export { areaDatasource }; diff --git a/api/lib/infrastructure/datasources/learning-content/challenge-datasource.js b/api/lib/infrastructure/datasources/learning-content/challenge-datasource.js index ae34c087dd9..01c5d977922 100644 --- a/api/lib/infrastructure/datasources/learning-content/challenge-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/challenge-datasource.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const datasource = require('./datasource.js'); +import _ from 'lodash'; +import * as datasource from './datasource.js'; const VALIDATED_CHALLENGE = 'validé'; const OPERATIVE_CHALLENGES = [VALIDATED_CHALLENGE, 'archivé']; @@ -65,4 +65,4 @@ const challengeDatasource = datasource.extend({ }, }); -module.exports = { challengeDatasource }; +export { challengeDatasource }; diff --git a/api/lib/infrastructure/datasources/learning-content/competence-datasource.js b/api/lib/infrastructure/datasources/learning-content/competence-datasource.js index fe551efe8fe..3966dfc8172 100644 --- a/api/lib/infrastructure/datasources/learning-content/competence-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/competence-datasource.js @@ -1,4 +1,4 @@ -const datasource = require('./datasource.js'); +import * as datasource from './datasource.js'; const competenceDatasource = datasource.extend({ modelName: 'competences', @@ -9,4 +9,4 @@ const competenceDatasource = datasource.extend({ }, }); -module.exports = { competenceDatasource }; +export { competenceDatasource }; diff --git a/api/lib/infrastructure/datasources/learning-content/course-datasource.js b/api/lib/infrastructure/datasources/learning-content/course-datasource.js index 877cd84912e..38ec69dcdc8 100644 --- a/api/lib/infrastructure/datasources/learning-content/course-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/course-datasource.js @@ -1,7 +1,7 @@ -const datasource = require('./datasource.js'); +import * as datasource from './datasource.js'; const courseDatasource = datasource.extend({ modelName: 'courses', }); -module.exports = { courseDatasource }; +export { courseDatasource }; diff --git a/api/lib/infrastructure/datasources/learning-content/datasource.js b/api/lib/infrastructure/datasources/learning-content/datasource.js index 68c26533485..af2ed6ec49e 100644 --- a/api/lib/infrastructure/datasources/learning-content/datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/datasource.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const lcms = require('../../lcms.js'); -const LearningContentResourceNotFound = require('./LearningContentResourceNotFound.js'); -const { learningContentCache } = require('../../caches/learning-content-cache.js'); +import _ from 'lodash'; +import { lcms } from '../../lcms.js'; +import { LearningContentResourceNotFound } from './LearningContentResourceNotFound.js'; +import { learningContentCache } from '../../caches/learning-content-cache.js'; const _DatasourcePrototype = { async get(id) { @@ -51,16 +51,16 @@ const _DatasourcePrototype = { }, }; -module.exports = { - extend(props) { - const result = Object.assign({}, _DatasourcePrototype, props); - _.bindAll(result, _.functions(result)); - return result; - }, +const extend = function (props) { + const result = Object.assign({}, _DatasourcePrototype, props); + _.bindAll(result, _.functions(result)); + return result; +}; - async refreshLearningContentCacheRecords() { - const learningContent = await lcms.getLatestRelease(); - await learningContentCache.set(learningContent); - return learningContent; - }, +const refreshLearningContentCacheRecords = async function () { + const learningContent = await lcms.getLatestRelease(); + await learningContentCache.set(learningContent); + return learningContent; }; + +export { extend, refreshLearningContentCacheRecords }; diff --git a/api/lib/infrastructure/datasources/learning-content/framework-datasource.js b/api/lib/infrastructure/datasources/learning-content/framework-datasource.js index 9d8fd785cb5..51417f11d7d 100644 --- a/api/lib/infrastructure/datasources/learning-content/framework-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/framework-datasource.js @@ -1,4 +1,4 @@ -const datasource = require('./datasource.js'); +import * as datasource from './datasource.js'; const frameworkDatasource = datasource.extend({ modelName: 'frameworks', @@ -14,4 +14,4 @@ const frameworkDatasource = datasource.extend({ }, }); -module.exports = { frameworkDatasource }; +export { frameworkDatasource }; diff --git a/api/lib/infrastructure/datasources/learning-content/index.js b/api/lib/infrastructure/datasources/learning-content/index.js index 30c550e603c..d2936b0b2cc 100644 --- a/api/lib/infrastructure/datasources/learning-content/index.js +++ b/api/lib/infrastructure/datasources/learning-content/index.js @@ -1,12 +1,12 @@ -const { areaDatasource } = require('./area-datasource.js'); -const { challengeDatasource } = require('./challenge-datasource.js'); -const { competenceDatasource } = require('./competence-datasource.js'); -const { courseDatasource } = require('./course-datasource.js'); -const { skillDatasource } = require('./skill-datasource.js'); -const { tubeDatasource } = require('./tube-datasource.js'); -const { tutorialDatasource } = require('./tutorial-datasource.js'); +import { areaDatasource } from './area-datasource.js'; +import { challengeDatasource } from './challenge-datasource.js'; +import { competenceDatasource } from './competence-datasource.js'; +import { courseDatasource } from './course-datasource.js'; +import { skillDatasource } from './skill-datasource.js'; +import { tubeDatasource } from './tube-datasource.js'; +import { tutorialDatasource } from './tutorial-datasource.js'; -module.exports = { +export { areaDatasource, challengeDatasource, competenceDatasource, diff --git a/api/lib/infrastructure/datasources/learning-content/skill-datasource.js b/api/lib/infrastructure/datasources/learning-content/skill-datasource.js index 83abb2dd1b1..412bddcd032 100644 --- a/api/lib/infrastructure/datasources/learning-content/skill-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/skill-datasource.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const datasource = require('./datasource.js'); +import _ from 'lodash'; +import * as datasource from './datasource.js'; const ACTIVE_STATUS = 'actif'; const OPERATIVE_STATUSES = ['actif', 'archivé']; @@ -61,4 +61,4 @@ const skillDatasource = datasource.extend({ }, }); -module.exports = { skillDatasource }; +export { skillDatasource }; diff --git a/api/lib/infrastructure/datasources/learning-content/thematic-datasource.js b/api/lib/infrastructure/datasources/learning-content/thematic-datasource.js index 55e4e14bccf..d86f066ffd3 100644 --- a/api/lib/infrastructure/datasources/learning-content/thematic-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/thematic-datasource.js @@ -1,4 +1,4 @@ -const datasource = require('./datasource.js'); +import * as datasource from './datasource.js'; const thematicDatasource = datasource.extend({ modelName: 'thematics', @@ -14,4 +14,4 @@ const thematicDatasource = datasource.extend({ }, }); -module.exports = { thematicDatasource }; +export { thematicDatasource }; diff --git a/api/lib/infrastructure/datasources/learning-content/tube-datasource.js b/api/lib/infrastructure/datasources/learning-content/tube-datasource.js index 098dd13357d..39c2b0da8cc 100644 --- a/api/lib/infrastructure/datasources/learning-content/tube-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/tube-datasource.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const datasource = require('./datasource.js'); +import _ from 'lodash'; +import * as datasource from './datasource.js'; const tubeDatasource = datasource.extend({ modelName: 'tubes', @@ -15,4 +15,4 @@ const tubeDatasource = datasource.extend({ }, }); -module.exports = { tubeDatasource }; +export { tubeDatasource }; diff --git a/api/lib/infrastructure/datasources/learning-content/tutorial-datasource.js b/api/lib/infrastructure/datasources/learning-content/tutorial-datasource.js index 800b8dc5b1a..bcb7fb02659 100644 --- a/api/lib/infrastructure/datasources/learning-content/tutorial-datasource.js +++ b/api/lib/infrastructure/datasources/learning-content/tutorial-datasource.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const datasource = require('./datasource.js'); +import _ from 'lodash'; +import * as datasource from './datasource.js'; const tutorialDatasource = datasource.extend({ modelName: 'tutorials', @@ -9,4 +9,4 @@ const tutorialDatasource = datasource.extend({ return tutorials.filter((tutorialData) => _.includes(tutorialRecordIds, tutorialData.id)); }, }); -module.exports = { tutorialDatasource }; +export { tutorialDatasource }; diff --git a/api/lib/infrastructure/events/EventBus.js b/api/lib/infrastructure/events/EventBus.js index e9fbb31b588..641735ae3fd 100644 --- a/api/lib/infrastructure/events/EventBus.js +++ b/api/lib/infrastructure/events/EventBus.js @@ -1,4 +1,4 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; class SubscriberList { constructor() { @@ -47,4 +47,4 @@ class EventBus { } } -module.exports = EventBus; +export { EventBus }; diff --git a/api/lib/infrastructure/events/EventBusBuilder.js b/api/lib/infrastructure/events/EventBusBuilder.js index 328feeadf71..b96a5cd8f95 100644 --- a/api/lib/infrastructure/events/EventBusBuilder.js +++ b/api/lib/infrastructure/events/EventBusBuilder.js @@ -1,8 +1,8 @@ -const EventBus = require('./EventBus.js'); -const dependenciesBuilder = require('./EventHandlerDependenciesBuilder.js'); -const LogEvent = require('./subscribers/LogEvent.js'); -const ScheduleParticipationResultCalculationJob = require('./subscribers/ScheduleParticipationResultCalculationJob.js'); -const ScheduleSendSharedParticipationResultsToPoleEmploiJob = require('./subscribers/ScheduleSendSharedParticipationResultsToPoleEmploiJob.js'); +import { EventBus } from './EventBus.js'; +import * as dependenciesBuilder from './EventHandlerDependenciesBuilder.js'; +import { LogEvent } from './subscribers/LogEvent.js'; +import { ScheduleParticipationResultCalculationJob } from './subscribers/ScheduleParticipationResultCalculationJob.js'; +import { ScheduleSendSharedParticipationResultsToPoleEmploiJob } from './subscribers/ScheduleSendSharedParticipationResultsToPoleEmploiJob.js'; const subscribers = [ LogEvent, @@ -20,6 +20,4 @@ function build() { return eventBus; } -module.exports = { - build, -}; +export { build }; diff --git a/api/lib/infrastructure/events/EventDispatcher.js b/api/lib/infrastructure/events/EventDispatcher.js index 93ca9ac8d2e..1ff498ebde9 100644 --- a/api/lib/infrastructure/events/EventDispatcher.js +++ b/api/lib/infrastructure/events/EventDispatcher.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; class EventDispatcher { constructor(logger) { @@ -72,4 +72,4 @@ class EventQueue { } } -module.exports = EventDispatcher; +export { EventDispatcher }; diff --git a/api/lib/infrastructure/events/EventDispatcherLogger.js b/api/lib/infrastructure/events/EventDispatcherLogger.js index baa747c7901..181c642ad7f 100644 --- a/api/lib/infrastructure/events/EventDispatcherLogger.js +++ b/api/lib/infrastructure/events/EventDispatcherLogger.js @@ -52,4 +52,4 @@ function buildLogBody({ event, eventHandlerName, error, duration }) { }; } -module.exports = EventDispatcherLogger; +export { EventDispatcherLogger }; diff --git a/api/lib/infrastructure/events/EventHandlerDependenciesBuilder.js b/api/lib/infrastructure/events/EventHandlerDependenciesBuilder.js index d635e705913..80f883819ad 100644 --- a/api/lib/infrastructure/events/EventHandlerDependenciesBuilder.js +++ b/api/lib/infrastructure/events/EventHandlerDependenciesBuilder.js @@ -1,6 +1,6 @@ -const monitoringTools = require('../../infrastructure/monitoring-tools.js'); -const ParticipationResultCalculationJob = require('../jobs/campaign-result/ParticipationResultCalculationJob.js'); -const SendSharedParticipationResultsToPoleEmploiJob = require('../jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob.js'); +import { monitoringTools } from '../../infrastructure/monitoring-tools.js'; +import { ParticipationResultCalculationJob } from '../jobs/campaign-result/ParticipationResultCalculationJob.js'; +import { SendSharedParticipationResultsToPoleEmploiJob } from '../jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob.js'; function build(classToInstanciate, domainTransaction) { const dependencies = _buildDependencies(domainTransaction); @@ -19,9 +19,7 @@ function _buildDependencies(domainTransaction) { }; } -module.exports = { - build, -}; +export { build }; class EventErrorHandler { constructor(handler, logger) { diff --git a/api/lib/infrastructure/events/subscribers/LogEvent.js b/api/lib/infrastructure/events/subscribers/LogEvent.js index be45d0e9f79..b8e92bd3cbe 100644 --- a/api/lib/infrastructure/events/subscribers/LogEvent.js +++ b/api/lib/infrastructure/events/subscribers/LogEvent.js @@ -1,4 +1,4 @@ -const Event = require('../../../domain/events/CampaignParticipationResultsShared.js'); +import { CampaignParticipationResultsShared } from '../../../domain/events/CampaignParticipationResultsShared.js'; class LogEvent { constructor({ monitoringTools }) { @@ -15,6 +15,6 @@ class LogEvent { } } -LogEvent.event = Event; +LogEvent.event = CampaignParticipationResultsShared; -module.exports = LogEvent; +export { LogEvent }; diff --git a/api/lib/infrastructure/events/subscribers/ScheduleParticipationResultCalculationJob.js b/api/lib/infrastructure/events/subscribers/ScheduleParticipationResultCalculationJob.js index 3dc22b227c5..634d06a6fb5 100644 --- a/api/lib/infrastructure/events/subscribers/ScheduleParticipationResultCalculationJob.js +++ b/api/lib/infrastructure/events/subscribers/ScheduleParticipationResultCalculationJob.js @@ -1,4 +1,4 @@ -const Event = require('../../../domain/events/CampaignParticipationResultsShared.js'); +import { CampaignParticipationResultsShared } from '../../../domain/events/CampaignParticipationResultsShared.js'; class ScheduleParticipationResultCalculationJob { constructor({ participationResultCalculationJob }) { @@ -14,6 +14,6 @@ class ScheduleParticipationResultCalculationJob { } } -ScheduleParticipationResultCalculationJob.event = Event; +ScheduleParticipationResultCalculationJob.event = CampaignParticipationResultsShared; -module.exports = ScheduleParticipationResultCalculationJob; +export { ScheduleParticipationResultCalculationJob }; diff --git a/api/lib/infrastructure/events/subscribers/ScheduleSendSharedParticipationResultsToPoleEmploiJob.js b/api/lib/infrastructure/events/subscribers/ScheduleSendSharedParticipationResultsToPoleEmploiJob.js index 2c4b3820d37..2aa8c6662b6 100644 --- a/api/lib/infrastructure/events/subscribers/ScheduleSendSharedParticipationResultsToPoleEmploiJob.js +++ b/api/lib/infrastructure/events/subscribers/ScheduleSendSharedParticipationResultsToPoleEmploiJob.js @@ -1,4 +1,4 @@ -const Event = require('../../../domain/events/CampaignParticipationResultsShared.js'); +import { CampaignParticipationResultsShared } from '../../../domain/events/CampaignParticipationResultsShared.js'; class ScheduleParticipationResultCalculationJob { constructor({ sendSharedParticipationResultsToPoleEmploiJob }) { @@ -14,6 +14,6 @@ class ScheduleParticipationResultCalculationJob { } } -ScheduleParticipationResultCalculationJob.event = Event; +ScheduleParticipationResultCalculationJob.event = CampaignParticipationResultsShared; -module.exports = ScheduleParticipationResultCalculationJob; +export { ScheduleParticipationResultCalculationJob as ScheduleSendSharedParticipationResultsToPoleEmploiJob }; diff --git a/api/lib/infrastructure/exports/campaigns/campaign-profiles-collection-result-line.js b/api/lib/infrastructure/exports/campaigns/campaign-profiles-collection-result-line.js index 9e229dae0de..f35e39acf4b 100644 --- a/api/lib/infrastructure/exports/campaigns/campaign-profiles-collection-result-line.js +++ b/api/lib/infrastructure/exports/campaigns/campaign-profiles-collection-result-line.js @@ -1,5 +1,5 @@ -const csvSerializer = require('../../serializers/csv/csv-serializer.js'); -const moment = require('moment'); +import * as csvSerializer from '../../serializers/csv/csv-serializer.js'; +import moment from 'moment'; const EMPTY_ARRAY = []; @@ -112,4 +112,4 @@ class CampaignProfilesCollectionResultLine { } } -module.exports = CampaignProfilesCollectionResultLine; +export { CampaignProfilesCollectionResultLine }; diff --git a/api/lib/infrastructure/external-storage/cpf-external-storage.js b/api/lib/infrastructure/external-storage/cpf-external-storage.js index 7ab467f13be..284393a3aef 100644 --- a/api/lib/infrastructure/external-storage/cpf-external-storage.js +++ b/api/lib/infrastructure/external-storage/cpf-external-storage.js @@ -1,52 +1,53 @@ -const s3Utils = require('./s3-utils.js'); -const { cpf } = require('../../config.js'); -const logger = require('../logger.js'); - -module.exports = { - upload: async function ({ filename, readableStream, dependencies = { s3Utils, logger } }) { - dependencies.logger.trace('cpfExternalStorage: start upload'); - - const { accessKeyId, secretAccessKey, endpoint, region, bucket } = cpf.storage; - const s3Client = dependencies.s3Utils.getS3Client({ - accessKeyId, - secretAccessKey, - endpoint, - region, - }); - - const upload = dependencies.s3Utils.startUpload({ - client: s3Client, - filename, - bucket, - readableStream, - }); - - upload.on('httpUploadProgress', (progress) => dependencies.logger.trace(progress)); - - await upload.done(); - dependencies.logger.trace(`cpfExternalStorage: ${filename} upload done`); - }, - - getPreSignUrlsOfFilesModifiedAfter: async function ({ date, dependencies = { s3Utils } }) { - const { accessKeyId, secretAccessKey, endpoint, region, bucket, preSignedExpiresIn: expiresIn } = cpf.storage; - const s3Client = dependencies.s3Utils.getS3Client({ - accessKeyId, - secretAccessKey, - endpoint, - region, - }); - - const filesInBucket = await dependencies.s3Utils.listFiles({ client: s3Client, bucket }); - - const keysOfFilesModifiedAfter = filesInBucket?.Contents.filter(({ LastModified }) => LastModified >= date).map( - ({ Key }) => Key - ); - - return await dependencies.s3Utils.preSignFiles({ - client: s3Client, - bucket, - keys: keysOfFilesModifiedAfter, - expiresIn, - }); - }, +import * as s3Utils from './s3-utils.js'; +import { config } from '../../config.js'; +import { logger } from '../logger.js'; +const { cpf } = config; + +const upload = async function ({ filename, readableStream, dependencies = { s3Utils, logger } }) { + dependencies.logger.trace('cpfExternalStorage: start upload'); + + const { accessKeyId, secretAccessKey, endpoint, region, bucket } = cpf.storage; + const s3Client = dependencies.s3Utils.getS3Client({ + accessKeyId, + secretAccessKey, + endpoint, + region, + }); + + const upload = dependencies.s3Utils.startUpload({ + client: s3Client, + filename, + bucket, + readableStream, + }); + + upload.on('httpUploadProgress', (progress) => dependencies.logger.trace(progress)); + + await upload.done(); + dependencies.logger.trace(`cpfExternalStorage: ${filename} upload done`); }; + +const getPreSignUrlsOfFilesModifiedAfter = async function ({ date, dependencies = { s3Utils } }) { + const { accessKeyId, secretAccessKey, endpoint, region, bucket, preSignedExpiresIn: expiresIn } = cpf.storage; + const s3Client = dependencies.s3Utils.getS3Client({ + accessKeyId, + secretAccessKey, + endpoint, + region, + }); + + const filesInBucket = await dependencies.s3Utils.listFiles({ client: s3Client, bucket }); + + const keysOfFilesModifiedAfter = filesInBucket?.Contents.filter(({ LastModified }) => LastModified >= date).map( + ({ Key }) => Key + ); + + return await dependencies.s3Utils.preSignFiles({ + client: s3Client, + bucket, + keys: keysOfFilesModifiedAfter, + expiresIn, + }); +}; + +export { upload, getPreSignUrlsOfFilesModifiedAfter }; diff --git a/api/lib/infrastructure/external-storage/s3-utils.js b/api/lib/infrastructure/external-storage/s3-utils.js index b670927ac1a..b1d63d23008 100644 --- a/api/lib/infrastructure/external-storage/s3-utils.js +++ b/api/lib/infrastructure/external-storage/s3-utils.js @@ -1,35 +1,39 @@ -const { S3Client, ListObjectsV2Command, GetObjectCommand } = require('@aws-sdk/client-s3'); -const { Upload } = require('@aws-sdk/lib-storage'); -const { getSignedUrl } = require('@aws-sdk/s3-request-presigner'); -const bluebird = require('bluebird'); +import { S3Client, ListObjectsV2Command, GetObjectCommand } from '@aws-sdk/client-s3'; +import { Upload } from '@aws-sdk/lib-storage'; +import { getSignedUrl } from '@aws-sdk/s3-request-presigner'; -module.exports = { - getS3Client({ accessKeyId, secretAccessKey, endpoint, region }) { - return new S3Client({ - credentials: { accessKeyId, secretAccessKey }, - endpoint, - region, - }); - }, - startUpload({ client, filename, bucket, readableStream }) { - return new Upload({ - client, - params: { - Key: filename, - Bucket: bucket, - ContentType: 'gzip', - Body: readableStream, - partSize: 1024 * 1024 * 5, - }, - }); - }, - async listFiles({ client, bucket }) { - return client.send(new ListObjectsV2Command({ Bucket: bucket })); - }, - async preSignFiles({ client, bucket, keys, expiresIn }) { - return bluebird.mapSeries(keys, async (key) => { - const getObjectCommand = new GetObjectCommand({ Bucket: bucket, Key: key }); - return await getSignedUrl(client, getObjectCommand, { expiresIn }); - }); - }, +import bluebird from 'bluebird'; + +const getS3Client = function ({ accessKeyId, secretAccessKey, endpoint, region }) { + return new S3Client({ + credentials: { accessKeyId, secretAccessKey }, + endpoint, + region, + }); +}; + +const startUpload = function ({ client, filename, bucket, readableStream }) { + return new Upload({ + client, + params: { + Key: filename, + Bucket: bucket, + ContentType: 'gzip', + Body: readableStream, + partSize: 1024 * 1024 * 5, + }, + }); +}; + +const listFiles = async function ({ client, bucket }) { + return client.send(new ListObjectsV2Command({ Bucket: bucket })); +}; + +const preSignFiles = async function ({ client, bucket, keys, expiresIn }) { + return bluebird.mapSeries(keys, async (key) => { + const getObjectCommand = new GetObjectCommand({ Bucket: bucket, Key: key }); + return await getSignedUrl(client, getObjectCommand, { expiresIn }); + }); }; + +export { getS3Client, startUpload, listFiles, preSignFiles }; diff --git a/api/lib/infrastructure/externals/pole-emploi/PoleEmploiPayload.js b/api/lib/infrastructure/externals/pole-emploi/PoleEmploiPayload.js index bdaa79fb952..9d38fc65b9f 100644 --- a/api/lib/infrastructure/externals/pole-emploi/PoleEmploiPayload.js +++ b/api/lib/infrastructure/externals/pole-emploi/PoleEmploiPayload.js @@ -1,5 +1,5 @@ -const _ = require('lodash'); -const config = require('../../../config.js'); +import _ from 'lodash'; +import { config } from '../../../config.js'; const CAMPAIGN_TYPE = 'EVALUATION'; const STRUCTURE_NAME = 'Pix'; @@ -159,4 +159,4 @@ function _getTypeTest(targetProfileName) { return PROFILE_TYPES.CP; } -module.exports = PoleEmploiPayload; +export { PoleEmploiPayload }; diff --git a/api/lib/infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js b/api/lib/infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js index e4a397492b5..dbd830ff804 100644 --- a/api/lib/infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js +++ b/api/lib/infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js @@ -1,8 +1,8 @@ -module.exports = { - async notify() { - return { - isSuccessful: false, - code: 'SENDING-DISABLED', - }; - }, +const notify = async function () { + return { + isSuccessful: false, + code: 'SENDING-DISABLED', + }; }; + +export { notify }; diff --git a/api/lib/infrastructure/externals/pole-emploi/pole-emploi-notifier.js b/api/lib/infrastructure/externals/pole-emploi/pole-emploi-notifier.js index 1a2e55f7607..5c79ae4a5ae 100644 --- a/api/lib/infrastructure/externals/pole-emploi/pole-emploi-notifier.js +++ b/api/lib/infrastructure/externals/pole-emploi/pole-emploi-notifier.js @@ -1,115 +1,118 @@ -const get = require('lodash/get'); -const moment = require('moment'); -const querystring = require('querystring'); -const monitoringTools = require('../../monitoring-tools.js'); -const authenticationMethodRepository = require('../../repositories/authentication-method-repository.js'); -const AuthenticationMethod = require('../../../domain/models/AuthenticationMethod.js'); -const OidcIdentityProviders = require('../../../domain/constants/oidc-identity-providers.js'); -const httpAgent = require('../../http/http-agent.js'); -const settings = require('../../../config.js'); -const { UnexpectedUserAccountError } = require('../../../domain/errors.js'); -const httpErrorsHelper = require('../../../infrastructure/http/errors-helper.js'); +import lodash from 'lodash'; -module.exports = { - async notify(userId, payload) { +const { get } = lodash; + +import moment from 'moment'; +import querystring from 'querystring'; +import { monitoringTools } from '../../monitoring-tools.js'; +import * as authenticationMethodRepository from '../../repositories/authentication-method-repository.js'; +import { AuthenticationMethod } from '../../../domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../../domain/constants/oidc-identity-providers.js'; +import { httpAgent } from '../../http/http-agent.js'; +import { config } from '../../../config.js'; +import { UnexpectedUserAccountError } from '../../../domain/errors.js'; +import * as httpErrorsHelper from '../../../infrastructure/http/errors-helper.js'; + +const notify = async function (userId, payload) { + monitoringTools.logInfoWithCorrelationIds({ + event: 'participation-send-pole-emploi', + 'pole-emploi-action': 'send-results', + 'participation-state': participationState(payload), + }); + const authenticationMethod = await authenticationMethodRepository.findOneByUserIdAndIdentityProvider({ + userId, + identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code, + }); + let accessToken = get(authenticationMethod, 'authenticationComplement.accessToken'); + if (!accessToken) { + throw new UnexpectedUserAccountError({ + message: "Le compte utilisateur n'est pas rattaché à l'organisation Pôle Emploi", + }); + } + + const expiredDate = get(authenticationMethod, 'authenticationComplement.expiredDate'); + const refreshToken = get(authenticationMethod, 'authenticationComplement.refreshToken'); + if (!refreshToken || new Date(expiredDate) <= new Date()) { monitoringTools.logInfoWithCorrelationIds({ event: 'participation-send-pole-emploi', - 'pole-emploi-action': 'send-results', + 'pole-emploi-action': 'refresh-token', 'participation-state': participationState(payload), + 'expired-date': expiredDate, }); - const authenticationMethod = await authenticationMethodRepository.findOneByUserIdAndIdentityProvider({ - userId, - identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code, + const data = { + grant_type: 'refresh_token', + refresh_token: refreshToken, + client_secret: config.poleEmploi.clientSecret, + client_id: config.poleEmploi.clientId, + }; + + const tokenResponse = await httpAgent.post({ + url: config.poleEmploi.tokenUrl, + payload: querystring.stringify(data), + headers: { 'content-type': 'application/x-www-form-urlencoded' }, + timeout: config.partner.fetchTimeOut, }); - let accessToken = get(authenticationMethod, 'authenticationComplement.accessToken'); - if (!accessToken) { - throw new UnexpectedUserAccountError({ - message: "Le compte utilisateur n'est pas rattaché à l'organisation Pôle Emploi", - }); - } - const expiredDate = get(authenticationMethod, 'authenticationComplement.expiredDate'); - const refreshToken = get(authenticationMethod, 'authenticationComplement.refreshToken'); - if (!refreshToken || new Date(expiredDate) <= new Date()) { - monitoringTools.logInfoWithCorrelationIds({ + if (!tokenResponse.isSuccessful) { + const serializedError = httpErrorsHelper.serializeHttpErrorResponse(tokenResponse); + monitoringTools.logErrorWithCorrelationIds({ event: 'participation-send-pole-emploi', 'pole-emploi-action': 'refresh-token', 'participation-state': participationState(payload), - 'expired-date': expiredDate, + message: serializedError, }); - const data = { - grant_type: 'refresh_token', - refresh_token: refreshToken, - client_secret: settings.poleEmploi.clientSecret, - client_id: settings.poleEmploi.clientId, + return { + isSuccessful: tokenResponse.isSuccessful, + code: tokenResponse.code || '500', }; + } - const tokenResponse = await httpAgent.post({ - url: settings.poleEmploi.tokenUrl, - payload: querystring.stringify(data), - headers: { 'content-type': 'application/x-www-form-urlencoded' }, - timeout: settings.partner.fetchTimeOut, - }); - - if (!tokenResponse.isSuccessful) { - const serializedError = httpErrorsHelper.serializeHttpErrorResponse(tokenResponse); - monitoringTools.logErrorWithCorrelationIds({ - event: 'participation-send-pole-emploi', - 'pole-emploi-action': 'refresh-token', - 'participation-state': participationState(payload), - message: serializedError, - }); - return { - isSuccessful: tokenResponse.isSuccessful, - code: tokenResponse.code || '500', - }; - } + accessToken = tokenResponse.data['access_token']; + const authenticationComplement = new AuthenticationMethod.OidcAuthenticationComplement({ + accessToken, + refreshToken: tokenResponse.data['refresh_token'], + expiredDate: moment().add(tokenResponse.data['expires_in'], 's').toDate(), + }); + await authenticationMethodRepository.updateAuthenticationComplementByUserIdAndIdentityProvider({ + authenticationComplement, + userId, + identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code, + }); + } - accessToken = tokenResponse.data['access_token']; - const authenticationComplement = new AuthenticationMethod.OidcAuthenticationComplement({ - accessToken, - refreshToken: tokenResponse.data['refresh_token'], - expiredDate: moment().add(tokenResponse.data['expires_in'], 's').toDate(), - }); - await authenticationMethodRepository.updateAuthenticationComplementByUserIdAndIdentityProvider({ - authenticationComplement, - userId, - identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code, - }); - } + const url = config.poleEmploi.sendingUrl; + const headers = { + Authorization: `Bearer ${accessToken}`, + 'Content-type': 'application/json', + Accept: 'application/json', + 'Service-source': 'Pix', + }; - const url = settings.poleEmploi.sendingUrl; - const headers = { - Authorization: `Bearer ${accessToken}`, - 'Content-type': 'application/json', - Accept: 'application/json', - 'Service-source': 'Pix', - }; + const httpResponse = await httpAgent.post({ + url, + payload, + headers, + timeout: config.partner.fetchTimeOut, + }); - const httpResponse = await httpAgent.post({ - url, - payload, - headers, - timeout: settings.partner.fetchTimeOut, + if (!httpResponse.isSuccessful) { + const serializedError = httpErrorsHelper.serializeHttpErrorResponse(httpResponse); + monitoringTools.logErrorWithCorrelationIds({ + event: 'participation-send-pole-emploi', + 'pole-emploi-action': 'send-results', + 'participation-state': participationState(payload), + message: serializedError, }); + } - if (!httpResponse.isSuccessful) { - const serializedError = httpErrorsHelper.serializeHttpErrorResponse(httpResponse); - monitoringTools.logErrorWithCorrelationIds({ - event: 'participation-send-pole-emploi', - 'pole-emploi-action': 'send-results', - 'participation-state': participationState(payload), - message: serializedError, - }); - } - - return { - isSuccessful: httpResponse.isSuccessful, - code: httpResponse.code || '500', - }; - }, + return { + isSuccessful: httpResponse.isSuccessful, + code: httpResponse.code || '500', + }; }; +export { notify }; + function participationState({ test }) { if (test.dateValidation) { return 'PARTICIPATION_SHARED'; diff --git a/api/lib/infrastructure/files/attendance-sheet/attendance-sheet-placeholders.js b/api/lib/infrastructure/files/attendance-sheet/attendance-sheet-placeholders.js index 322787a708e..526a1712b9b 100644 --- a/api/lib/infrastructure/files/attendance-sheet/attendance-sheet-placeholders.js +++ b/api/lib/infrastructure/files/attendance-sheet/attendance-sheet-placeholders.js @@ -89,7 +89,7 @@ const SCO_ATTENDANCE_SHEET_CANDIDATE_TEMPLATE_VALUES = [ const EXTRA_EMPTY_CANDIDATE_ROWS = 20; -module.exports = { +export { ATTENDANCE_SHEET_SESSION_TEMPLATE_VALUES, NON_SCO_ATTENDANCE_SHEET_CANDIDATE_TEMPLATE_VALUES, SCO_ATTENDANCE_SHEET_CANDIDATE_TEMPLATE_VALUES, diff --git a/api/lib/infrastructure/files/candidates-import/CandidateData.js b/api/lib/infrastructure/files/candidates-import/CandidateData.js index 0789ae367bf..7fb01a0484a 100644 --- a/api/lib/infrastructure/files/candidates-import/CandidateData.js +++ b/api/lib/infrastructure/files/candidates-import/CandidateData.js @@ -1,15 +1,15 @@ -const moment = require('moment'); -const _ = require('lodash'); +import moment from 'moment'; +import _ from 'lodash'; const FRANCE_COUNTRY_CODE = '99100'; -const CertificationCandidate = require('../../../domain/models/CertificationCandidate.js'); -const { +import { CertificationCandidate } from '../../../domain/models/CertificationCandidate.js'; +import { PIX_PLUS_DROIT, CLEA, PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE, -} = require('../../../domain/models/ComplementaryCertification.js'); +} from '../../../domain/models/ComplementaryCertification.js'; -module.exports = class CandidateData { +class CandidateData { constructor({ id = null, firstName = null, @@ -113,4 +113,6 @@ module.exports = class CandidateData { static empty({ number, i18n }) { return new CandidateData({ number, i18n }); } -}; +} + +export { CandidateData }; diff --git a/api/lib/infrastructure/files/candidates-import/SessionData.js b/api/lib/infrastructure/files/candidates-import/SessionData.js index 575dad3f25f..268d4bde97b 100644 --- a/api/lib/infrastructure/files/candidates-import/SessionData.js +++ b/api/lib/infrastructure/files/candidates-import/SessionData.js @@ -1,6 +1,6 @@ -const moment = require('moment'); +import moment from 'moment'; -module.exports = class SessionData { +class SessionData { constructor({ id, accessCode, @@ -41,4 +41,6 @@ module.exports = class SessionData { static fromSession(session) { return new SessionData(session); } -}; +} + +export { SessionData }; diff --git a/api/lib/infrastructure/files/candidates-import/candidates-import-placeholders.js b/api/lib/infrastructure/files/candidates-import/candidates-import-placeholders.js index 1a4afa3e453..49774ecfd28 100644 --- a/api/lib/infrastructure/files/candidates-import/candidates-import-placeholders.js +++ b/api/lib/infrastructure/files/candidates-import/candidates-import-placeholders.js @@ -1,9 +1,9 @@ -const { +import { PIX_PLUS_DROIT, CLEA, PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE, -} = require('../../../domain/models/ComplementaryCertification.js'); +} from '../../../domain/models/ComplementaryCertification.js'; const IMPORT_CANDIDATES_SESSION_TEMPLATE_HEADERS = [ 'headers.birthcity', @@ -161,7 +161,7 @@ const IMPORT_CANDIDATES_TEMPLATE_VALUES = [ const EXTRA_EMPTY_CANDIDATE_ROWS = 20; -module.exports = { +export { IMPORT_CANDIDATES_SESSION_TEMPLATE_HEADERS, IMPORT_CANDIDATES_SESSION_TEMPLATE_VALUES, IMPORT_CANDIDATES_TEMPLATE_VALUES, diff --git a/api/lib/infrastructure/files/candidates-import/candidates-import-transformation-structures.js b/api/lib/infrastructure/files/candidates-import/candidates-import-transformation-structures.js index 25953c97173..f724f9b3842 100644 --- a/api/lib/infrastructure/files/candidates-import/candidates-import-transformation-structures.js +++ b/api/lib/infrastructure/files/candidates-import/candidates-import-transformation-structures.js @@ -1,11 +1,11 @@ -const _ = require('lodash'); -const { convertDateValue } = require('../../utils/date-utils.js'); -const { +import _ from 'lodash'; +import { convertDateValue } from '../../utils/date-utils.js'; +import { CLEA, PIX_PLUS_DROIT, PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE, -} = require('../../../domain/models/ComplementaryCertification.js'); +} from '../../../domain/models/ComplementaryCertification.js'; // These are transformation structures. They provide all the necessary info // on how to transform cell values in an attendance sheet into a target JS object. @@ -178,6 +178,4 @@ function _toBooleanIfValueEqualsOuiOrNull({ val, translate }) { return val?.toUpperCase() === yesTranslation.toUpperCase() ? true : null; } -module.exports = { - getTransformationStructsForPixCertifCandidatesImport, -}; +export { getTransformationStructsForPixCertifCandidatesImport }; diff --git a/api/lib/infrastructure/files/candidates-import/fill-candidates-import-sheet.js b/api/lib/infrastructure/files/candidates-import/fill-candidates-import-sheet.js index 721b1197152..902e9c5575b 100644 --- a/api/lib/infrastructure/files/candidates-import/fill-candidates-import-sheet.js +++ b/api/lib/infrastructure/files/candidates-import/fill-candidates-import-sheet.js @@ -1,23 +1,28 @@ -const writeOdsUtils = require('../../utils/ods/write-ods-utils.js'); -const readOdsUtils = require('../../utils/ods/read-ods-utils.js'); -const { +import * as writeOdsUtils from '../../utils/ods/write-ods-utils.js'; +import * as readOdsUtils from '../../utils/ods/read-ods-utils.js'; + +import { EXTRA_EMPTY_CANDIDATE_ROWS, IMPORT_CANDIDATES_TEMPLATE_VALUES, IMPORT_CANDIDATES_SESSION_TEMPLATE_VALUES, IMPORT_CANDIDATES_SESSION_TEMPLATE_HEADERS, -} = require('./candidates-import-placeholders.js'); -const CertificationCandidate = require('../../../domain/models/CertificationCandidate.js'); +} from './candidates-import-placeholders.js'; + +import { CertificationCandidate } from '../../../domain/models/CertificationCandidate.js'; -const _ = require('lodash'); -const CandidateData = require('./CandidateData.js'); -const SessionData = require('./SessionData.js'); +import _ from 'lodash'; +import { CandidateData } from './CandidateData.js'; +import { SessionData } from './SessionData.js'; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); const INFORMATIVE_HEADER_ROW = 8; const HEADER_ROW_SPAN = 3; const CANDIDATE_TABLE_HEADER_ROW = 11; const CANDIDATE_TABLE_FIRST_ROW = 12; -module.exports = async function fillCandidatesImportSheet({ +const fillCandidatesImportSheet = async function ({ session, certificationCenterHabilitations, isScoCertificationCenter, @@ -43,6 +48,8 @@ module.exports = async function fillCandidatesImportSheet({ return odsBuilder.build({ templateFilePath: _getCandidatesImportTemplatePath() }); }; +export { fillCandidatesImportSheet }; + async function _getCandidatesImportTemplate() { const templatePath = _getCandidatesImportTemplatePath(); return readOdsUtils.getContentXml({ odsFilePath: templatePath }); diff --git a/api/lib/infrastructure/files/sessions-import.js b/api/lib/infrastructure/files/sessions-import.js index e9ee24d6363..4644396face 100644 --- a/api/lib/infrastructure/files/sessions-import.js +++ b/api/lib/infrastructure/files/sessions-import.js @@ -1,6 +1,9 @@ -const { Parser } = require('json2csv'); -const { headers, COMPLEMENTARY_CERTIFICATION_SUFFIX } = require('../utils/csv/sessions-import.js'); -const omit = require('lodash/omit'); +import { Parser } from 'json2csv'; + +const { omit } = lodash; + +import { headers, COMPLEMENTARY_CERTIFICATION_SUFFIX } from '../utils/csv/sessions-import.js'; +import lodash from 'lodash'; function getHeaders({ habilitationLabels, shouldDisplayBillingModeColumns = true }) { const complementaryCertificationsHeaders = _getComplementaryCertificationsHeaders(habilitationLabels); @@ -27,4 +30,4 @@ function _getHeadersAsArray(complementaryCertificationsHeaders = [], shouldDispl return [...csvHeaders, ...complementaryCertificationsHeaders]; } -module.exports = { getHeaders }; +export { getHeaders }; diff --git a/api/lib/infrastructure/helpers/csv.js b/api/lib/infrastructure/helpers/csv.js index 4d7d3fecf81..6137384ee28 100644 --- a/api/lib/infrastructure/helpers/csv.js +++ b/api/lib/infrastructure/helpers/csv.js @@ -1,8 +1,13 @@ -const fs = require('fs'); -const { readFile, access } = require('fs').promises; -const { isEmpty, difference } = require('lodash'); -const { FileValidationError, NotFoundError } = require('../../domain/errors.js'); -const papa = require('papaparse'); +import fs, { promises } from 'fs'; + +const { readFile, access } = promises; + +import lodash from 'lodash'; + +const { isEmpty, difference } = lodash; + +import { FileValidationError, NotFoundError } from '../../domain/errors.js'; +import papa from 'papaparse'; const ERRORS = { MISSING_REQUIRED_FIELD_NAMES: 'MISSING_REQUIRED_FIELD_NAMES', @@ -81,7 +86,4 @@ async function _parseCsvData(cleanedData, options) { return data; } -module.exports = { - checkCsvHeader, - parseCsvWithHeader, -}; +export { checkCsvHeader, parseCsvWithHeader }; diff --git a/api/lib/infrastructure/http/errors-helper.js b/api/lib/infrastructure/http/errors-helper.js index 0cfc44fdc9d..f7e0c54ea0e 100644 --- a/api/lib/infrastructure/http/errors-helper.js +++ b/api/lib/infrastructure/http/errors-helper.js @@ -21,6 +21,4 @@ function serializeHttpErrorResponse(response, customMessage) { return dataToLog; } -module.exports = { - serializeHttpErrorResponse, -}; +export { serializeHttpErrorResponse }; diff --git a/api/lib/infrastructure/http/http-agent.js b/api/lib/infrastructure/http/http-agent.js index 20731619295..5241985a977 100644 --- a/api/lib/infrastructure/http/http-agent.js +++ b/api/lib/infrastructure/http/http-agent.js @@ -1,8 +1,9 @@ -// eslint-disable-next-line no-restricted-modules -const axios = require('axios'); -const { performance } = require('perf_hooks'); +import axios from 'axios'; +import perf_hooks from 'perf_hooks'; -const monitoringTools = require('../monitoring-tools.js'); +const { performance } = perf_hooks; + +import { monitoringTools } from '../monitoring-tools.js'; class HttpResponse { constructor({ code, data, isSuccessful }) { @@ -12,7 +13,7 @@ class HttpResponse { } } -const HttpAgent = { +const httpAgent = { async post({ url, payload, headers, timeout }) { const startTime = performance.now(); let responseTime = null; @@ -114,4 +115,4 @@ const HttpAgent = { }, }; -module.exports = HttpAgent; +export { httpAgent }; diff --git a/api/lib/infrastructure/jobs/JobPgBoss.js b/api/lib/infrastructure/jobs/JobPgBoss.js index 59d7af0a9ea..4304b4c5e27 100644 --- a/api/lib/infrastructure/jobs/JobPgBoss.js +++ b/api/lib/infrastructure/jobs/JobPgBoss.js @@ -20,4 +20,4 @@ class JobPgBoss { } } -module.exports = JobPgBoss; +export { JobPgBoss }; diff --git a/api/lib/infrastructure/jobs/JobQueue.js b/api/lib/infrastructure/jobs/JobQueue.js index fcfc6916a16..47f7620b6d1 100644 --- a/api/lib/infrastructure/jobs/JobQueue.js +++ b/api/lib/infrastructure/jobs/JobQueue.js @@ -1,6 +1,9 @@ -const MonitoredJobHandler = require('./monitoring/MonitoredJobHandler.js'); -const logger = require('../logger.js'); -const { teamSize, teamConcurrency } = require('../../config.js').pgBoss; +import { MonitoredJobHandler } from './monitoring/MonitoredJobHandler.js'; +import { logger } from '../logger.js'; +import { config } from '../../config.js'; + +const { teamSize, teamConcurrency } = config.pgBoss; + class JobQueue { constructor(pgBoss) { this.pgBoss = pgBoss; @@ -22,4 +25,4 @@ class JobQueue { } } -module.exports = JobQueue; +export { JobQueue }; diff --git a/api/lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob.js b/api/lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob.js index c1e6868de01..2e951aa3cfc 100644 --- a/api/lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob.js +++ b/api/lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob.js @@ -1,11 +1,9 @@ -const Job = require('../JobPgBoss.js'); +import { JobPgBoss } from '../JobPgBoss.js'; -class ParticipationResultCalculationJob extends Job { +class ParticipationResultCalculationJob extends JobPgBoss { constructor(queryBuilder) { super({ name: 'ParticipationResultCalculationJob', retryLimit: 3 }, queryBuilder); } } -ParticipationResultCalculationJob.name = 'ParticipationResultCalculationJob'; - -module.exports = ParticipationResultCalculationJob; +export { ParticipationResultCalculationJob }; diff --git a/api/lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler.js b/api/lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler.js index 83c2f7afeda..758aa73f418 100644 --- a/api/lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler.js +++ b/api/lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler.js @@ -1,5 +1,5 @@ -const Job = require('./ParticipationResultCalculationJob.js'); -const usecases = require('../../../domain/usecases/index.js'); +import { ParticipationResultCalculationJob } from './ParticipationResultCalculationJob.js'; +import { usecases } from '../../../domain/usecases/index.js'; class ParticipationResultCalculationJobHandler { async handle(event) { @@ -9,8 +9,8 @@ class ParticipationResultCalculationJobHandler { } get name() { - return Job.name; + return ParticipationResultCalculationJob.name; } } -module.exports = ParticipationResultCalculationJobHandler; +export { ParticipationResultCalculationJobHandler }; diff --git a/api/lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler.js b/api/lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler.js index e67ff359b84..72d5eec1b73 100644 --- a/api/lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler.js +++ b/api/lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler.js @@ -1,5 +1,5 @@ -const Job = require('./SendSharedParticipationResultsToPoleEmploiJob.js'); -const usecases = require('../../../domain/usecases/index.js'); +import { SendSharedParticipationResultsToPoleEmploiJob } from './SendSharedParticipationResultsToPoleEmploiJob.js'; +import { usecases } from '../../../domain/usecases/index.js'; class SendSharedParticipationResultsToPoleEmploiHandler { async handle(event) { @@ -9,8 +9,8 @@ class SendSharedParticipationResultsToPoleEmploiHandler { } get name() { - return Job.name; + return SendSharedParticipationResultsToPoleEmploiJob.name; } } -module.exports = SendSharedParticipationResultsToPoleEmploiHandler; +export { SendSharedParticipationResultsToPoleEmploiHandler }; diff --git a/api/lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob.js b/api/lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob.js index fddb49fe52a..6f3bb21a67f 100644 --- a/api/lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob.js +++ b/api/lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob.js @@ -1,11 +1,9 @@ -const Job = require('../JobPgBoss.js'); +import { JobPgBoss } from '../JobPgBoss.js'; -class SendSharedParticipationResultsToPoleEmploi extends Job { +class SendSharedParticipationResultsToPoleEmploiJob extends JobPgBoss { constructor(queryBuilder) { super({ name: 'SendSharedParticipationResultsToPoleEmploi', retryLimit: 0 }, queryBuilder); } } -SendSharedParticipationResultsToPoleEmploi.name = 'SendSharedParticipationResultsToPoleEmploi'; - -module.exports = SendSharedParticipationResultsToPoleEmploi; +export { SendSharedParticipationResultsToPoleEmploiJob as SendSharedParticipationResultsToPoleEmploiJob }; diff --git a/api/lib/infrastructure/jobs/cpf-export/handlers/create-and-upload.js b/api/lib/infrastructure/jobs/cpf-export/handlers/create-and-upload.js index 50987ec809f..70fd90fd390 100644 --- a/api/lib/infrastructure/jobs/cpf-export/handlers/create-and-upload.js +++ b/api/lib/infrastructure/jobs/cpf-export/handlers/create-and-upload.js @@ -1,16 +1,21 @@ -const { createGzip } = require('node:zlib'); -const dayjs = require('dayjs'); -const utc = require('dayjs/plugin/utc'); -const timezone = require('dayjs/plugin/timezone'); +import { createGzip } from 'node:zlib'; + +import dayjs from 'dayjs'; +import utc from 'dayjs/plugin/utc.js'; +import timezone from 'dayjs/plugin/timezone.js'; + dayjs.extend(utc); dayjs.extend(timezone); -module.exports = async function createAndUpload({ +import * as uuid from 'uuid'; + +const createAndUpload = async function ({ data, logger, cpfCertificationResultRepository, cpfCertificationXmlExportService, cpfExternalStorage, + uuidService = uuid, }) { const { batchId } = data; const start = new Date(); @@ -28,6 +33,7 @@ module.exports = async function createAndUpload({ cpfCertificationXmlExportService.buildXmlExport({ cpfCertificationResults, writableStream: gzipStream, + uuidService, }); const now = dayjs().tz('Europe/Paris').format('YYYYMMDD-HHmmss'); @@ -45,6 +51,8 @@ module.exports = async function createAndUpload({ logger.info(`${filename} generated in ${_getTimeInSec(start)}s.`); }; +export { createAndUpload }; + function _getTimeInSec(start) { return Math.floor((new Date().getTime() - start) / 1024); } diff --git a/api/lib/infrastructure/jobs/cpf-export/handlers/planner.js b/api/lib/infrastructure/jobs/cpf-export/handlers/planner.js index f05f783d2f6..35ecd27bad0 100644 --- a/api/lib/infrastructure/jobs/cpf-export/handlers/planner.js +++ b/api/lib/infrastructure/jobs/cpf-export/handlers/planner.js @@ -1,7 +1,9 @@ -const dayjs = require('dayjs'); -const { plannerJob } = require('../../../../config.js').cpf; +import dayjs from 'dayjs'; +import { config } from '../../../../config.js'; -module.exports = async function planner({ job, pgBoss, cpfCertificationResultRepository, logger }) { +const { plannerJob } = config.cpf; + +const planner = async function ({ job, pgBoss, cpfCertificationResultRepository, logger }) { const startDate = dayjs() .utc() .subtract(plannerJob.minimumReliabilityPeriod + (plannerJob.monthsToProcess - 1), 'months') @@ -33,3 +35,5 @@ module.exports = async function planner({ job, pgBoss, cpfCertificationResultRep await pgBoss.insert(newJobs.map((batchId) => ({ name: 'CpfExportBuilderJob', data: { batchId } }))); }; + +export { planner }; diff --git a/api/lib/infrastructure/jobs/cpf-export/handlers/send-email.js b/api/lib/infrastructure/jobs/cpf-export/handlers/send-email.js index 1985f854bcb..809a7b3e54c 100644 --- a/api/lib/infrastructure/jobs/cpf-export/handlers/send-email.js +++ b/api/lib/infrastructure/jobs/cpf-export/handlers/send-email.js @@ -1,7 +1,8 @@ -const { cpf } = require('../../../../config.js'); -const cronParser = require('cron-parser'); +import { config } from '../../../../config.js'; +import cronParser from 'cron-parser'; -module.exports = async function sendEmail({ cpfExternalStorage, mailService }) { +const { cpf } = config; +const sendEmail = async function ({ cpfExternalStorage, mailService }) { const parsedCron = cronParser.parseExpression(cpf.plannerJob.cron, { tz: 'Europe/Paris' }); const date = parsedCron.prev().toDate(); @@ -9,3 +10,5 @@ module.exports = async function sendEmail({ cpfExternalStorage, mailService }) { await mailService.sendCpfEmail({ email: cpf.sendEmailJob.recipient, generatedFiles }); }; + +export { sendEmail }; diff --git a/api/lib/infrastructure/jobs/cpf-export/index.js b/api/lib/infrastructure/jobs/cpf-export/index.js index a2f7f182409..f06f7871b5f 100644 --- a/api/lib/infrastructure/jobs/cpf-export/index.js +++ b/api/lib/infrastructure/jobs/cpf-export/index.js @@ -1,9 +1,13 @@ -const { injectDependencies } = require('../../utils/dependency-injection.js'); +import { injectDependencies } from '../../utils/dependency-injection.js'; -const cpfCertificationResultRepository = require('../../repositories/cpf-certification-result-repository.js'); -const cpfCertificationXmlExportService = require('../../../domain/services/cpf-certification-xml-export-service.js'); -const cpfExternalStorage = require('../../external-storage/cpf-external-storage.js'); -const mailService = require('../../../domain/services/mail-service.js'); +import * as cpfCertificationResultRepository from '../../repositories/cpf-certification-result-repository.js'; +import * as cpfCertificationXmlExportService from '../../../domain/services/cpf-certification-xml-export-service.js'; +import * as cpfExternalStorage from '../../external-storage/cpf-external-storage.js'; +import * as mailService from '../../../domain/services/mail-service.js'; + +import * as planner from './handlers/planner.js'; +import * as createAndUpload from './handlers/create-and-upload.js'; +import * as sendEmail from './handlers/send-email.js'; const dependencies = { cpfCertificationResultRepository, @@ -14,11 +18,11 @@ const dependencies = { const cpfExport = injectDependencies( { - planner: require('./handlers/planner.js'), - createAndUpload: require('./handlers/create-and-upload.js'), - sendEmail: require('./handlers/send-email.js'), + planner, + createAndUpload, + sendEmail, }, dependencies ); -module.exports = cpfExport; +export { cpfExport }; diff --git a/api/lib/infrastructure/jobs/cpf-export/schedule-cpf-jobs.js b/api/lib/infrastructure/jobs/cpf-export/schedule-cpf-jobs.js index 6c968208375..7bf746c3cca 100644 --- a/api/lib/infrastructure/jobs/cpf-export/schedule-cpf-jobs.js +++ b/api/lib/infrastructure/jobs/cpf-export/schedule-cpf-jobs.js @@ -1,25 +1,29 @@ -const handlers = require('./index.js'); -const logger = require('../../logger.js'); -const config = require('../../../config.js'); +import { cpfExport } from './index.js'; +import { logger } from '../../logger.js'; +import { config } from '../../../config.js'; const { plannerJob, sendEmailJob } = config.cpf; -module.exports = async function scheduleCpfJobs(pgBoss) { +const { planner, createAndUpload, sendEmail } = cpfExport; + +const scheduleCpfJobs = async function (pgBoss) { await pgBoss.schedule('CpfExportPlannerJob', plannerJob.cron, null, { tz: 'Europe/Paris' }); await pgBoss.work('CpfExportPlannerJob', async (job) => { - await _processJob(job, handlers.planner, { pgBoss }); + await _processJob(job, planner, { pgBoss }); }); await pgBoss.work('CpfExportBuilderJob', { batchSize: 1 }, async ([job]) => { - await _processJob(job, handlers.createAndUpload, { data: job.data }); + await _processJob(job, createAndUpload, { data: job.data }); }); await pgBoss.schedule('CpfExportSenderJob', sendEmailJob.cron, null, { tz: 'Europe/Paris' }); await pgBoss.work('CpfExportSenderJob', async (job) => { - await _processJob(job, handlers.sendEmail, {}); + await _processJob(job, sendEmail, {}); }); }; +export { scheduleCpfJobs }; + async function _processJob(job, handler, params) { try { await handler({ ...params, job, logger: buildLogger(job) }); diff --git a/api/lib/infrastructure/jobs/monitoring/MonitoredJobHandler.js b/api/lib/infrastructure/jobs/monitoring/MonitoredJobHandler.js index 76b75ee22c7..d78694f162a 100644 --- a/api/lib/infrastructure/jobs/monitoring/MonitoredJobHandler.js +++ b/api/lib/infrastructure/jobs/monitoring/MonitoredJobHandler.js @@ -36,4 +36,4 @@ class MonitoredJobHandler { } } -module.exports = MonitoredJobHandler; +export { MonitoredJobHandler }; diff --git a/api/lib/infrastructure/jobs/monitoring/MonitoredJobQueue.js b/api/lib/infrastructure/jobs/monitoring/MonitoredJobQueue.js index 07cc968d909..2c0a16747c1 100644 --- a/api/lib/infrastructure/jobs/monitoring/MonitoredJobQueue.js +++ b/api/lib/infrastructure/jobs/monitoring/MonitoredJobQueue.js @@ -1,6 +1,8 @@ -const MonitoringJobHandler = require('./MonitoringJobExecutionTimeHandler.js'); -const logger = require('../../logger.js'); -const { teamSize, teamConcurrency } = require('../../../config.js').pgBoss; +import { MonitoringJobExecutionTimeHandler } from './MonitoringJobExecutionTimeHandler.js'; +import { logger } from '../../logger.js'; +import { config } from '../../../config.js'; + +const { teamSize, teamConcurrency } = config.pgBoss; class MonitoredJobQueue { constructor(jobQueue) { @@ -10,7 +12,7 @@ class MonitoredJobQueue { performJob(name, handlerClass) { this.jobQueue.performJob(name, handlerClass); - const monitoringJobHandler = new MonitoringJobHandler({ logger }); + const monitoringJobHandler = new MonitoringJobExecutionTimeHandler({ logger }); this.jobQueue.pgBoss.onComplete(name, { teamSize, teamConcurrency }, (job) => { monitoringJobHandler.handle(job); }); @@ -21,4 +23,4 @@ class MonitoredJobQueue { } } -module.exports = MonitoredJobQueue; +export { MonitoredJobQueue }; diff --git a/api/lib/infrastructure/jobs/monitoring/MonitoringJobExecutionTimeHandler.js b/api/lib/infrastructure/jobs/monitoring/MonitoringJobExecutionTimeHandler.js index e5e5bad3f6c..755d3373563 100644 --- a/api/lib/infrastructure/jobs/monitoring/MonitoringJobExecutionTimeHandler.js +++ b/api/lib/infrastructure/jobs/monitoring/MonitoringJobExecutionTimeHandler.js @@ -1,4 +1,4 @@ -const dayjs = require('dayjs'); +import dayjs from 'dayjs'; class MonitoringJobExecutionTimeHandler { constructor({ logger }) { @@ -22,4 +22,4 @@ class MonitoringJobExecutionTimeHandler { } } -module.exports = MonitoringJobExecutionTimeHandler; +export { MonitoringJobExecutionTimeHandler }; diff --git a/api/lib/infrastructure/lcms.js b/api/lib/infrastructure/lcms.js index 6f611b90d13..0b0f6ddf244 100644 --- a/api/lib/infrastructure/lcms.js +++ b/api/lib/infrastructure/lcms.js @@ -1,26 +1,28 @@ -const httpAgent = require('./http/http-agent.js'); +import { httpAgent } from './http/http-agent.js'; +import { config } from '../config.js'; -const { lcms } = require('../config.js'); +const { lcms: lcmsConfig } = config; +const getLatestRelease = async function () { + const response = await httpAgent.get({ + url: lcmsConfig.url + '/releases/latest', + headers: { Authorization: `Bearer ${lcmsConfig.apiKey}` }, + }); -module.exports = { - async getLatestRelease() { - const response = await httpAgent.get({ - url: lcms.url + '/releases/latest', - headers: { Authorization: `Bearer ${lcms.apiKey}` }, - }); + if (!response.isSuccessful) { + throw new Error(`An error occurred while fetching ${lcmsConfig.url}`); + } - if (!response.isSuccessful) { - throw new Error(`An error occurred while fetching ${lcms.url}`); - } - - return response.data.content; - }, + return response.data.content; +}; - async createRelease() { - const response = await httpAgent.post({ - url: lcms.url + '/releases', - headers: { Authorization: `Bearer ${lcms.apiKey}` }, - }); - return response.data.content; - }, +const createRelease = async function () { + const response = await httpAgent.post({ + url: lcmsConfig.url + '/releases', + headers: { Authorization: `Bearer ${lcmsConfig.apiKey}` }, + }); + return response.data.content; }; + +const lcms = { getLatestRelease, createRelease }; + +export { lcms }; diff --git a/api/lib/infrastructure/logger.js b/api/lib/infrastructure/logger.js index 28c353da714..ce76f5b1eaa 100644 --- a/api/lib/infrastructure/logger.js +++ b/api/lib/infrastructure/logger.js @@ -1,9 +1,11 @@ -const pino = require('pino'); -const pretty = require('pino-pretty'); -const { logging: logSettings } = require('../config.js'); +import pino from 'pino'; +import pretty from 'pino-pretty'; +import { config } from '../config.js'; + +const { logging } = config; let prettyPrint; -if (logSettings.logForHumans) { +if (logging.logForHumans) { const omitDay = 'HH:MM:ss'; prettyPrint = pretty({ sync: true, @@ -15,11 +17,11 @@ if (logSettings.logForHumans) { const logger = pino( { - level: logSettings.logLevel, + level: logging.logLevel, redact: ['req.headers.authorization'], - enabled: logSettings.enabled, + enabled: logging.enabled, }, prettyPrint ); -module.exports = logger; +export { logger }; diff --git a/api/lib/infrastructure/mail-check.js b/api/lib/infrastructure/mail-check.js index db2eb4cbcfd..66203b67b3f 100644 --- a/api/lib/infrastructure/mail-check.js +++ b/api/lib/infrastructure/mail-check.js @@ -1,10 +1,12 @@ -const { Resolver } = require('node:dns').promises; +import { promises } from 'node:dns'; + +const { Resolver } = promises; const resolver = new Resolver(); -module.exports = { - checkDomainIsValid(emailAddress) { - const domain = emailAddress.replace(/.*@/g, ''); - return resolver.resolveMx(domain).then(() => true); - }, +const checkDomainIsValid = function (emailAddress) { + const domain = emailAddress.replace(/.*@/g, ''); + return resolver.resolveMx(domain).then(() => true); }; + +export { checkDomainIsValid }; diff --git a/api/lib/infrastructure/mailers/MailingProvider.js b/api/lib/infrastructure/mailers/MailingProvider.js index 12493c0e793..3a5b1108c56 100644 --- a/api/lib/infrastructure/mailers/MailingProvider.js +++ b/api/lib/infrastructure/mailers/MailingProvider.js @@ -4,4 +4,4 @@ class MailingProvider { } } -module.exports = MailingProvider; +export { MailingProvider }; diff --git a/api/lib/infrastructure/mailers/MailingProviderInvalidEmailError.js b/api/lib/infrastructure/mailers/MailingProviderInvalidEmailError.js index a028d922bdd..6d84c96fe05 100644 --- a/api/lib/infrastructure/mailers/MailingProviderInvalidEmailError.js +++ b/api/lib/infrastructure/mailers/MailingProviderInvalidEmailError.js @@ -1,3 +1,3 @@ class MailingProviderInvalidEmailError extends Error {} -module.exports = { MailingProviderInvalidEmailError }; +export { MailingProviderInvalidEmailError }; diff --git a/api/lib/infrastructure/mailers/SendinblueProvider.js b/api/lib/infrastructure/mailers/SendinblueProvider.js index 2413abe353f..1802607f816 100644 --- a/api/lib/infrastructure/mailers/SendinblueProvider.js +++ b/api/lib/infrastructure/mailers/SendinblueProvider.js @@ -1,10 +1,11 @@ -const _ = require('lodash'); -const SibApiV3Sdk = require('sib-api-v3-sdk'); +import _ from 'lodash'; +import SibApiV3Sdk from 'sib-api-v3-sdk'; -const MailingProvider = require('./MailingProvider.js'); -const { mailing } = require('../../config.js'); -const { MailingProviderInvalidEmailError } = require('./MailingProviderInvalidEmailError'); +import { MailingProvider } from './MailingProvider.js'; +import { config } from '../../config.js'; +import { MailingProviderInvalidEmailError } from './MailingProviderInvalidEmailError.js'; +const { mailing } = config; function _formatPayload({ to, fromName, from, subject, template, variables, tags }) { const payload = { to: [ @@ -64,4 +65,4 @@ class SendinblueProvider extends MailingProvider { } } -module.exports = SendinblueProvider; +export { SendinblueProvider }; diff --git a/api/lib/infrastructure/mailers/mailer.js b/api/lib/infrastructure/mailers/mailer.js index 4a1512a6e48..d8648fdc4bd 100644 --- a/api/lib/infrastructure/mailers/mailer.js +++ b/api/lib/infrastructure/mailers/mailer.js @@ -1,11 +1,12 @@ -const Debug = require('debug'); -const SendinblueProvider = require('./SendinblueProvider.js'); -const { mailing } = require('../../config.js'); -const logger = require('../logger.js'); -const mailCheck = require('../mail-check.js'); -const EmailingAttempt = require('../../domain/models/EmailingAttempt.js'); -const { MailingProviderInvalidEmailError } = require('./MailingProviderInvalidEmailError'); - +import Debug from 'debug'; +import { SendinblueProvider } from './SendinblueProvider.js'; +import { config } from '../../config.js'; +import { logger } from '../logger.js'; +import * as mailCheck from '../mail-check.js'; +import { EmailingAttempt } from '../../domain/models/EmailingAttempt.js'; +import { MailingProviderInvalidEmailError } from './MailingProviderInvalidEmailError.js'; + +const { mailing } = config; const debugEmail = Debug('pix:mailer:email'); class Mailer { @@ -97,4 +98,4 @@ class Mailer { const mailer = new Mailer(); -module.exports = { mailer, Mailer }; +export { mailer, Mailer }; diff --git a/api/lib/infrastructure/monitoring-tools.js b/api/lib/infrastructure/monitoring-tools.js index 9b17565a74f..f9a65d9b2f9 100644 --- a/api/lib/infrastructure/monitoring-tools.js +++ b/api/lib/infrastructure/monitoring-tools.js @@ -1,14 +1,20 @@ -const Request = require('@hapi/hapi/lib/request'); -const settings = require('../config.js'); -const { get, set, update, omit } = require('lodash'); -const logger = require('../infrastructure/logger.js'); -const requestUtils = require('../infrastructure/utils/request-response-utils.js'); +import Request from '@hapi/hapi/lib/request.js'; + +import { config } from '../config.js'; +import lodash from 'lodash'; + +const { get, set, update, omit } = lodash; +import { logger } from '../infrastructure/logger.js'; +import * as requestResponseUtils from '../infrastructure/utils/request-response-utils.js'; + +import async_hooks from 'async_hooks'; + +const { AsyncLocalStorage } = async_hooks; -const { AsyncLocalStorage } = require('async_hooks'); const asyncLocalStorage = new AsyncLocalStorage(); function getCorrelationContext() { - if (!settings.hapi.enableRequestMonitoring) { + if (!config.hapi.enableRequestMonitoring) { return {}; } const context = asyncLocalStorage.getStore(); @@ -43,7 +49,7 @@ function logErrorWithCorrelationIds(data) { function extractUserIdFromRequest(request) { let userId = get(request, 'auth.credentials.userId'); - if (!userId && get(request, 'headers.authorization')) userId = requestUtils.extractUserIdFromRequest(request); + if (!userId && get(request, 'headers.authorization')) userId = requestResponseUtils.extractUserIdFromRequest(request); return userId || '-'; } @@ -82,7 +88,7 @@ function pushInContext(path, value) { } function installHapiHook() { - if (!settings.hapi.enableRequestMonitoring) return; + if (!config.hapi.enableRequestMonitoring) return; const originalMethod = Request.prototype._execute; @@ -97,7 +103,21 @@ function installHapiHook() { }; } -module.exports = { +const monitoringTools = { + extractUserIdFromRequest, + getContext, + getInContext, + incrementInContext, + installHapiHook, + logErrorWithCorrelationIds, + logInfoWithCorrelationIds, + pushInContext, + setInContext, + asyncLocalStorage, +}; + +export { + monitoringTools, extractUserIdFromRequest, getContext, getInContext, @@ -107,5 +127,5 @@ module.exports = { logInfoWithCorrelationIds, pushInContext, setInContext, - asyncLocalStorageForTests: asyncLocalStorage, + asyncLocalStorage, }; diff --git a/api/lib/infrastructure/open-api-doc/authentication/response-authentication-doc.js b/api/lib/infrastructure/open-api-doc/authentication/response-authentication-doc.js index fb89cb4ea57..ca8b610de30 100644 --- a/api/lib/infrastructure/open-api-doc/authentication/response-authentication-doc.js +++ b/api/lib/infrastructure/open-api-doc/authentication/response-authentication-doc.js @@ -1,7 +1,9 @@ -const Joi = require('joi'); +import Joi from 'joi'; -module.exports = Joi.object({ +const joiObject = Joi.object({ token_type: 'bearer', access_token: Joi.string().required().description('The bearer token.'), client_id: Joi.string().required().description('The client id.'), }).label('BearerToken'); + +export { joiObject as responseAuthenticationDoc }; diff --git a/api/lib/infrastructure/open-api-doc/livret-scolaire/area-doc.js b/api/lib/infrastructure/open-api-doc/livret-scolaire/area-doc.js index 2fd2bd350b4..fb58c35e72c 100644 --- a/api/lib/infrastructure/open-api-doc/livret-scolaire/area-doc.js +++ b/api/lib/infrastructure/open-api-doc/livret-scolaire/area-doc.js @@ -1,6 +1,8 @@ -const Joi = require('joi'); +import Joi from 'joi'; -module.exports = Joi.object({ +const joiObject = Joi.object({ id: Joi.number().example('1').required().description('ID unique de la compétence (ex : “1”, “4”)'), name: Joi.string().example('1. Information et données').required().description('Titre du domaine'), }); + +export { joiObject as areaDoc }; diff --git a/api/lib/infrastructure/open-api-doc/livret-scolaire/certification-doc.js b/api/lib/infrastructure/open-api-doc/livret-scolaire/certification-doc.js index 5b742aa1f17..c7322a39fe5 100644 --- a/api/lib/infrastructure/open-api-doc/livret-scolaire/certification-doc.js +++ b/api/lib/infrastructure/open-api-doc/livret-scolaire/certification-doc.js @@ -1,8 +1,8 @@ -const Joi = require('joi'); -const certificationStatus = require('../../../../lib/domain/read-models/livret-scolaire/CertificateStatus.js'); -const competenceResultDoc = require('./competence-result-doc.js'); +import Joi from 'joi'; +import { status } from '../../../../lib/domain/read-models/livret-scolaire/CertificateStatus.js'; +import { competenceResultDoc } from './competence-result-doc.js'; -module.exports = Joi.object({ +const joiObject = Joi.object({ id: Joi.number().required().description('ID de la certification pour l’élève'), firstName: Joi.string().example('Anne').required().description('Prénom de l’élève'), middleName: Joi.string().example('Sophie').required().description('Deuxième nom de l’élève'), @@ -12,7 +12,7 @@ module.exports = Joi.object({ nationalStudentId: Joi.string().example('029991043XX').required().description('INE de l’élève'), status: Joi.string() .example('validated') - .valid(certificationStatus) + .valid(status) .required() .description( "validated: le candidat a obtenu sa certification. rejected: le candidat a eu sa certification rejetée. pending: le candidat a passé sa certification mais elle n'est pas encore publiée" @@ -27,3 +27,5 @@ module.exports = Joi.object({ .description('Nom du centre de certification'), competenceResult: competenceResultDoc, }); + +export { joiObject as certificationDoc }; diff --git a/api/lib/infrastructure/open-api-doc/livret-scolaire/certifications-results-doc.js b/api/lib/infrastructure/open-api-doc/livret-scolaire/certifications-results-doc.js index 8103c0288fc..6c545b5acae 100644 --- a/api/lib/infrastructure/open-api-doc/livret-scolaire/certifications-results-doc.js +++ b/api/lib/infrastructure/open-api-doc/livret-scolaire/certifications-results-doc.js @@ -1,9 +1,11 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const certificationDoc = require('./certification-doc.js'); -const competenceDoc = require('./competence-doc.js'); +import { certificationDoc } from './certification-doc.js'; +import { competenceDoc } from './competence-doc.js'; -module.exports = Joi.object({ +const joiObject = Joi.object({ certifications: certificationDoc, competences: competenceDoc, }).label('CertificationsResults'); + +export { joiObject as certificationsResultsDoc }; diff --git a/api/lib/infrastructure/open-api-doc/livret-scolaire/competence-doc.js b/api/lib/infrastructure/open-api-doc/livret-scolaire/competence-doc.js index 1f24f641968..6016fd0020d 100644 --- a/api/lib/infrastructure/open-api-doc/livret-scolaire/competence-doc.js +++ b/api/lib/infrastructure/open-api-doc/livret-scolaire/competence-doc.js @@ -1,8 +1,8 @@ -const Joi = require('joi'); +import Joi from 'joi'; -const areaDoc = require('./area-doc.js'); +import { areaDoc } from './area-doc.js'; -module.exports = Joi.object({ +const joiObject = Joi.object({ id: Joi.number().example('1.1').required().description('ID unique de la compétence (ex : “1.1”, “4.3”)'), name: Joi.string() .example('Mener une recherche et une veille d’information') @@ -10,3 +10,5 @@ module.exports = Joi.object({ .description('Nom de la compétence'), area: areaDoc, }); + +export { joiObject as competenceDoc }; diff --git a/api/lib/infrastructure/open-api-doc/livret-scolaire/competence-result-doc.js b/api/lib/infrastructure/open-api-doc/livret-scolaire/competence-result-doc.js index ea5c8f4e76d..dcb49c0b9b9 100644 --- a/api/lib/infrastructure/open-api-doc/livret-scolaire/competence-result-doc.js +++ b/api/lib/infrastructure/open-api-doc/livret-scolaire/competence-result-doc.js @@ -1,6 +1,6 @@ -const Joi = require('joi'); +import Joi from 'joi'; -module.exports = Joi.object({ +const joiObject = Joi.object({ level: Joi.number().example('4').required().description('Niveau obtenu pour la compétence'), competenceId: Joi.string() .example('1.1') @@ -9,3 +9,5 @@ module.exports = Joi.object({ 'ID unique de la compétence : il fait directement référence à l’attribut id du Resource Object Competence' ), }).description('Tableau des niveaux validés par compétence'); + +export { joiObject as competenceResultDoc }; diff --git a/api/lib/infrastructure/open-api-doc/livret-scolaire/response-object-error-doc.js b/api/lib/infrastructure/open-api-doc/livret-scolaire/response-object-error-doc.js index 81aa9c08578..b03ecaccb93 100644 --- a/api/lib/infrastructure/open-api-doc/livret-scolaire/response-object-error-doc.js +++ b/api/lib/infrastructure/open-api-doc/livret-scolaire/response-object-error-doc.js @@ -1,8 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -module.exports = Joi.object({ +const joiObject = Joi.object({ code: Joi.string().required().description('An application-specific error code.'), title: Joi.string().required().description('A short, human-readable summary of the problem'), status: Joi.string().required().description('the HTTP status code applicable of the problem'), detail: Joi.string().required().description('a human-readable explanation specific of the problem'), }).label('Response-Error-Object'); + +export { joiObject as responseObjectErrorDoc }; diff --git a/api/lib/infrastructure/open-api-doc/pole-emploi/envois-doc.js b/api/lib/infrastructure/open-api-doc/pole-emploi/envois-doc.js index 7d402b18a4c..99894293081 100644 --- a/api/lib/infrastructure/open-api-doc/pole-emploi/envois-doc.js +++ b/api/lib/infrastructure/open-api-doc/pole-emploi/envois-doc.js @@ -1,4 +1,4 @@ -const Joi = require('joi'); +import Joi from 'joi'; const CAMPAIGN_TYPES = ['EVALUATION', 'COLLECTE_PROFILS']; const TEST_STATUS = [2, 3, 4]; @@ -149,4 +149,4 @@ const poleEmploiEnvoisDoc = Joi.array() ) .label('Envois'); -module.exports = { poleEmploiEnvoisDoc }; +export { poleEmploiEnvoisDoc }; diff --git a/api/lib/infrastructure/open-api-doc/pole-emploi/erreur-doc.js b/api/lib/infrastructure/open-api-doc/pole-emploi/erreur-doc.js index d9ab80ab85b..d307207dfe8 100644 --- a/api/lib/infrastructure/open-api-doc/pole-emploi/erreur-doc.js +++ b/api/lib/infrastructure/open-api-doc/pole-emploi/erreur-doc.js @@ -1,8 +1,10 @@ -const Joi = require('joi'); +import Joi from 'joi'; -module.exports = Joi.object({ +const joiObject = Joi.object({ code: Joi.string().required().description("Code erreur spécifique à l'application."), titre: Joi.string().required().description("Un résumé court et lisible de l'erreur"), statut: Joi.string().required().description("le code d'état HTTP lié à l'erreur"), detail: Joi.string().required().description("Une explication détaillé et lisible de l'erreur"), }).label('Erreur'); + +export { joiObject as erreurDoc }; diff --git a/api/lib/infrastructure/orm-models/Answer.js b/api/lib/infrastructure/orm-models/Answer.js index ad7bd7e1c51..ac11ec6c535 100644 --- a/api/lib/infrastructure/orm-models/Answer.js +++ b/api/lib/infrastructure/orm-models/Answer.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Assessment.js'); +import './Assessment.js'; const modelName = 'Answer'; -module.exports = Bookshelf.model( +const BookshelfAnswer = Bookshelf.model( modelName, { tableName: 'answers', @@ -18,3 +18,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfAnswer }; diff --git a/api/lib/infrastructure/orm-models/Assessment.js b/api/lib/infrastructure/orm-models/Assessment.js index 8bd786cde56..bb712f5fd12 100644 --- a/api/lib/infrastructure/orm-models/Assessment.js +++ b/api/lib/infrastructure/orm-models/Assessment.js @@ -1,13 +1,13 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Answer.js'); -require('./User.js'); -require('./KnowledgeElement.js'); -require('./CampaignParticipation.js'); +import './Answer.js'; +import './User.js'; +import './KnowledgeElement.js'; +import './CampaignParticipation.js'; const modelName = 'Assessment'; -module.exports = Bookshelf.model( +const BookshelfAssessment = Bookshelf.model( modelName, { tableName: 'assessments', @@ -29,3 +29,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfAssessment }; diff --git a/api/lib/infrastructure/orm-models/AuthenticationMethod.js b/api/lib/infrastructure/orm-models/AuthenticationMethod.js index e1b8b10c9d3..80193011ddf 100644 --- a/api/lib/infrastructure/orm-models/AuthenticationMethod.js +++ b/api/lib/infrastructure/orm-models/AuthenticationMethod.js @@ -1,12 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); -// eslint-disable-next-line no-unused-vars -const jsonColumns = require('bookshelf-json-columns'); +import { Bookshelf } from '../bookshelf.js'; -require('./User.js'); +import './User.js'; const modelName = 'AuthenticationMethod'; -module.exports = Bookshelf.model( +const BookshelfAuthenticationMethod = Bookshelf.model( modelName, { tableName: 'authentication-methods', @@ -21,3 +19,5 @@ module.exports = Bookshelf.model( jsonColumns: ['authenticationComplement'], } ); + +export { BookshelfAuthenticationMethod }; diff --git a/api/lib/infrastructure/orm-models/Badge.js b/api/lib/infrastructure/orm-models/Badge.js index 52726f51726..67abcfd144c 100644 --- a/api/lib/infrastructure/orm-models/Badge.js +++ b/api/lib/infrastructure/orm-models/Badge.js @@ -1,12 +1,12 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./BadgeCriterion.js'); -require('./SkillSet.js'); -require('./TargetProfile.js'); +import './BadgeCriterion.js'; +import './SkillSet.js'; +import './TargetProfile.js'; const modelName = 'Badge'; -module.exports = Bookshelf.model( +const BookshelfBadge = Bookshelf.model( modelName, { tableName: 'badges', @@ -27,3 +27,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfBadge }; diff --git a/api/lib/infrastructure/orm-models/BadgeAcquisition.js b/api/lib/infrastructure/orm-models/BadgeAcquisition.js index da04af286cd..c0707f654bc 100644 --- a/api/lib/infrastructure/orm-models/BadgeAcquisition.js +++ b/api/lib/infrastructure/orm-models/BadgeAcquisition.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Badge.js'); -require('./User.js'); +import './Badge.js'; +import './User.js'; const modelName = 'BadgeAcquisition'; -module.exports = Bookshelf.model( +const BookshelfBadgeAcquisition = Bookshelf.model( modelName, { tableName: 'badge-acquisitions', @@ -22,3 +22,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfBadgeAcquisition }; diff --git a/api/lib/infrastructure/orm-models/BadgeCriterion.js b/api/lib/infrastructure/orm-models/BadgeCriterion.js index b4e8dc04e55..bb4dc052abb 100644 --- a/api/lib/infrastructure/orm-models/BadgeCriterion.js +++ b/api/lib/infrastructure/orm-models/BadgeCriterion.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Badge.js'); +import './Badge.js'; const modelName = 'BadgeCriterion'; -module.exports = Bookshelf.model( +const BookshelfBadgeCriteri = Bookshelf.model( modelName, { tableName: 'badge-criteria', @@ -17,3 +17,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfBadgeCriteri }; diff --git a/api/lib/infrastructure/orm-models/Campaign.js b/api/lib/infrastructure/orm-models/Campaign.js index d490397c98d..47e6a5423c8 100644 --- a/api/lib/infrastructure/orm-models/Campaign.js +++ b/api/lib/infrastructure/orm-models/Campaign.js @@ -1,14 +1,14 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Assessment.js'); -require('./CampaignParticipation.js'); -require('./Organization.js'); -require('./TargetProfile.js'); -require('./User.js'); +import './Assessment.js'; +import './CampaignParticipation.js'; +import './Organization.js'; +import './TargetProfile.js'; +import './User.js'; const modelName = 'Campaign'; -module.exports = Bookshelf.model( +const BookshelfCampaign = Bookshelf.model( modelName, { tableName: 'campaigns', @@ -34,3 +34,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCampaign }; diff --git a/api/lib/infrastructure/orm-models/CampaignParticipation.js b/api/lib/infrastructure/orm-models/CampaignParticipation.js index ff2c9f70a6d..71e95b18296 100644 --- a/api/lib/infrastructure/orm-models/CampaignParticipation.js +++ b/api/lib/infrastructure/orm-models/CampaignParticipation.js @@ -1,12 +1,12 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Assessment.js'); -require('./Campaign.js'); -require('./User.js'); +import './Assessment.js'; +import './Campaign.js'; +import './User.js'; const modelName = 'CampaignParticipation'; -module.exports = Bookshelf.model( +const BookshelfCampaignParticipation = Bookshelf.model( modelName, { tableName: 'campaign-participations', @@ -36,3 +36,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCampaignParticipation }; diff --git a/api/lib/infrastructure/orm-models/CertificationCandidate.js b/api/lib/infrastructure/orm-models/CertificationCandidate.js index 56a3e820f58..fb33c6a718b 100644 --- a/api/lib/infrastructure/orm-models/CertificationCandidate.js +++ b/api/lib/infrastructure/orm-models/CertificationCandidate.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Session.js'); -require('./User.js'); +import './Session.js'; +import './User.js'; const modelName = 'CertificationCandidate'; -module.exports = Bookshelf.model( +const BookshelfCertificationCandidate = Bookshelf.model( modelName, { tableName: 'certification-candidates', @@ -23,3 +23,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCertificationCandidate }; diff --git a/api/lib/infrastructure/orm-models/CertificationCenter.js b/api/lib/infrastructure/orm-models/CertificationCenter.js index 77a892f251d..9b7f3f21cb9 100644 --- a/api/lib/infrastructure/orm-models/CertificationCenter.js +++ b/api/lib/infrastructure/orm-models/CertificationCenter.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./ComplementaryCertification.js'); +import './ComplementaryCertification.js'; const modelName = 'CertificationCenter'; -module.exports = Bookshelf.model( +const BookshelfCertificationCenter = Bookshelf.model( modelName, { tableName: 'certification-centers', @@ -27,3 +27,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCertificationCenter }; diff --git a/api/lib/infrastructure/orm-models/CertificationCenterMembership.js b/api/lib/infrastructure/orm-models/CertificationCenterMembership.js index 41cdb61eaf3..aa9dd359825 100644 --- a/api/lib/infrastructure/orm-models/CertificationCenterMembership.js +++ b/api/lib/infrastructure/orm-models/CertificationCenterMembership.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./CertificationCenter.js'); -require('./User.js'); +import './CertificationCenter.js'; +import './User.js'; const modelName = 'CertificationCenterMembership'; -module.exports = Bookshelf.model( +const BookshelfCertificationCenterMembership = Bookshelf.model( modelName, { tableName: 'certification-center-memberships', @@ -23,3 +23,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCertificationCenterMembership }; diff --git a/api/lib/infrastructure/orm-models/CertificationChallenge.js b/api/lib/infrastructure/orm-models/CertificationChallenge.js index f5c4b513428..ae9a8ecc73b 100644 --- a/api/lib/infrastructure/orm-models/CertificationChallenge.js +++ b/api/lib/infrastructure/orm-models/CertificationChallenge.js @@ -1,8 +1,8 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'CertificationChallenge'; -module.exports = Bookshelf.model( +const BookshelfCertificationChallenge = Bookshelf.model( modelName, { tableName: 'certification-challenges', @@ -12,3 +12,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCertificationChallenge }; diff --git a/api/lib/infrastructure/orm-models/CertificationCourse.js b/api/lib/infrastructure/orm-models/CertificationCourse.js index 78239924c2f..62216a41d85 100644 --- a/api/lib/infrastructure/orm-models/CertificationCourse.js +++ b/api/lib/infrastructure/orm-models/CertificationCourse.js @@ -1,14 +1,14 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Assessment.js'); -require('./CertificationChallenge.js'); -require('./CertificationIssueReport.js'); -require('./ComplementaryCertificationCourse.js'); -require('./Session.js'); +import './Assessment.js'; +import './CertificationChallenge.js'; +import './CertificationIssueReport.js'; +import './ComplementaryCertificationCourse.js'; +import './Session.js'; const modelName = 'CertificationCourse'; -module.exports = Bookshelf.model( +const BookshelfCertificationCourse = Bookshelf.model( modelName, { tableName: 'certification-courses', @@ -46,3 +46,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCertificationCourse }; diff --git a/api/lib/infrastructure/orm-models/CertificationIssueReport.js b/api/lib/infrastructure/orm-models/CertificationIssueReport.js index f4dc946787e..88b8502a4d2 100644 --- a/api/lib/infrastructure/orm-models/CertificationIssueReport.js +++ b/api/lib/infrastructure/orm-models/CertificationIssueReport.js @@ -1,8 +1,8 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'CertificationIssueReport'; -module.exports = Bookshelf.model( +const BookshelfCertificationIssueReport = Bookshelf.model( modelName, { tableName: 'certification-issue-reports', @@ -12,3 +12,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCertificationIssueReport }; diff --git a/api/lib/infrastructure/orm-models/CompetenceEvaluation.js b/api/lib/infrastructure/orm-models/CompetenceEvaluation.js index 02d80e52f96..f80ab504f12 100644 --- a/api/lib/infrastructure/orm-models/CompetenceEvaluation.js +++ b/api/lib/infrastructure/orm-models/CompetenceEvaluation.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Assessment.js'); -require('./User.js'); +import './Assessment.js'; +import './User.js'; const modelName = 'CompetenceEvaluation'; -module.exports = Bookshelf.model( +const BookshelfCompetenceEvaluation = Bookshelf.model( modelName, { tableName: 'competence-evaluations', @@ -23,3 +23,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCompetenceEvaluation }; diff --git a/api/lib/infrastructure/orm-models/CompetenceMark.js b/api/lib/infrastructure/orm-models/CompetenceMark.js index c2f464b67e0..c4375293ecc 100644 --- a/api/lib/infrastructure/orm-models/CompetenceMark.js +++ b/api/lib/infrastructure/orm-models/CompetenceMark.js @@ -1,9 +1,9 @@ -const Bookshelf = require('../bookshelf.js'); -const CompetenceMark = require('../../domain/models/CompetenceMark.js'); +import { Bookshelf } from '../bookshelf.js'; +import { CompetenceMark } from '../../domain/models/CompetenceMark.js'; const modelName = 'CompetenceMark'; -module.exports = Bookshelf.model( +const BookshelfCompetenceMark = Bookshelf.model( modelName, { tableName: 'competence-marks', @@ -22,3 +22,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfCompetenceMark }; diff --git a/api/lib/infrastructure/orm-models/ComplementaryCertification.js b/api/lib/infrastructure/orm-models/ComplementaryCertification.js index 7fdfe0b65c7..5018955c6ff 100644 --- a/api/lib/infrastructure/orm-models/ComplementaryCertification.js +++ b/api/lib/infrastructure/orm-models/ComplementaryCertification.js @@ -1,8 +1,8 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'ComplementaryCertification'; -module.exports = Bookshelf.model( +const BookshelfComplementaryCertification = Bookshelf.model( modelName, { tableName: 'complementary-certifications', @@ -12,3 +12,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfComplementaryCertification }; diff --git a/api/lib/infrastructure/orm-models/ComplementaryCertificationCourse.js b/api/lib/infrastructure/orm-models/ComplementaryCertificationCourse.js index 5fdea0410aa..dfa0c45894a 100644 --- a/api/lib/infrastructure/orm-models/ComplementaryCertificationCourse.js +++ b/api/lib/infrastructure/orm-models/ComplementaryCertificationCourse.js @@ -1,8 +1,8 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'ComplementaryCertificationCourse'; -module.exports = Bookshelf.model( +const BookshelfComplementaryCertificationCourse = Bookshelf.model( modelName, { tableName: 'complementary-certification-courses', @@ -12,3 +12,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfComplementaryCertificationCourse }; diff --git a/api/lib/infrastructure/orm-models/ComplementaryCertificationCourseResult.js b/api/lib/infrastructure/orm-models/ComplementaryCertificationCourseResult.js index 3151ada2616..880d30f4cd4 100644 --- a/api/lib/infrastructure/orm-models/ComplementaryCertificationCourseResult.js +++ b/api/lib/infrastructure/orm-models/ComplementaryCertificationCourseResult.js @@ -1,8 +1,8 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'ComplementaryCertificationCourseResult'; -module.exports = Bookshelf.model( +const BookshelfComplementaryCertificationCourseResult = Bookshelf.model( 'ComplementaryCertificationCourseResults', { tableName: 'complementary-certification-course-results', @@ -15,3 +15,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfComplementaryCertificationCourseResult }; diff --git a/api/lib/infrastructure/orm-models/Feedback.js b/api/lib/infrastructure/orm-models/Feedback.js index b165babc44b..f2b5a2d36db 100644 --- a/api/lib/infrastructure/orm-models/Feedback.js +++ b/api/lib/infrastructure/orm-models/Feedback.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Assessment.js'); +import './Assessment.js'; const modelName = 'Feedback'; -module.exports = Bookshelf.model( +const BookshelfFeedback = Bookshelf.model( modelName, { tableName: 'feedbacks', @@ -18,3 +18,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfFeedback as Feedback }; diff --git a/api/lib/infrastructure/orm-models/FinalizedSession.js b/api/lib/infrastructure/orm-models/FinalizedSession.js index 78195e3b443..265fb71f36a 100644 --- a/api/lib/infrastructure/orm-models/FinalizedSession.js +++ b/api/lib/infrastructure/orm-models/FinalizedSession.js @@ -1,8 +1,8 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'FinalizedSession'; -module.exports = Bookshelf.model( +const BookshelfFinalizedSession = Bookshelf.model( modelName, { tableName: 'finalized-sessions', @@ -18,3 +18,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfFinalizedSession }; diff --git a/api/lib/infrastructure/orm-models/KnowledgeElement.js b/api/lib/infrastructure/orm-models/KnowledgeElement.js index 631e0797a48..e359dcc143b 100644 --- a/api/lib/infrastructure/orm-models/KnowledgeElement.js +++ b/api/lib/infrastructure/orm-models/KnowledgeElement.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Assessment.js'); -require('./User.js'); +import './Assessment.js'; +import './User.js'; const modelName = 'KnowledgeElement'; -module.exports = Bookshelf.model( +const BookshelfKnowledgeElement = Bookshelf.model( modelName, { tableName: 'knowledge-elements', @@ -23,3 +23,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfKnowledgeElement }; diff --git a/api/lib/infrastructure/orm-models/KnowledgeElementSnapshot.js b/api/lib/infrastructure/orm-models/KnowledgeElementSnapshot.js index 142f8c829b2..dbcc6ab83b4 100644 --- a/api/lib/infrastructure/orm-models/KnowledgeElementSnapshot.js +++ b/api/lib/infrastructure/orm-models/KnowledgeElementSnapshot.js @@ -1,8 +1,8 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'KnowledgeElementSnapshot'; -module.exports = Bookshelf.model( +const BookshelfKnowledgeElementSnapshot = Bookshelf.model( modelName, { tableName: 'knowledge-element-snapshots', @@ -11,3 +11,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfKnowledgeElementSnapshot }; diff --git a/api/lib/infrastructure/orm-models/Membership.js b/api/lib/infrastructure/orm-models/Membership.js index 46993ece29b..038339b69a6 100644 --- a/api/lib/infrastructure/orm-models/Membership.js +++ b/api/lib/infrastructure/orm-models/Membership.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Organization.js'); -require('./User.js'); +import './Organization.js'; +import './User.js'; const modelName = 'Membership'; -module.exports = Bookshelf.model( +const BookshelfMembership = Bookshelf.model( modelName, { tableName: 'memberships', @@ -23,3 +23,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfMembership }; diff --git a/api/lib/infrastructure/orm-models/Organization.js b/api/lib/infrastructure/orm-models/Organization.js index b1d71e0bb4f..8975265fde9 100644 --- a/api/lib/infrastructure/orm-models/Organization.js +++ b/api/lib/infrastructure/orm-models/Organization.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Tag.js'); +import './Tag.js'; const modelName = 'Organization'; -module.exports = Bookshelf.model( +const BookshelfOrganization = Bookshelf.model( modelName, { tableName: 'organizations', @@ -18,3 +18,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfOrganization }; diff --git a/api/lib/infrastructure/orm-models/OrganizationInvitation.js b/api/lib/infrastructure/orm-models/OrganizationInvitation.js index 9af7b82deb2..4a5f9082a88 100644 --- a/api/lib/infrastructure/orm-models/OrganizationInvitation.js +++ b/api/lib/infrastructure/orm-models/OrganizationInvitation.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Organization.js'); +import './Organization.js'; const modelName = 'OrganizationInvitation'; -module.exports = Bookshelf.model( +const BookshelfOrganizationInvitation = Bookshelf.model( modelName, { tableName: 'organization-invitations', @@ -18,3 +18,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfOrganizationInvitation }; diff --git a/api/lib/infrastructure/orm-models/OrganizationLearner.js b/api/lib/infrastructure/orm-models/OrganizationLearner.js index d7e19c1005f..c08d6248b96 100644 --- a/api/lib/infrastructure/orm-models/OrganizationLearner.js +++ b/api/lib/infrastructure/orm-models/OrganizationLearner.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./User.js'); -require('./Organization.js'); +import './User.js'; +import './Organization.js'; const modelName = 'OrganizationLearner'; -module.exports = Bookshelf.model( +const BookshelfOrganizationLearner = Bookshelf.model( modelName, { tableName: 'organization-learners', @@ -23,3 +23,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfOrganizationLearner }; diff --git a/api/lib/infrastructure/orm-models/OrganizationTag.js b/api/lib/infrastructure/orm-models/OrganizationTag.js index a456fd7fff6..69076a845ce 100644 --- a/api/lib/infrastructure/orm-models/OrganizationTag.js +++ b/api/lib/infrastructure/orm-models/OrganizationTag.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Organization.js'); -require('./Tag.js'); +import './Organization.js'; +import './Tag.js'; const modelName = 'OrganizationTag'; -module.exports = Bookshelf.model( +const BookshelfOrganizationTag = Bookshelf.model( modelName, { tableName: 'organization-tags', @@ -23,3 +23,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfOrganizationTag }; diff --git a/api/lib/infrastructure/orm-models/PoleEmploiSending.js b/api/lib/infrastructure/orm-models/PoleEmploiSending.js index d5d994c6d6d..12c92bdd228 100644 --- a/api/lib/infrastructure/orm-models/PoleEmploiSending.js +++ b/api/lib/infrastructure/orm-models/PoleEmploiSending.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./CampaignParticipation.js'); +import './CampaignParticipation.js'; const modelName = 'PoleEmploiSending'; -module.exports = Bookshelf.model( +const BookshelfPoleEmploiSending = Bookshelf.model( modelName, { tableName: 'pole-emploi-sendings', @@ -18,3 +18,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfPoleEmploiSending }; diff --git a/api/lib/infrastructure/orm-models/ResetPasswordDemand.js b/api/lib/infrastructure/orm-models/ResetPasswordDemand.js index 0a246c5d480..29c5bb09283 100644 --- a/api/lib/infrastructure/orm-models/ResetPasswordDemand.js +++ b/api/lib/infrastructure/orm-models/ResetPasswordDemand.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./User.js'); +import './User.js'; const modelName = 'ResetPasswordDemand'; -module.exports = Bookshelf.model( +const BookshelfResetPasswordDemand = Bookshelf.model( modelName, { tableName: 'reset-password-demands', @@ -18,3 +18,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfResetPasswordDemand as ResetPasswordDemand }; diff --git a/api/lib/infrastructure/orm-models/Session.js b/api/lib/infrastructure/orm-models/Session.js index bde28f82612..442e062e3c5 100644 --- a/api/lib/infrastructure/orm-models/Session.js +++ b/api/lib/infrastructure/orm-models/Session.js @@ -1,9 +1,9 @@ -const Bookshelf = require('../bookshelf.js'); -require('./CertificationCandidate.js'); +import { Bookshelf } from '../bookshelf.js'; +import './CertificationCandidate.js'; const modelName = 'Session'; -module.exports = Bookshelf.model( +const BookshelfSession = Bookshelf.model( modelName, { tableName: 'sessions', @@ -17,3 +17,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfSession }; diff --git a/api/lib/infrastructure/orm-models/SkillSet.js b/api/lib/infrastructure/orm-models/SkillSet.js index 4e24a45ef7d..7efe3268056 100644 --- a/api/lib/infrastructure/orm-models/SkillSet.js +++ b/api/lib/infrastructure/orm-models/SkillSet.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Badge.js'); +import './Badge.js'; const modelName = 'SkillSet'; -module.exports = Bookshelf.model( +const BookshelfSkillSet = Bookshelf.model( modelName, { tableName: 'skill-sets', @@ -17,3 +17,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfSkillSet }; diff --git a/api/lib/infrastructure/orm-models/Stage.js b/api/lib/infrastructure/orm-models/Stage.js index fe12d56f952..2fef7ba569f 100644 --- a/api/lib/infrastructure/orm-models/Stage.js +++ b/api/lib/infrastructure/orm-models/Stage.js @@ -1,9 +1,9 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'Stage'; -require('./TargetProfile.js'); +import './TargetProfile.js'; -module.exports = Bookshelf.model( +const BookshelfStage = Bookshelf.model( modelName, { tableName: 'stages', @@ -17,3 +17,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfStage }; diff --git a/api/lib/infrastructure/orm-models/Tag.js b/api/lib/infrastructure/orm-models/Tag.js index 29d75a7aa83..8706f40f7c2 100644 --- a/api/lib/infrastructure/orm-models/Tag.js +++ b/api/lib/infrastructure/orm-models/Tag.js @@ -1,8 +1,8 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; const modelName = 'Tag'; -module.exports = Bookshelf.model( +const BookshelfTag = Bookshelf.model( modelName, { tableName: 'tags', @@ -12,3 +12,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfTag }; diff --git a/api/lib/infrastructure/orm-models/TargetProfile.js b/api/lib/infrastructure/orm-models/TargetProfile.js index f2a85136c18..6fda989a798 100644 --- a/api/lib/infrastructure/orm-models/TargetProfile.js +++ b/api/lib/infrastructure/orm-models/TargetProfile.js @@ -1,12 +1,12 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Badge.js'); -require('./Stage.js'); -require('./Organization.js'); +import './Badge.js'; +import './Stage.js'; +import './Organization.js'; const modelName = 'TargetProfile'; -module.exports = Bookshelf.model( +const BookshelfTargetProfile = Bookshelf.model( modelName, { tableName: 'target-profiles', @@ -28,3 +28,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfTargetProfile }; diff --git a/api/lib/infrastructure/orm-models/TargetProfileShare.js b/api/lib/infrastructure/orm-models/TargetProfileShare.js index 95baf582b43..a1abb1bb317 100644 --- a/api/lib/infrastructure/orm-models/TargetProfileShare.js +++ b/api/lib/infrastructure/orm-models/TargetProfileShare.js @@ -1,10 +1,10 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./TargetProfile.js'); +import './TargetProfile.js'; const modelName = 'TargetProfileShare'; -module.exports = Bookshelf.model( +const BookshelfTargetProfileShare = Bookshelf.model( modelName, { tableName: 'target-profile-shares', @@ -22,3 +22,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfTargetProfileShare }; diff --git a/api/lib/infrastructure/orm-models/User.js b/api/lib/infrastructure/orm-models/User.js index 0297c1e2eb6..11c6fe04a39 100644 --- a/api/lib/infrastructure/orm-models/User.js +++ b/api/lib/infrastructure/orm-models/User.js @@ -1,16 +1,16 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./Assessment.js'); -require('./KnowledgeElement.js'); -require('./Membership.js'); -require('./CertificationCenterMembership.js'); -require('./UserOrgaSettings.js'); -require('./OrganizationLearner.js'); -require('./AuthenticationMethod.js'); +import './Assessment.js'; +import './KnowledgeElement.js'; +import './Membership.js'; +import './CertificationCenterMembership.js'; +import './UserOrgaSettings.js'; +import './OrganizationLearner.js'; +import './AuthenticationMethod.js'; const modelName = 'User'; -module.exports = Bookshelf.model( +const BookshelfUser = Bookshelf.model( modelName, { tableName: 'users', @@ -48,3 +48,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfUser }; diff --git a/api/lib/infrastructure/orm-models/UserOrgaSettings.js b/api/lib/infrastructure/orm-models/UserOrgaSettings.js index 949a464a09d..a6436784864 100644 --- a/api/lib/infrastructure/orm-models/UserOrgaSettings.js +++ b/api/lib/infrastructure/orm-models/UserOrgaSettings.js @@ -1,11 +1,11 @@ -const Bookshelf = require('../bookshelf.js'); +import { Bookshelf } from '../bookshelf.js'; -require('./User.js'); -require('./Organization.js'); +import './User.js'; +import './Organization.js'; const modelName = 'UserOrgaSettings'; -module.exports = Bookshelf.model( +const BookshelfUserOrgaSetting = Bookshelf.model( modelName, { tableName: 'user-orga-settings', @@ -23,3 +23,5 @@ module.exports = Bookshelf.model( modelName, } ); + +export { BookshelfUserOrgaSetting as BookshelfUserOrgaSettings }; diff --git a/api/lib/infrastructure/plugins/i18n.js b/api/lib/infrastructure/plugins/i18n.js index e216100740f..dc3700db770 100644 --- a/api/lib/infrastructure/plugins/i18n.js +++ b/api/lib/infrastructure/plugins/i18n.js @@ -1,4 +1,6 @@ -const hapiI18n = require('hapi-i18n'); +import hapiI18n from 'hapi-i18n'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); const plugin = hapiI18n; const options = { locales: ['en', 'fr'], @@ -10,7 +12,4 @@ const options = { updateFiles: false, }; -module.exports = { - plugin, - options, -}; +export { plugin, options }; diff --git a/api/lib/infrastructure/plugins/index.js b/api/lib/infrastructure/plugins/index.js index 15e0e86088e..7d3fe3c6f7f 100644 --- a/api/lib/infrastructure/plugins/index.js +++ b/api/lib/infrastructure/plugins/index.js @@ -1,10 +1,10 @@ -const Inert = require('@hapi/inert'); -const Vision = require('@hapi/vision'); -const config = require('../../config.js'); -const i18n = require('./i18n.js'); -const pino = require('./pino.js'); -const sentry = require('./sentry.js'); +import Inert from '@hapi/inert'; +import Vision from '@hapi/vision'; +import { config } from '../../config.js'; +import * as i18n from './i18n.js'; +import * as pino from './pino.js'; +import * as sentry from './sentry.js'; const plugins = [Inert, Vision, i18n, pino, ...(config.sentry.enabled ? [sentry] : [])]; -module.exports = plugins; +export { plugins }; diff --git a/api/lib/infrastructure/plugins/pino.js b/api/lib/infrastructure/plugins/pino.js index 318798ca232..2040d9b49cf 100644 --- a/api/lib/infrastructure/plugins/pino.js +++ b/api/lib/infrastructure/plugins/pino.js @@ -1,8 +1,8 @@ -const config = require('../../config.js'); -const monitoringTools = require('../monitoring-tools.js'); -const hapiPino = require('hapi-pino'); -const logger = require('../logger.js'); -const crypto = require('crypto'); +import { config } from '../../config.js'; +import { monitoringTools } from '../monitoring-tools.js'; +import hapiPino from 'hapi-pino'; +import { logger } from '../logger.js'; +import crypto from 'crypto'; function logObjectSerializer(req) { const enhancedReq = { @@ -37,7 +37,4 @@ const options = { logQueryParams: true, }; -module.exports = { - plugin, - options, -}; +export { plugin, options }; diff --git a/api/lib/infrastructure/plugins/sentry.js b/api/lib/infrastructure/plugins/sentry.js index 599eff2a5af..4476ea6e19b 100644 --- a/api/lib/infrastructure/plugins/sentry.js +++ b/api/lib/infrastructure/plugins/sentry.js @@ -1,6 +1,7 @@ -const hapiSentry = require('hapi-sentry'); -const packageJSON = require('../../../package.json'); -const config = require('../../config.js'); +import hapiSentry from 'hapi-sentry'; +import packageJSON from '../../../package.json' assert { type: 'json' }; + +import { config } from '../../config.js'; const plugin = hapiSentry; const options = { @@ -17,7 +18,4 @@ const options = { }, }; -module.exports = { - plugin, - options, -}; +export { plugin, options }; diff --git a/api/lib/infrastructure/repositories/account-recovery-demand-repository.js b/api/lib/infrastructure/repositories/account-recovery-demand-repository.js index d8c0257f96b..2fb0392d0f7 100644 --- a/api/lib/infrastructure/repositories/account-recovery-demand-repository.js +++ b/api/lib/infrastructure/repositories/account-recovery-demand-repository.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const AccountRecoveryDemand = require('../../domain/models/AccountRecoveryDemand.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { AccountRecoveryDemand } from '../../domain/models/AccountRecoveryDemand.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { DomainTransaction } from '../DomainTransaction.js'; const _toDomain = (accountRecoveryDemandDTO) => { return new AccountRecoveryDemand(accountRecoveryDemandDTO); @@ -12,41 +12,41 @@ const _toDomainArray = (accountRecoveryDemandsDTOs) => { return _.map(accountRecoveryDemandsDTOs, _toDomain); }; -module.exports = { - async findByTemporaryKey(temporaryKey) { - const accountRecoveryDemandDTO = await knex - .where({ temporaryKey }) - .select('id', 'organizationLearnerId', 'userId', 'oldEmail', 'newEmail', 'temporaryKey', 'used', 'createdAt') - .from('account-recovery-demands') - .first(); - - if (!accountRecoveryDemandDTO) { - throw new NotFoundError('No account recovery demand found'); - } - - return _toDomain(accountRecoveryDemandDTO); - }, - - async findByUserId(userId) { - const accountRecoveryDemandsDTOs = await knex - .select('id', 'organizationLearnerId', 'userId', 'oldEmail', 'newEmail', 'temporaryKey', 'used', 'createdAt') - .from('account-recovery-demands') - .where({ userId }); - - return _toDomainArray(accountRecoveryDemandsDTOs); - }, - - async save(accountRecoveryDemand) { - const result = await knex('account-recovery-demands').insert(accountRecoveryDemand).returning('*'); - - return _toDomain(result[0]); - }, - - async markAsBeingUsed(temporaryKey, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const query = knex('account-recovery-demands') - .where({ temporaryKey }) - .update({ used: true, updatedAt: knex.fn.now() }); - if (knexTransaction) query.transacting(knexTransaction); - return query; - }, +const findByTemporaryKey = async function (temporaryKey) { + const accountRecoveryDemandDTO = await knex + .where({ temporaryKey }) + .select('id', 'organizationLearnerId', 'userId', 'oldEmail', 'newEmail', 'temporaryKey', 'used', 'createdAt') + .from('account-recovery-demands') + .first(); + + if (!accountRecoveryDemandDTO) { + throw new NotFoundError('No account recovery demand found'); + } + + return _toDomain(accountRecoveryDemandDTO); +}; + +const findByUserId = async function (userId) { + const accountRecoveryDemandsDTOs = await knex + .select('id', 'organizationLearnerId', 'userId', 'oldEmail', 'newEmail', 'temporaryKey', 'used', 'createdAt') + .from('account-recovery-demands') + .where({ userId }); + + return _toDomainArray(accountRecoveryDemandsDTOs); }; + +const save = async function (accountRecoveryDemand) { + const result = await knex('account-recovery-demands').insert(accountRecoveryDemand).returning('*'); + + return _toDomain(result[0]); +}; + +const markAsBeingUsed = async function (temporaryKey, { knexTransaction } = DomainTransaction.emptyTransaction()) { + const query = knex('account-recovery-demands') + .where({ temporaryKey }) + .update({ used: true, updatedAt: knex.fn.now() }); + if (knexTransaction) query.transacting(knexTransaction); + return query; +}; + +export { findByTemporaryKey, findByUserId, save, markAsBeingUsed }; diff --git a/api/lib/infrastructure/repositories/admin-member-repository.js b/api/lib/infrastructure/repositories/admin-member-repository.js index c3a523e302e..417e7badd87 100644 --- a/api/lib/infrastructure/repositories/admin-member-repository.js +++ b/api/lib/infrastructure/repositories/admin-member-repository.js @@ -1,80 +1,80 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const AdminMember = require('../../domain/models/AdminMember.js'); -const { AdminMemberError } = require('../../domain/errors.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { AdminMember } from '../../domain/models/AdminMember.js'; +import { AdminMemberError } from '../../domain/errors.js'; const TABLE_NAME = 'pix-admin-roles'; -module.exports = { - findAll: async function () { - const members = await knex - .select(`${TABLE_NAME}.id`, 'users.id as userId', 'firstName', 'lastName', 'email', 'role') - .from(TABLE_NAME) - .where({ disabledAt: null }) - .join('users', 'users.id', `${TABLE_NAME}.userId`) - .orderBy(['firstName', 'lastName']); +const findAll = async function () { + const members = await knex + .select(`${TABLE_NAME}.id`, 'users.id as userId', 'firstName', 'lastName', 'email', 'role') + .from(TABLE_NAME) + .where({ disabledAt: null }) + .join('users', 'users.id', `${TABLE_NAME}.userId`) + .orderBy(['firstName', 'lastName']); - return members.map((member) => new AdminMember(member)); - }, + return members.map((member) => new AdminMember(member)); +}; - getById: async function (id) { - const adminMember = await knex - .select(`${TABLE_NAME}.id`, 'users.id as userId', 'firstName', 'lastName', 'email', 'role', 'disabledAt') - .from(TABLE_NAME) - .where({ 'pix-admin-roles.id': id }) - .join('users', 'users.id', `${TABLE_NAME}.userId`) - .first(); +const getById = async function (id) { + const adminMember = await knex + .select(`${TABLE_NAME}.id`, 'users.id as userId', 'firstName', 'lastName', 'email', 'role', 'disabledAt') + .from(TABLE_NAME) + .where({ 'pix-admin-roles.id': id }) + .join('users', 'users.id', `${TABLE_NAME}.userId`) + .first(); - return adminMember ? new AdminMember(adminMember) : undefined; - }, + return adminMember ? new AdminMember(adminMember) : undefined; +}; - get: async function ({ userId }) { - const adminMember = await knex - .select(`${TABLE_NAME}.id`, 'users.id as userId', 'firstName', 'lastName', 'email', 'role', 'disabledAt') - .from(TABLE_NAME) - .where({ userId }) - .join('users', 'users.id', `${TABLE_NAME}.userId`) - .first(); +const get = async function ({ userId }) { + const adminMember = await knex + .select(`${TABLE_NAME}.id`, 'users.id as userId', 'firstName', 'lastName', 'email', 'role', 'disabledAt') + .from(TABLE_NAME) + .where({ userId }) + .join('users', 'users.id', `${TABLE_NAME}.userId`) + .first(); - return adminMember ? new AdminMember(adminMember) : undefined; - }, + return adminMember ? new AdminMember(adminMember) : undefined; +}; - async update({ id, attributesToUpdate }) { - const now = new Date(); - const [updatedAdminMember] = await knex - .from(TABLE_NAME) - .where({ id }) - .update({ ...attributesToUpdate, updatedAt: now }) - .returning('*'); +const update = async function ({ id, attributesToUpdate }) { + const now = new Date(); + const [updatedAdminMember] = await knex + .from(TABLE_NAME) + .where({ id }) + .update({ ...attributesToUpdate, updatedAt: now }) + .returning('*'); - if (!updatedAdminMember) { - throw new AdminMemberError( - 'A problem occurred while trying to update an admin member role', - 'UPDATE_ADMIN_MEMBER_ERROR' - ); - } + if (!updatedAdminMember) { + throw new AdminMemberError( + 'A problem occurred while trying to update an admin member role', + 'UPDATE_ADMIN_MEMBER_ERROR' + ); + } - return new AdminMember(updatedAdminMember); - }, + return new AdminMember(updatedAdminMember); +}; - async save(pixAdminRole) { - const [savedAdminMember] = await knex(TABLE_NAME).insert(pixAdminRole).returning('*'); - return new AdminMember(savedAdminMember); - }, +const save = async function (pixAdminRole) { + const [savedAdminMember] = await knex(TABLE_NAME).insert(pixAdminRole).returning('*'); + return new AdminMember(savedAdminMember); +}; - async deactivate({ id }) { - const now = new Date(); - const [deactivateddAdminMember] = await knex - .from('pix-admin-roles') - .where({ id }) - .whereRaw('"disabledAt" IS NULL') - .update({ disabledAt: now, updatedAt: now }) - .returning('*'); +const deactivate = async function ({ id }) { + const now = new Date(); + const [deactivateddAdminMember] = await knex + .from('pix-admin-roles') + .where({ id }) + .whereRaw('"disabledAt" IS NULL') + .update({ disabledAt: now, updatedAt: now }) + .returning('*'); - if (!deactivateddAdminMember) { - throw new AdminMemberError( - 'A problem occurred while trying to deactivate an admin member', - 'DEACTIVATE_ADMIN_MEMBER_ERROR' - ); - } - }, + if (!deactivateddAdminMember) { + throw new AdminMemberError( + 'A problem occurred while trying to deactivate an admin member', + 'DEACTIVATE_ADMIN_MEMBER_ERROR' + ); + } }; + +export { findAll, getById, get, update, save, deactivate }; diff --git a/api/lib/infrastructure/repositories/answer-repository.js b/api/lib/infrastructure/repositories/answer-repository.js index cf94a1ad424..2ffdbe8fda9 100644 --- a/api/lib/infrastructure/repositories/answer-repository.js +++ b/api/lib/infrastructure/repositories/answer-repository.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const jsYaml = require('js-yaml'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { ChallengeAlreadyAnsweredError, NotFoundError } = require('../../domain/errors.js'); -const Answer = require('../../domain/models/Answer.js'); -const answerStatusDatabaseAdapter = require('../adapters/answer-status-database-adapter.js'); +import _ from 'lodash'; +import jsYaml from 'js-yaml'; +import { knex } from '../../../db/knex-database-connection.js'; +import { ChallengeAlreadyAnsweredError, NotFoundError } from '../../domain/errors.js'; +import { Answer } from '../../domain/models/Answer.js'; +import * as answerStatusDatabaseAdapter from '../adapters/answer-status-database-adapter.js'; function _adaptAnswerToDb(answer) { return { @@ -48,83 +48,91 @@ const COLUMNS = Object.freeze([ 'timeSpent', ]); -module.exports = { - async get(id) { - const answerDTO = await knex.select(COLUMNS).from('answers').where({ id }).first(); +const get = async function (id) { + const answerDTO = await knex.select(COLUMNS).from('answers').where({ id }).first(); - if (!answerDTO) { - throw new NotFoundError(`Not found answer for ID ${id}`); - } + if (!answerDTO) { + throw new NotFoundError(`Not found answer for ID ${id}`); + } - return _toDomain(answerDTO); - }, + return _toDomain(answerDTO); +}; - async findByIds(ids) { - const answerDTOs = await knex.select(COLUMNS).from('answers').whereInArray('id', ids).orderBy('id'); +const findByIds = async function (ids) { + const answerDTOs = await knex.select(COLUMNS).from('answers').whereInArray('id', ids).orderBy('id'); - return _toDomainArray(answerDTOs); - }, + return _toDomainArray(answerDTOs); +}; - async findByChallengeAndAssessment({ challengeId, assessmentId }) { - const answerDTO = await knex - .select(COLUMNS) - .from('answers') - .where({ challengeId, assessmentId }) - .orderBy('createdAt', 'desc') - .first(); +const findByChallengeAndAssessment = async function ({ challengeId, assessmentId }) { + const answerDTO = await knex + .select(COLUMNS) + .from('answers') + .where({ challengeId, assessmentId }) + .orderBy('createdAt', 'desc') + .first(); - if (!answerDTO) { - return null; - } + if (!answerDTO) { + return null; + } - return _toDomain(answerDTO); - }, + return _toDomain(answerDTO); +}; - async findByAssessment(assessmentId) { - const answerDTOs = await knex.select(COLUMNS).from('answers').where({ assessmentId }).orderBy('createdAt'); - const answerDTOsWithoutDuplicate = _.uniqBy(answerDTOs, 'challengeId'); +const findByAssessment = async function (assessmentId) { + const answerDTOs = await knex.select(COLUMNS).from('answers').where({ assessmentId }).orderBy('createdAt'); + const answerDTOsWithoutDuplicate = _.uniqBy(answerDTOs, 'challengeId'); - return _toDomainArray(answerDTOsWithoutDuplicate); - }, + return _toDomainArray(answerDTOsWithoutDuplicate); +}; - async findLastByAssessment(assessmentId) { - const answerDTO = await knex - .select(COLUMNS) - .from('answers') - .where({ assessmentId }) - .orderBy('createdAt', 'desc') - .first(); +const findLastByAssessment = async function (assessmentId) { + const answerDTO = await knex + .select(COLUMNS) + .from('answers') + .where({ assessmentId }) + .orderBy('createdAt', 'desc') + .first(); - if (!answerDTO) { - return null; - } + if (!answerDTO) { + return null; + } - return _toDomain(answerDTO); - }, - - async findChallengeIdsFromAnswerIds(ids) { - return knex.distinct().pluck('challengeId').from('answers').whereInArray('id', ids); - }, - - async saveWithKnowledgeElements(answer, knowledgeElements) { - const answerForDB = _adaptAnswerToDb(answer); - return knex.transaction(async (trx) => { - const alreadySavedAnswer = await trx('answers') - .select('id') - .where({ challengeId: answer.challengeId, assessmentId: answer.assessmentId }); - if (alreadySavedAnswer.length !== 0) { - throw new ChallengeAlreadyAnsweredError(); - } - const [savedAnswerDTO] = await trx('answers').insert(answerForDB).returning(COLUMNS); - const savedAnswer = _toDomain(savedAnswerDTO); - if (!_.isEmpty(knowledgeElements)) { - for (const knowledgeElement of knowledgeElements) { - knowledgeElement.answerId = savedAnswer.id; - } - const knowledgeElementsForDB = knowledgeElements.map(_adaptKnowledgeElementToDb); - await trx('knowledge-elements').insert(knowledgeElementsForDB); + return _toDomain(answerDTO); +}; + +const findChallengeIdsFromAnswerIds = async function (ids) { + return knex.distinct().pluck('challengeId').from('answers').whereInArray('id', ids); +}; + +const saveWithKnowledgeElements = async function (answer, knowledgeElements) { + const answerForDB = _adaptAnswerToDb(answer); + return knex.transaction(async (trx) => { + const alreadySavedAnswer = await trx('answers') + .select('id') + .where({ challengeId: answer.challengeId, assessmentId: answer.assessmentId }); + if (alreadySavedAnswer.length !== 0) { + throw new ChallengeAlreadyAnsweredError(); + } + const [savedAnswerDTO] = await trx('answers').insert(answerForDB).returning(COLUMNS); + const savedAnswer = _toDomain(savedAnswerDTO); + if (!_.isEmpty(knowledgeElements)) { + for (const knowledgeElement of knowledgeElements) { + knowledgeElement.answerId = savedAnswer.id; } - return savedAnswer; - }); - }, + const knowledgeElementsForDB = knowledgeElements.map(_adaptKnowledgeElementToDb); + await trx('knowledge-elements').insert(knowledgeElementsForDB); + } + return savedAnswer; + }); +}; + +export { + get, + findByIds, + findByChallengeAndAssessment, + findByAssessment, + findLastByAssessment, + findChallengeIdsFromAnswerIds, + saveWithKnowledgeElements, }; diff --git a/api/lib/infrastructure/repositories/area-repository.js b/api/lib/infrastructure/repositories/area-repository.js index a4244e6c4ba..f9c7e06ffe8 100644 --- a/api/lib/infrastructure/repositories/area-repository.js +++ b/api/lib/infrastructure/repositories/area-repository.js @@ -1,9 +1,9 @@ -const Area = require('../../domain/models/Area.js'); -const { areaDatasource } = require('../datasources/learning-content/area-datasource.js'); -const competenceRepository = require('./competence-repository.js'); -const { getTranslatedKey } = require('../../domain/services/get-translated-text.js'); -const _ = require('lodash'); -const { NotFoundError } = require('../../domain/errors.js'); +import { Area } from '../../domain/models/Area.js'; +import { areaDatasource } from '../datasources/learning-content/area-datasource.js'; +import * as competenceRepository from './competence-repository.js'; +import { getTranslatedKey } from '../../domain/services/get-translated-text.js'; +import _ from 'lodash'; +import { NotFoundError } from '../../domain/errors.js'; function _toDomain({ areaData, locale }) { const translatedTitle = getTranslatedKey(areaData.title_i18n, locale); @@ -62,11 +62,4 @@ async function get({ id, locale }) { return _toDomain({ areaData, locale }); } -module.exports = { - list, - listWithPixCompetencesOnly, - findByFrameworkIdWithCompetences, - findByFrameworkId, - findByRecordIds, - get, -}; +export { list, listWithPixCompetencesOnly, findByFrameworkIdWithCompetences, findByFrameworkId, findByRecordIds, get }; diff --git a/api/lib/infrastructure/repositories/assessment-repository.js b/api/lib/infrastructure/repositories/assessment-repository.js index c597ccf3010..5a23856cc71 100644 --- a/api/lib/infrastructure/repositories/assessment-repository.js +++ b/api/lib/infrastructure/repositories/assessment-repository.js @@ -1,171 +1,190 @@ -const BookshelfAssessment = require('../orm-models/Assessment.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const Assessment = require('../../domain/models/Assessment.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const { groupBy, map, head, uniqBy, omit } = require('lodash'); -const { NotFoundError } = require('../../domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); - -module.exports = { - async getWithAnswers(id) { - const [assessment] = await knex('assessments').where('assessments.id', id); - if (!assessment) { - throw new NotFoundError(`Assessment not found for ID ${id}`); - } +import { BookshelfAssessment } from '../orm-models/Assessment.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { Assessment } from '../../domain/models/Assessment.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import lodash from 'lodash'; + +const { groupBy, map, head, uniqBy, omit } = lodash; + +import { NotFoundError } from '../../domain/errors.js'; +import { knex } from '../../../db/knex-database-connection.js'; + +const getWithAnswers = async function (id) { + const [assessment] = await knex('assessments').where('assessments.id', id); + if (!assessment) { + throw new NotFoundError(`Assessment not found for ID ${id}`); + } + + const answers = await knex('answers') + .select('id', 'challengeId', 'value') + .where('assessmentId', id) + .orderBy('createdAt'); + assessment.answers = uniqBy(answers, 'challengeId'); + return new Assessment(assessment); +}; - const answers = await knex('answers') - .select('id', 'challengeId', 'value') - .where('assessmentId', id) - .orderBy('createdAt'); - assessment.answers = uniqBy(answers, 'challengeId'); - return new Assessment(assessment); - }, +const get = async function (id, domainTransaction = DomainTransaction.emptyTransaction()) { + const knexConn = domainTransaction.knexTransaction || knex; + const assessment = await knexConn('assessments').where({ id }).first(); - async get(id, domainTransaction = DomainTransaction.emptyTransaction()) { - const knexConn = domainTransaction.knexTransaction || knex; - const assessment = await knexConn('assessments').where({ id }).first(); + if (!assessment) { + throw new NotFoundError("L'assessment n'existe pas ou son accès est restreint"); + } + return new Assessment(assessment); +}; - if (!assessment) { - throw new NotFoundError("L'assessment n'existe pas ou son accès est restreint"); - } - return new Assessment(assessment); - }, - - findLastCompletedAssessmentsForEachCompetenceByUser(userId, limitDate) { - return BookshelfAssessment.collection() - .query((qb) => { - qb.join('assessment-results', 'assessment-results.assessmentId', 'assessments.id'); - qb.where({ userId }) - .where(function () { - this.where({ type: 'PLACEMENT' }); - }) - .where('assessments.createdAt', '<', limitDate) - .where('assessment-results.createdAt', '<', limitDate) - .where('assessments.state', '=', 'completed') - .orderBy('assessments.createdAt', 'desc'); - }) - .fetch({ require: false }) - .then((bookshelfAssessmentCollection) => bookshelfAssessmentCollection.models) - .then(_selectLastAssessmentForEachCompetence) - .then((assessments) => bookshelfToDomainConverter.buildDomainObjects(BookshelfAssessment, assessments)); - }, - - getByAssessmentIdAndUserId(assessmentId, userId) { - return BookshelfAssessment.query({ where: { id: assessmentId }, andWhere: { userId } }) - .fetch() - .then((assessment) => bookshelfToDomainConverter.buildDomainObject(BookshelfAssessment, assessment)) - .catch((error) => { - if (error instanceof BookshelfAssessment.NotFoundError) { - throw new NotFoundError(); - } - - throw error; - }); - }, - - async save({ assessment, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction.knexTransaction || knex; - assessment.validate(); - const [assessmentCreated] = await knexConn('assessments').insert(_adaptModelToDb(assessment)).returning('*'); - return new Assessment(assessmentCreated); - }, - - findNotAbortedCampaignAssessmentsByUserId(userId) { - return BookshelfAssessment.where({ userId, type: 'CAMPAIGN' }) - .where('state', '!=', 'aborted') - .fetchAll() - .then((assessments) => bookshelfToDomainConverter.buildDomainObjects(BookshelfAssessment, assessments)); - }, - - abortByAssessmentId(assessmentId) { - return this._updateStateById({ id: assessmentId, state: Assessment.states.ABORTED }); - }, - - completeByAssessmentId(assessmentId, domainTransaction = DomainTransaction.emptyTransaction()) { - return this._updateStateById( - { id: assessmentId, state: Assessment.states.COMPLETED }, - domainTransaction.knexTransaction - ); - }, - - endBySupervisorByAssessmentId(assessmentId) { - return this._updateStateById({ id: assessmentId, state: Assessment.states.ENDED_BY_SUPERVISOR }); - }, - - async getByCertificationCandidateId(certificationCandidateId) { - const assessment = await knex('assessments') - .select('assessments.*') - .innerJoin('certification-courses', 'certification-courses.id', 'assessments.certificationCourseId') - .innerJoin('certification-candidates', function () { - this.on('certification-candidates.userId', 'certification-courses.userId').andOn( - 'certification-candidates.sessionId', - 'certification-courses.sessionId' - ); - }) - .where({ 'certification-candidates.id': certificationCandidateId }) - .first(); - return new Assessment({ ...assessment }); - }, - - async ownedByUser({ id, userId = null }) { - const assessment = await knex('assessments').select('userId').where({ id }).first(); - - if (!assessment) { - return false; - } +const findLastCompletedAssessmentsForEachCompetenceByUser = function (userId, limitDate) { + return BookshelfAssessment.collection() + .query((qb) => { + qb.join('assessment-results', 'assessment-results.assessmentId', 'assessments.id'); + qb.where({ userId }) + .where(function () { + this.where({ type: 'PLACEMENT' }); + }) + .where('assessments.createdAt', '<', limitDate) + .where('assessment-results.createdAt', '<', limitDate) + .where('assessments.state', '=', 'completed') + .orderBy('assessments.createdAt', 'desc'); + }) + .fetch({ require: false }) + .then((bookshelfAssessmentCollection) => bookshelfAssessmentCollection.models) + .then(_selectLastAssessmentForEachCompetence) + .then((assessments) => bookshelfToDomainConverter.buildDomainObjects(BookshelfAssessment, assessments)); +}; - return assessment.userId === userId; - }, +const getByAssessmentIdAndUserId = function (assessmentId, userId) { + return BookshelfAssessment.query({ where: { id: assessmentId }, andWhere: { userId } }) + .fetch() + .then((assessment) => bookshelfToDomainConverter.buildDomainObject(BookshelfAssessment, assessment)) + .catch((error) => { + if (error instanceof BookshelfAssessment.NotFoundError) { + throw new NotFoundError(); + } - async _updateStateById({ id, state }, knexTransaction) { - const assessment = await BookshelfAssessment.where({ id }).save( - { state }, - { require: true, patch: true, transacting: knexTransaction } - ); - return bookshelfToDomainConverter.buildDomainObject(BookshelfAssessment, assessment); - }, - - async updateLastQuestionDate({ id, lastQuestionDate }) { - try { - await BookshelfAssessment.where({ id }).save( - { lastQuestionDate }, - { require: true, patch: true, method: 'update' } + throw error; + }); +}; + +const save = async function ({ assessment, domainTransaction = DomainTransaction.emptyTransaction() }) { + const knexConn = domainTransaction.knexTransaction || knex; + assessment.validate(); + const [assessmentCreated] = await knexConn('assessments').insert(_adaptModelToDb(assessment)).returning('*'); + return new Assessment(assessmentCreated); +}; + +const findNotAbortedCampaignAssessmentsByUserId = function (userId) { + return BookshelfAssessment.where({ userId, type: 'CAMPAIGN' }) + .where('state', '!=', 'aborted') + .fetchAll() + .then((assessments) => bookshelfToDomainConverter.buildDomainObjects(BookshelfAssessment, assessments)); +}; + +const abortByAssessmentId = function (assessmentId) { + return this._updateStateById({ id: assessmentId, state: Assessment.states.ABORTED }); +}; + +const completeByAssessmentId = function (assessmentId, domainTransaction = DomainTransaction.emptyTransaction()) { + return this._updateStateById( + { id: assessmentId, state: Assessment.states.COMPLETED }, + domainTransaction.knexTransaction + ); +}; + +const endBySupervisorByAssessmentId = function (assessmentId) { + return this._updateStateById({ id: assessmentId, state: Assessment.states.ENDED_BY_SUPERVISOR }); +}; + +const getByCertificationCandidateId = async function (certificationCandidateId) { + const assessment = await knex('assessments') + .select('assessments.*') + .innerJoin('certification-courses', 'certification-courses.id', 'assessments.certificationCourseId') + .innerJoin('certification-candidates', function () { + this.on('certification-candidates.userId', 'certification-courses.userId').andOn( + 'certification-candidates.sessionId', + 'certification-courses.sessionId' ); - } catch (err) { - if (err instanceof BookshelfAssessment.NoRowsUpdatedError) { - return null; - } - throw err; + }) + .where({ 'certification-candidates.id': certificationCandidateId }) + .first(); + return new Assessment({ ...assessment }); +}; + +const ownedByUser = async function ({ id, userId = null }) { + const assessment = await knex('assessments').select('userId').where({ id }).first(); + + if (!assessment) { + return false; + } + + return assessment.userId === userId; +}; + +const _updateStateById = async function ({ id, state }, knexTransaction) { + const assessment = await BookshelfAssessment.where({ id }).save( + { state }, + { require: true, patch: true, transacting: knexTransaction } + ); + return bookshelfToDomainConverter.buildDomainObject(BookshelfAssessment, assessment); +}; + +const updateLastQuestionDate = async function ({ id, lastQuestionDate }) { + try { + await BookshelfAssessment.where({ id }).save( + { lastQuestionDate }, + { require: true, patch: true, method: 'update' } + ); + } catch (err) { + if (err instanceof BookshelfAssessment.NoRowsUpdatedError) { + return null; } - }, + throw err; + } +}; - async updateWhenNewChallengeIsAsked({ id, lastChallengeId }) { - try { - await BookshelfAssessment.where({ id }).save( - { lastChallengeId, lastQuestionState: Assessment.statesOfLastQuestion.ASKED }, - { require: true, patch: true, method: 'update' } - ); - } catch (err) { - if (err instanceof BookshelfAssessment.NoRowsUpdatedError) { - return null; - } - throw err; +const updateWhenNewChallengeIsAsked = async function ({ id, lastChallengeId }) { + try { + await BookshelfAssessment.where({ id }).save( + { lastChallengeId, lastQuestionState: Assessment.statesOfLastQuestion.ASKED }, + { require: true, patch: true, method: 'update' } + ); + } catch (err) { + if (err instanceof BookshelfAssessment.NoRowsUpdatedError) { + return null; } - }, + throw err; + } +}; - async updateLastQuestionState({ id, lastQuestionState, domainTransaction }) { - try { - await BookshelfAssessment.where({ id }).save( - { lastQuestionState }, - { require: true, patch: true, method: 'update', transacting: domainTransaction.knexTransaction } - ); - } catch (err) { - if (err instanceof BookshelfAssessment.NoRowsUpdatedError) { - return null; - } - throw err; +const updateLastQuestionState = async function ({ id, lastQuestionState, domainTransaction }) { + try { + await BookshelfAssessment.where({ id }).save( + { lastQuestionState }, + { require: true, patch: true, method: 'update', transacting: domainTransaction.knexTransaction } + ); + } catch (err) { + if (err instanceof BookshelfAssessment.NoRowsUpdatedError) { + return null; } - }, + throw err; + } +}; + +export { + getWithAnswers, + get, + findLastCompletedAssessmentsForEachCompetenceByUser, + getByAssessmentIdAndUserId, + save, + findNotAbortedCampaignAssessmentsByUserId, + abortByAssessmentId, + completeByAssessmentId, + endBySupervisorByAssessmentId, + getByCertificationCandidateId, + ownedByUser, + _updateStateById, + updateLastQuestionDate, + updateWhenNewChallengeIsAsked, + updateLastQuestionState, }; function _selectLastAssessmentForEachCompetence(bookshelfAssessments) { diff --git a/api/lib/infrastructure/repositories/assessment-result-repository.js b/api/lib/infrastructure/repositories/assessment-result-repository.js index 182a089e41f..dffd3df17c8 100644 --- a/api/lib/infrastructure/repositories/assessment-result-repository.js +++ b/api/lib/infrastructure/repositories/assessment-result-repository.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { MissingAssessmentId, AssessmentResultNotCreatedError } = require('../../domain/errors.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const AssessmentResult = require('../../domain/models/AssessmentResult.js'); -const CompetenceMark = require('../../domain/models/CompetenceMark.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { MissingAssessmentId, AssessmentResultNotCreatedError } from '../../domain/errors.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { AssessmentResult } from '../../domain/models/AssessmentResult.js'; +import { CompetenceMark } from '../../domain/models/CompetenceMark.js'; function _toDomain({ assessmentResultDTO, competencesMarksDTO }) { const competenceMarks = competencesMarksDTO.map((competenceMark) => new CompetenceMark(competenceMark)); @@ -25,102 +25,106 @@ function _toDomain({ assessmentResultDTO, competencesMarksDTO }) { }); } -module.exports = { - async save({ certificationCourseId, assessmentResult, domainTransaction = DomainTransaction.emptyTransaction() }) { - const { - pixScore, - reproducibilityRate, - status, - emitter, - commentForJury, - commentForCandidate, - commentForOrganization, - id, - juryId, - assessmentId, - } = assessmentResult; +const save = async function ({ + certificationCourseId, + assessmentResult, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const { + pixScore, + reproducibilityRate, + status, + emitter, + commentForJury, + commentForCandidate, + commentForOrganization, + id, + juryId, + assessmentId, + } = assessmentResult; - const knexConn = domainTransaction.knexTransaction || knex; - if (_.isNil(assessmentId)) { - throw new MissingAssessmentId(); - } - try { - const [savedAssessmentResultData] = await knexConn('assessment-results') - .insert({ - pixScore, - reproducibilityRate, - status, - emitter, - commentForJury, - commentForCandidate, - commentForOrganization, - id, - juryId, - assessmentId, - }) - .returning('*'); - - await knex('certification-courses-last-assessment-results') - .insert({ certificationCourseId, lastAssessmentResultId: savedAssessmentResultData.id }) - .onConflict('certificationCourseId') - .merge(['lastAssessmentResultId']); + const knexConn = domainTransaction.knexTransaction || knex; + if (_.isNil(assessmentId)) { + throw new MissingAssessmentId(); + } + try { + const [savedAssessmentResultData] = await knexConn('assessment-results') + .insert({ + pixScore, + reproducibilityRate, + status, + emitter, + commentForJury, + commentForCandidate, + commentForOrganization, + id, + juryId, + assessmentId, + }) + .returning('*'); - const savedAssessmentResult = new AssessmentResult({ - ...savedAssessmentResultData, - reproducibilityRate: _.toNumber(savedAssessmentResultData.reproducibilityRate) ?? null, - }); - return savedAssessmentResult; - } catch (error) { - throw new AssessmentResultNotCreatedError(); - } - }, + await knex('certification-courses-last-assessment-results') + .insert({ certificationCourseId, lastAssessmentResultId: savedAssessmentResultData.id }) + .onConflict('certificationCourseId') + .merge(['lastAssessmentResultId']); - async findLatestLevelAndPixScoreByAssessmentId({ assessmentId, limitDate }) { - const result = await knex('assessment-results') - .select('level', 'pixScore') - .where((qb) => { - qb.where({ assessmentId }); - if (limitDate) { - qb.where('createdAt', '<', limitDate); - } - }) - .orderBy('createdAt', 'desc') - .first(); + const savedAssessmentResult = new AssessmentResult({ + ...savedAssessmentResultData, + reproducibilityRate: _.toNumber(savedAssessmentResultData.reproducibilityRate) ?? null, + }); + return savedAssessmentResult; + } catch (error) { + throw new AssessmentResultNotCreatedError(); + } +}; - return { - level: _.get(result, 'level', 0), - pixScore: _.get(result, 'pixScore', 0), - }; - }, +const findLatestLevelAndPixScoreByAssessmentId = async function ({ assessmentId, limitDate }) { + const result = await knex('assessment-results') + .select('level', 'pixScore') + .where((qb) => { + qb.where({ assessmentId }); + if (limitDate) { + qb.where('createdAt', '<', limitDate); + } + }) + .orderBy('createdAt', 'desc') + .first(); - async getByCertificationCourseId({ certificationCourseId }) { - const assessment = await knex('assessments') - .select('id') - .where({ certificationCourseId }) - .orderBy('createdAt', 'desc') - .first(); + return { + level: _.get(result, 'level', 0), + pixScore: _.get(result, 'pixScore', 0), + }; +}; - if (assessment) { - const assessmentId = assessment.id; +const getByCertificationCourseId = async function ({ certificationCourseId }) { + const assessment = await knex('assessments') + .select('id') + .where({ certificationCourseId }) + .orderBy('createdAt', 'desc') + .first(); - const latestAssessmentResult = await knex('assessment-results') - .where({ assessmentId }) - .orderBy('createdAt', 'desc') - .first(); + if (assessment) { + const assessmentId = assessment.id; - if (latestAssessmentResult) { - const competencesMarksDTO = await knex('competence-marks').where({ - assessmentResultId: latestAssessmentResult.id, - }); + const latestAssessmentResult = await knex('assessment-results') + .where({ assessmentId }) + .orderBy('createdAt', 'desc') + .first(); - return _toDomain({ - assessmentResultDTO: latestAssessmentResult, - competencesMarksDTO, - }); - } + if (latestAssessmentResult) { + const competencesMarksDTO = await knex('competence-marks').where({ + assessmentResultId: latestAssessmentResult.id, + }); - return AssessmentResult.buildStartedAssessmentResult({ assessmentId }); + return _toDomain({ + assessmentResultDTO: latestAssessmentResult, + competencesMarksDTO, + }); } - return AssessmentResult.buildStartedAssessmentResult({ assessmentId: null }); - }, + + return AssessmentResult.buildStartedAssessmentResult({ assessmentId }); + } + return AssessmentResult.buildStartedAssessmentResult({ assessmentId: null }); }; + +export { save, findLatestLevelAndPixScoreByAssessmentId, getByCertificationCourseId }; diff --git a/api/lib/infrastructure/repositories/authentication-method-repository.js b/api/lib/infrastructure/repositories/authentication-method-repository.js index b157a70a41c..9bd5f818985 100644 --- a/api/lib/infrastructure/repositories/authentication-method-repository.js +++ b/api/lib/infrastructure/repositories/authentication-method-repository.js @@ -1,10 +1,10 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const bookshelfUtils = require('../utils/knex-utils.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const { AlreadyExistingEntityError, AuthenticationMethodNotFoundError } = require('../../domain/errors.js'); -const AuthenticationMethod = require('../../domain/models/AuthenticationMethod.js'); -const OidcIdentityProviders = require('../../domain/constants/oidc-identity-providers.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import * as knexUtils from '../utils/knex-utils.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { AlreadyExistingEntityError, AuthenticationMethodNotFoundError } from '../../domain/errors.js'; +import { AuthenticationMethod } from '../../domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../domain/constants/oidc-identity-providers.js'; function _toDomain(authenticationMethodDTO) { if (authenticationMethodDTO.identityProvider === AuthenticationMethod.identityProviders.PIX) { @@ -53,229 +53,256 @@ const COLUMNS = Object.freeze([ 'updatedAt', ]); -module.exports = { - async create({ authenticationMethod, domainTransaction = DomainTransaction.emptyTransaction() }) { - try { - const knexConn = domainTransaction.knexTransaction ?? knex; - const authenticationMethodForDB = _.pick(authenticationMethod, [ - 'identityProvider', - 'authenticationComplement', - 'externalIdentifier', - 'userId', - ]); - const [authenticationMethodDTO] = await knexConn(AUTHENTICATION_METHODS_TABLE) - .insert(authenticationMethodForDB) - .returning(COLUMNS); - return _toDomain(authenticationMethodDTO); - } catch (err) { - if (bookshelfUtils.isUniqConstraintViolated(err)) { - throw new AlreadyExistingEntityError( - `An authentication method already exists for the user ID ${authenticationMethod.userId} and the externalIdentifier ${authenticationMethod.externalIdentifier}.` - ); - } - - throw err; - } - }, - - async createPasswordThatShouldBeChanged({ - userId, - hashedPassword, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - try { - const authenticationComplement = new AuthenticationMethod.PixAuthenticationComplement({ - password: hashedPassword, - shouldChangePassword: true, - }); - const authenticationMethod = new AuthenticationMethod({ - authenticationComplement, - identityProvider: AuthenticationMethod.identityProviders.PIX, - userId, - }); - const authenticationMethodForDB = _.pick(authenticationMethod, [ - 'identityProvider', - 'authenticationComplement', - 'externalIdentifier', - 'userId', - ]); - const knexConn = domainTransaction.knexTransaction ?? knex; - const [authenticationMethodDTO] = await knexConn(AUTHENTICATION_METHODS_TABLE) - .insert(authenticationMethodForDB) - .returning(COLUMNS); - return _toDomain(authenticationMethodDTO); - } catch (err) { - if (bookshelfUtils.isUniqConstraintViolated(err)) { - throw new AlreadyExistingEntityError(`Authentication method PIX already exists for the user ID ${userId}.`); - } - } - }, - - async findOneByUserIdAndIdentityProvider({ userId, identityProvider }) { - const authenticationMethodDTO = await knex - .select(COLUMNS) - .from(AUTHENTICATION_METHODS_TABLE) - .where({ userId, identityProvider }) - .first(); - - return authenticationMethodDTO ? _toDomain(authenticationMethodDTO) : null; - }, - - async findOneByExternalIdentifierAndIdentityProvider({ externalIdentifier, identityProvider }) { - const authenticationMethodDTO = await knex - .select(COLUMNS) - .from(AUTHENTICATION_METHODS_TABLE) - .where({ externalIdentifier, identityProvider }) - .first(); - - return authenticationMethodDTO ? _toDomain(authenticationMethodDTO) : null; - }, - - async findByUserId({ userId }) { - const authenticationMethodDTOs = await knex - .select(COLUMNS) - .from(AUTHENTICATION_METHODS_TABLE) - .where({ userId }) - .orderBy('id', 'ASC'); - - return authenticationMethodDTOs.map(_toDomain); - }, - - async getByIdAndUserId({ id, userId }) { - const authenticationMethod = await knex.from(AUTHENTICATION_METHODS_TABLE).where({ id, userId }).first(); - if (!authenticationMethod) { - throw new AuthenticationMethodNotFoundError(`Authentication method of id ${id} and user id ${userId} not found.`); - } - return _toDomain(authenticationMethod); - }, - - async hasIdentityProviderPIX({ userId }) { - const authenticationMethodDTO = await knex - .select(COLUMNS) - .from(AUTHENTICATION_METHODS_TABLE) - .where({ - userId, - identityProvider: AuthenticationMethod.identityProviders.PIX, - }) - .first(); - - return Boolean(authenticationMethodDTO); - }, - - async removeByUserIdAndIdentityProvider({ userId, identityProvider }) { - return knex(AUTHENTICATION_METHODS_TABLE).where({ userId, identityProvider }).del(); - }, - - async removeAllAuthenticationMethodsByUserId({ userId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction.knexTransaction ?? knex; - return knexConn(AUTHENTICATION_METHODS_TABLE).where({ userId }).del(); - }, - - async updateChangedPassword({ userId, hashedPassword }, domainTransaction = DomainTransaction.emptyTransaction()) { - const authenticationComplement = new AuthenticationMethod.PixAuthenticationComplement({ - password: hashedPassword, - shouldChangePassword: false, - }); - +const create = async function ({ authenticationMethod, domainTransaction = DomainTransaction.emptyTransaction() }) { + try { const knexConn = domainTransaction.knexTransaction ?? knex; + const authenticationMethodForDB = _.pick(authenticationMethod, [ + 'identityProvider', + 'authenticationComplement', + 'externalIdentifier', + 'userId', + ]); const [authenticationMethodDTO] = await knexConn(AUTHENTICATION_METHODS_TABLE) - .where({ - userId, - identityProvider: AuthenticationMethod.identityProviders.PIX, - }) - .update({ authenticationComplement, updatedAt: new Date() }) + .insert(authenticationMethodForDB) .returning(COLUMNS); - - if (!authenticationMethodDTO) { - throw new AuthenticationMethodNotFoundError(`Authentication method PIX for User ID ${userId} not found.`); - } return _toDomain(authenticationMethodDTO); - }, + } catch (err) { + if (knexUtils.isUniqConstraintViolated(err)) { + throw new AlreadyExistingEntityError( + `An authentication method already exists for the user ID ${authenticationMethod.userId} and the externalIdentifier ${authenticationMethod.externalIdentifier}.` + ); + } - async updatePasswordThatShouldBeChanged({ - userId, - hashedPassword, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { + throw err; + } +}; + +const createPasswordThatShouldBeChanged = async function ({ + userId, + hashedPassword, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + try { const authenticationComplement = new AuthenticationMethod.PixAuthenticationComplement({ password: hashedPassword, shouldChangePassword: true, }); - + const authenticationMethod = new AuthenticationMethod({ + authenticationComplement, + identityProvider: AuthenticationMethod.identityProviders.PIX, + userId, + }); + const authenticationMethodForDB = _.pick(authenticationMethod, [ + 'identityProvider', + 'authenticationComplement', + 'externalIdentifier', + 'userId', + ]); const knexConn = domainTransaction.knexTransaction ?? knex; const [authenticationMethodDTO] = await knexConn(AUTHENTICATION_METHODS_TABLE) - .where({ - userId, - identityProvider: AuthenticationMethod.identityProviders.PIX, - }) - .update({ authenticationComplement, updatedAt: new Date() }) + .insert(authenticationMethodForDB) .returning(COLUMNS); - - if (!authenticationMethodDTO) { - throw new AuthenticationMethodNotFoundError(`Authentication method PIX for User ID ${userId} not found.`); - } return _toDomain(authenticationMethodDTO); - }, + } catch (err) { + if (knexUtils.isUniqConstraintViolated(err)) { + throw new AlreadyExistingEntityError(`Authentication method PIX already exists for the user ID ${userId}.`); + } + } +}; - async updateExpiredPassword({ userId, hashedPassword }) { - const authenticationComplement = new AuthenticationMethod.PixAuthenticationComplement({ - password: hashedPassword, - shouldChangePassword: false, - }); +const findOneByUserIdAndIdentityProvider = async function ({ userId, identityProvider }) { + const authenticationMethodDTO = await knex + .select(COLUMNS) + .from(AUTHENTICATION_METHODS_TABLE) + .where({ userId, identityProvider }) + .first(); - const [authenticationMethodDTO] = await knex(AUTHENTICATION_METHODS_TABLE) - .where({ - userId, - identityProvider: AuthenticationMethod.identityProviders.PIX, - }) - .update({ authenticationComplement, updatedAt: new Date() }) - .returning(COLUMNS); + return authenticationMethodDTO ? _toDomain(authenticationMethodDTO) : null; +}; - if (!authenticationMethodDTO) { - throw new AuthenticationMethodNotFoundError(`Authentication method PIX for User ID ${userId} not found.`); - } - return _toDomain(authenticationMethodDTO); - }, +const findOneByExternalIdentifierAndIdentityProvider = async function ({ externalIdentifier, identityProvider }) { + const authenticationMethodDTO = await knex + .select(COLUMNS) + .from(AUTHENTICATION_METHODS_TABLE) + .where({ externalIdentifier, identityProvider }) + .first(); - async updateExternalIdentifierByUserIdAndIdentityProvider({ externalIdentifier, userId, identityProvider }) { - const [authenticationMethodDTO] = await knex(AUTHENTICATION_METHODS_TABLE) - .where({ userId, identityProvider }) - .update({ externalIdentifier, updatedAt: new Date() }) - .returning(COLUMNS); + return authenticationMethodDTO ? _toDomain(authenticationMethodDTO) : null; +}; - if (!authenticationMethodDTO) { - throw new AuthenticationMethodNotFoundError( - `No rows updated for authentication method of type ${identityProvider} for user ${userId}.` - ); - } - return _toDomain(authenticationMethodDTO); - }, +const findByUserId = async function ({ userId }) { + const authenticationMethodDTOs = await knex + .select(COLUMNS) + .from(AUTHENTICATION_METHODS_TABLE) + .where({ userId }) + .orderBy('id', 'ASC'); - async updateAuthenticationComplementByUserIdAndIdentityProvider({ - authenticationComplement, - userId, - identityProvider, - }) { - const [authenticationMethodDTO] = await knex(AUTHENTICATION_METHODS_TABLE) - .where({ userId, identityProvider }) - .update({ authenticationComplement, updatedAt: new Date() }) - .returning(COLUMNS); + return authenticationMethodDTOs.map(_toDomain); +}; - if (!authenticationMethodDTO) { - throw new AuthenticationMethodNotFoundError( - `No rows updated for authentication method of type ${identityProvider} for user ${userId}.` - ); - } - return _toDomain(authenticationMethodDTO); - }, +const getByIdAndUserId = async function ({ id, userId }) { + const authenticationMethod = await knex.from(AUTHENTICATION_METHODS_TABLE).where({ id, userId }).first(); + if (!authenticationMethod) { + throw new AuthenticationMethodNotFoundError(`Authentication method of id ${id} and user id ${userId} not found.`); + } + return _toDomain(authenticationMethod); +}; + +const hasIdentityProviderPIX = async function ({ userId }) { + const authenticationMethodDTO = await knex + .select(COLUMNS) + .from(AUTHENTICATION_METHODS_TABLE) + .where({ + userId, + identityProvider: AuthenticationMethod.identityProviders.PIX, + }) + .first(); + + return Boolean(authenticationMethodDTO); +}; + +const removeByUserIdAndIdentityProvider = async function ({ userId, identityProvider }) { + return knex(AUTHENTICATION_METHODS_TABLE).where({ userId, identityProvider }).del(); +}; + +const removeAllAuthenticationMethodsByUserId = async function ({ + userId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction ?? knex; + return knexConn(AUTHENTICATION_METHODS_TABLE).where({ userId }).del(); +}; + +const updateChangedPassword = async function ( + { userId, hashedPassword }, + domainTransaction = DomainTransaction.emptyTransaction() +) { + const authenticationComplement = new AuthenticationMethod.PixAuthenticationComplement({ + password: hashedPassword, + shouldChangePassword: false, + }); + + const knexConn = domainTransaction.knexTransaction ?? knex; + const [authenticationMethodDTO] = await knexConn(AUTHENTICATION_METHODS_TABLE) + .where({ + userId, + identityProvider: AuthenticationMethod.identityProviders.PIX, + }) + .update({ authenticationComplement, updatedAt: new Date() }) + .returning(COLUMNS); + + if (!authenticationMethodDTO) { + throw new AuthenticationMethodNotFoundError(`Authentication method PIX for User ID ${userId} not found.`); + } + return _toDomain(authenticationMethodDTO); +}; + +const updatePasswordThatShouldBeChanged = async function ({ + userId, + hashedPassword, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const authenticationComplement = new AuthenticationMethod.PixAuthenticationComplement({ + password: hashedPassword, + shouldChangePassword: true, + }); - async updateAuthenticationMethodUserId({ originUserId, identityProvider, targetUserId }) { - await knex(AUTHENTICATION_METHODS_TABLE) - .where({ userId: originUserId, identityProvider }) - .update({ userId: targetUserId, updatedAt: new Date() }); - }, + const knexConn = domainTransaction.knexTransaction ?? knex; + const [authenticationMethodDTO] = await knexConn(AUTHENTICATION_METHODS_TABLE) + .where({ + userId, + identityProvider: AuthenticationMethod.identityProviders.PIX, + }) + .update({ authenticationComplement, updatedAt: new Date() }) + .returning(COLUMNS); + + if (!authenticationMethodDTO) { + throw new AuthenticationMethodNotFoundError(`Authentication method PIX for User ID ${userId} not found.`); + } + return _toDomain(authenticationMethodDTO); +}; + +const updateExpiredPassword = async function ({ userId, hashedPassword }) { + const authenticationComplement = new AuthenticationMethod.PixAuthenticationComplement({ + password: hashedPassword, + shouldChangePassword: false, + }); + + const [authenticationMethodDTO] = await knex(AUTHENTICATION_METHODS_TABLE) + .where({ + userId, + identityProvider: AuthenticationMethod.identityProviders.PIX, + }) + .update({ authenticationComplement, updatedAt: new Date() }) + .returning(COLUMNS); + + if (!authenticationMethodDTO) { + throw new AuthenticationMethodNotFoundError(`Authentication method PIX for User ID ${userId} not found.`); + } + return _toDomain(authenticationMethodDTO); +}; + +const updateExternalIdentifierByUserIdAndIdentityProvider = async function ({ + externalIdentifier, + userId, + identityProvider, +}) { + const [authenticationMethodDTO] = await knex(AUTHENTICATION_METHODS_TABLE) + .where({ userId, identityProvider }) + .update({ externalIdentifier, updatedAt: new Date() }) + .returning(COLUMNS); + + if (!authenticationMethodDTO) { + throw new AuthenticationMethodNotFoundError( + `No rows updated for authentication method of type ${identityProvider} for user ${userId}.` + ); + } + return _toDomain(authenticationMethodDTO); +}; + +const updateAuthenticationComplementByUserIdAndIdentityProvider = async function ({ + authenticationComplement, + userId, + identityProvider, +}) { + const [authenticationMethodDTO] = await knex(AUTHENTICATION_METHODS_TABLE) + .where({ userId, identityProvider }) + .update({ authenticationComplement, updatedAt: new Date() }) + .returning(COLUMNS); + + if (!authenticationMethodDTO) { + throw new AuthenticationMethodNotFoundError( + `No rows updated for authentication method of type ${identityProvider} for user ${userId}.` + ); + } + return _toDomain(authenticationMethodDTO); +}; + +const updateAuthenticationMethodUserId = async function ({ originUserId, identityProvider, targetUserId }) { + await knex(AUTHENTICATION_METHODS_TABLE) + .where({ userId: originUserId, identityProvider }) + .update({ userId: targetUserId, updatedAt: new Date() }); +}; + +const update = async function ({ id, authenticationComplement }) { + await knex(AUTHENTICATION_METHODS_TABLE).where({ id }).update({ authenticationComplement, updatedAt: new Date() }); +}; - async update({ id, authenticationComplement }) { - await knex(AUTHENTICATION_METHODS_TABLE).where({ id }).update({ authenticationComplement, updatedAt: new Date() }); - }, +export { + create, + createPasswordThatShouldBeChanged, + findOneByUserIdAndIdentityProvider, + findOneByExternalIdentifierAndIdentityProvider, + findByUserId, + getByIdAndUserId, + hasIdentityProviderPIX, + removeByUserIdAndIdentityProvider, + removeAllAuthenticationMethodsByUserId, + updateChangedPassword, + updatePasswordThatShouldBeChanged, + updateExpiredPassword, + updateExternalIdentifierByUserIdAndIdentityProvider, + updateAuthenticationComplementByUserIdAndIdentityProvider, + updateAuthenticationMethodUserId, + update, }; diff --git a/api/lib/infrastructure/repositories/badge-acquisition-repository.js b/api/lib/infrastructure/repositories/badge-acquisition-repository.js index ac0fddc9ca2..5bef6ed06eb 100644 --- a/api/lib/infrastructure/repositories/badge-acquisition-repository.js +++ b/api/lib/infrastructure/repositories/badge-acquisition-repository.js @@ -1,52 +1,59 @@ -const bluebird = require('bluebird'); -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import bluebird from 'bluebird'; +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; const BADGE_ACQUISITIONS_TABLE = 'badge-acquisitions'; -module.exports = { - async createOrUpdate({ badgeAcquisitionsToCreate = [], domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction.knexTransaction || knex; - return bluebird.mapSeries(badgeAcquisitionsToCreate, async ({ badgeId, userId, campaignParticipationId }) => { - const alreadyCreatedBadgeAcquisition = await knexConn(BADGE_ACQUISITIONS_TABLE) - .select('id') - .where({ badgeId, userId, campaignParticipationId }); - if (alreadyCreatedBadgeAcquisition.length === 0) { - return knexConn(BADGE_ACQUISITIONS_TABLE).insert(badgeAcquisitionsToCreate); - } else { - return knexConn(BADGE_ACQUISITIONS_TABLE) - .update({ updatedAt: knex.raw('CURRENT_TIMESTAMP') }) - .where({ userId, badgeId, campaignParticipationId }); - } - }); - }, +const createOrUpdate = async function ({ + badgeAcquisitionsToCreate = [], + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction || knex; + return bluebird.mapSeries(badgeAcquisitionsToCreate, async ({ badgeId, userId, campaignParticipationId }) => { + const alreadyCreatedBadgeAcquisition = await knexConn(BADGE_ACQUISITIONS_TABLE) + .select('id') + .where({ badgeId, userId, campaignParticipationId }); + if (alreadyCreatedBadgeAcquisition.length === 0) { + return knexConn(BADGE_ACQUISITIONS_TABLE).insert(badgeAcquisitionsToCreate); + } else { + return knexConn(BADGE_ACQUISITIONS_TABLE) + .update({ updatedAt: knex.raw('CURRENT_TIMESTAMP') }) + .where({ userId, badgeId, campaignParticipationId }); + } + }); +}; - async getAcquiredBadgeIds({ badgeIds, userId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction.knexTransaction || knex; - return knexConn(BADGE_ACQUISITIONS_TABLE).pluck('badgeId').where({ userId }).whereIn('badgeId', badgeIds); - }, +const getAcquiredBadgeIds = async function ({ + badgeIds, + userId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction || knex; + return knexConn(BADGE_ACQUISITIONS_TABLE).pluck('badgeId').where({ userId }).whereIn('badgeId', badgeIds); +}; - async getAcquiredBadgesByCampaignParticipations({ - campaignParticipationsIds, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knexConn = domainTransaction.knexTransaction || knex; - const badges = await knexConn('badges') - .distinct('badges.id') - .select('badge-acquisitions.campaignParticipationId AS campaignParticipationId', 'badges.*') - .from('badges') - .join(BADGE_ACQUISITIONS_TABLE, 'badges.id', 'badge-acquisitions.badgeId') - .where('badge-acquisitions.campaignParticipationId', 'IN', campaignParticipationsIds) - .orderBy('badges.id'); +const getAcquiredBadgesByCampaignParticipations = async function ({ + campaignParticipationsIds, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction || knex; + const badges = await knexConn('badges') + .distinct('badges.id') + .select('badge-acquisitions.campaignParticipationId AS campaignParticipationId', 'badges.*') + .from('badges') + .join(BADGE_ACQUISITIONS_TABLE, 'badges.id', 'badge-acquisitions.badgeId') + .where('badge-acquisitions.campaignParticipationId', 'IN', campaignParticipationsIds) + .orderBy('badges.id'); - const acquiredBadgesByCampaignParticipations = {}; - for (const badge of badges) { - if (acquiredBadgesByCampaignParticipations[badge.campaignParticipationId]) { - acquiredBadgesByCampaignParticipations[badge.campaignParticipationId].push(badge); - } else { - acquiredBadgesByCampaignParticipations[badge.campaignParticipationId] = [badge]; - } + const acquiredBadgesByCampaignParticipations = {}; + for (const badge of badges) { + if (acquiredBadgesByCampaignParticipations[badge.campaignParticipationId]) { + acquiredBadgesByCampaignParticipations[badge.campaignParticipationId].push(badge); + } else { + acquiredBadgesByCampaignParticipations[badge.campaignParticipationId] = [badge]; } - return acquiredBadgesByCampaignParticipations; - }, + } + return acquiredBadgesByCampaignParticipations; }; + +export { createOrUpdate, getAcquiredBadgeIds, getAcquiredBadgesByCampaignParticipations }; diff --git a/api/lib/infrastructure/repositories/badge-criteria-repository.js b/api/lib/infrastructure/repositories/badge-criteria-repository.js index 4d1cd2d2044..640ccd2d2ce 100644 --- a/api/lib/infrastructure/repositories/badge-criteria-repository.js +++ b/api/lib/infrastructure/repositories/badge-criteria-repository.js @@ -1,17 +1,17 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const BadgeCriterion = require('../../../lib/domain/models/BadgeCriterion.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { BadgeCriterion } from '../../../lib/domain/models/BadgeCriterion.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; const TABLE_NAME = 'badge-criteria'; -module.exports = { - async save({ badgeCriterion }, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const data = { - ...badgeCriterion, - // WORKAROUND: jsonb array needs to be stringified see https://knexjs.org/guide/schema-builder.html#json - cappedTubes: badgeCriterion.cappedTubes ? JSON.stringify(badgeCriterion.cappedTubes) : null, - }; - const savedBadgeCriterion = await (knexTransaction ?? knex)(TABLE_NAME).insert(data).returning('*'); - return new BadgeCriterion(savedBadgeCriterion[0]); - }, +const save = async function ({ badgeCriterion }, { knexTransaction } = DomainTransaction.emptyTransaction()) { + const data = { + ...badgeCriterion, + // WORKAROUND: jsonb array needs to be stringified see https://knexjs.org/guide/schema-builder.html#json + cappedTubes: badgeCriterion.cappedTubes ? JSON.stringify(badgeCriterion.cappedTubes) : null, + }; + const savedBadgeCriterion = await (knexTransaction ?? knex)(TABLE_NAME).insert(data).returning('*'); + return new BadgeCriterion(savedBadgeCriterion[0]); }; + +export { save }; diff --git a/api/lib/infrastructure/repositories/badge-for-calculation-repository.js b/api/lib/infrastructure/repositories/badge-for-calculation-repository.js index e532788d0db..75eb82d5bbf 100644 --- a/api/lib/infrastructure/repositories/badge-for-calculation-repository.js +++ b/api/lib/infrastructure/repositories/badge-for-calculation-repository.js @@ -1,121 +1,121 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { BadgeForCalculation, BadgeCriterion } = require('../../domain/models/BadgeForCalculation.js'); -const { SCOPES } = require('../../domain/models/BadgeCriterion.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); -const campaignRepository = require('./campaign-repository.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { BadgeForCalculation, BadgeCriterion } from '../../domain/models/BadgeForCalculation.js'; +import { SCOPES } from '../../domain/models/BadgeCriterion.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import * as campaignRepository from './campaign-repository.js'; -module.exports = { - async findByCampaignParticipationId({ - campaignParticipationId, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knexConn = domainTransaction?.knexTransaction || knex; - const badgesDTO = await knexConn('badges') - .select('badges.id') - .join('target-profiles', 'target-profiles.id', 'badges.targetProfileId') - .join('campaigns', 'campaigns.targetProfileId', 'target-profiles.id') - .join('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') - .where('campaign-participations.id', campaignParticipationId) - .orderBy('badges.id'); +const findByCampaignParticipationId = async function ({ + campaignParticipationId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction?.knexTransaction || knex; + const badgesDTO = await knexConn('badges') + .select('badges.id') + .join('target-profiles', 'target-profiles.id', 'badges.targetProfileId') + .join('campaigns', 'campaigns.targetProfileId', 'target-profiles.id') + .join('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') + .where('campaign-participations.id', campaignParticipationId) + .orderBy('badges.id'); - const badgeIds = badgesDTO.map(({ id }) => id); - const badgeCriteriaDTO = await knexConn('badge-criteria') - .select(['id', 'threshold', 'badgeId', 'scope', 'cappedTubes', 'skillSetIds']) - .whereIn('badgeId', badgeIds) - .orderBy('badge-criteria.id'); - const badgeCriteriaDTOByBadge = _.groupBy(badgeCriteriaDTO, 'badgeId'); + const badgeIds = badgesDTO.map(({ id }) => id); + const badgeCriteriaDTO = await knexConn('badge-criteria') + .select(['id', 'threshold', 'badgeId', 'scope', 'cappedTubes', 'skillSetIds']) + .whereIn('badgeId', badgeIds) + .orderBy('badge-criteria.id'); + const badgeCriteriaDTOByBadge = _.groupBy(badgeCriteriaDTO, 'badgeId'); - const campaignSkills = await campaignRepository.findSkillsByCampaignParticipationId({ - campaignParticipationId, - domainTransaction, - }); - const campaignSkillIds = campaignSkills.map(({ id }) => id); - const campaignSkillsByTube = _.groupBy(campaignSkills, 'tubeId'); + const campaignSkills = await campaignRepository.findSkillsByCampaignParticipationId({ + campaignParticipationId, + domainTransaction, + }); + const campaignSkillIds = campaignSkills.map(({ id }) => id); + const campaignSkillsByTube = _.groupBy(campaignSkills, 'tubeId'); - const badges = []; - for (const badgeDTO of badgesDTO) { - const badge = await _buildBadge( - knexConn, - campaignSkillsByTube, - campaignSkillIds, - badgeCriteriaDTOByBadge[badgeDTO.id], - badgeDTO - ); - badges.push(badge); - } - return _.compact(badges); - }, + const badges = []; + for (const badgeDTO of badgesDTO) { + const badge = await _buildBadge( + knexConn, + campaignSkillsByTube, + campaignSkillIds, + badgeCriteriaDTOByBadge[badgeDTO.id], + badgeDTO + ); + badges.push(badge); + } + return _.compact(badges); +}; - async findByCampaignId({ campaignId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction?.knexTransaction || knex; - const badgesDTO = await knexConn('badges') - .select('badges.id') - .join('target-profiles', 'target-profiles.id', 'badges.targetProfileId') - .join('campaigns', 'campaigns.targetProfileId', 'target-profiles.id') - .where('campaigns.id', campaignId) - .orderBy('badges.id'); +const findByCampaignId = async function ({ campaignId, domainTransaction = DomainTransaction.emptyTransaction() }) { + const knexConn = domainTransaction?.knexTransaction || knex; + const badgesDTO = await knexConn('badges') + .select('badges.id') + .join('target-profiles', 'target-profiles.id', 'badges.targetProfileId') + .join('campaigns', 'campaigns.targetProfileId', 'target-profiles.id') + .where('campaigns.id', campaignId) + .orderBy('badges.id'); - const badgeIds = badgesDTO.map(({ id }) => id); - const badgeCriteriaDTO = await knexConn('badge-criteria') - .select(['id', 'threshold', 'badgeId', 'scope', 'cappedTubes', 'skillSetIds']) - .whereIn('badgeId', badgeIds) - .orderBy('badge-criteria.id'); - const badgeCriteriaDTOByBadge = _.groupBy(badgeCriteriaDTO, 'badgeId'); + const badgeIds = badgesDTO.map(({ id }) => id); + const badgeCriteriaDTO = await knexConn('badge-criteria') + .select(['id', 'threshold', 'badgeId', 'scope', 'cappedTubes', 'skillSetIds']) + .whereIn('badgeId', badgeIds) + .orderBy('badge-criteria.id'); + const badgeCriteriaDTOByBadge = _.groupBy(badgeCriteriaDTO, 'badgeId'); - const campaignSkills = await campaignRepository.findSkills({ - campaignId, - domainTransaction, - }); - const campaignSkillIds = campaignSkills.map(({ id }) => id); - const campaignSkillsByTube = _.groupBy(campaignSkills, 'tubeId'); + const campaignSkills = await campaignRepository.findSkills({ + campaignId, + domainTransaction, + }); + const campaignSkillIds = campaignSkills.map(({ id }) => id); + const campaignSkillsByTube = _.groupBy(campaignSkills, 'tubeId'); - const badges = []; - for (const badgeDTO of badgesDTO) { - const badge = await _buildBadge( - knexConn, - campaignSkillsByTube, - campaignSkillIds, - badgeCriteriaDTOByBadge[badgeDTO.id], - badgeDTO - ); - badges.push(badge); - } - return _.compact(badges); - }, + const badges = []; + for (const badgeDTO of badgesDTO) { + const badge = await _buildBadge( + knexConn, + campaignSkillsByTube, + campaignSkillIds, + badgeCriteriaDTOByBadge[badgeDTO.id], + badgeDTO + ); + badges.push(badge); + } + return _.compact(badges); +}; - async getByCertifiableBadgeAcquisition({ - certifiableBadgeAcquisition, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const badgeId = certifiableBadgeAcquisition.badgeId; - const campaignId = certifiableBadgeAcquisition.campaignId; - const knexConn = domainTransaction?.knexTransaction || knex; - const badgeDTO = await knexConn('badges') - .select('badges.id') - .join('target-profiles', 'target-profiles.id', 'badges.targetProfileId') - .join('campaigns', 'campaigns.targetProfileId', 'target-profiles.id') - .where('campaigns.id', campaignId) - .where('badges.id', badgeId) - .first(); - if (!badgeDTO) return null; +const getByCertifiableBadgeAcquisition = async function ({ + certifiableBadgeAcquisition, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const badgeId = certifiableBadgeAcquisition.badgeId; + const campaignId = certifiableBadgeAcquisition.campaignId; + const knexConn = domainTransaction?.knexTransaction || knex; + const badgeDTO = await knexConn('badges') + .select('badges.id') + .join('target-profiles', 'target-profiles.id', 'badges.targetProfileId') + .join('campaigns', 'campaigns.targetProfileId', 'target-profiles.id') + .where('campaigns.id', campaignId) + .where('badges.id', badgeId) + .first(); + if (!badgeDTO) return null; - const badgeCriteriaDTO = await knexConn('badge-criteria') - .select(['id', 'threshold', 'badgeId', 'scope', 'cappedTubes', 'skillSetIds']) - .where('badgeId', badgeDTO.id) - .orderBy('badge-criteria.id'); + const badgeCriteriaDTO = await knexConn('badge-criteria') + .select(['id', 'threshold', 'badgeId', 'scope', 'cappedTubes', 'skillSetIds']) + .where('badgeId', badgeDTO.id) + .orderBy('badge-criteria.id'); - const campaignSkills = await campaignRepository.findSkills({ - campaignId, - domainTransaction, - }); - const campaignSkillIds = campaignSkills.map(({ id }) => id); - const campaignSkillsByTube = _.groupBy(campaignSkills, 'tubeId'); + const campaignSkills = await campaignRepository.findSkills({ + campaignId, + domainTransaction, + }); + const campaignSkillIds = campaignSkills.map(({ id }) => id); + const campaignSkillsByTube = _.groupBy(campaignSkills, 'tubeId'); - return _buildBadge(knexConn, campaignSkillsByTube, campaignSkillIds, badgeCriteriaDTO, badgeDTO); - }, + return _buildBadge(knexConn, campaignSkillsByTube, campaignSkillIds, badgeCriteriaDTO, badgeDTO); }; +export { findByCampaignParticipationId, findByCampaignId, getByCertifiableBadgeAcquisition }; + async function _buildBadge(knex, campaignSkillsByTube, campaignSkillIds, badgeCriteriaDTO, badgeDTO) { const badgeCriteria = []; for (const badgeCriterionDTO of badgeCriteriaDTO) { diff --git a/api/lib/infrastructure/repositories/badge-repository.js b/api/lib/infrastructure/repositories/badge-repository.js index 97730ee2dbc..08480a4d774 100644 --- a/api/lib/infrastructure/repositories/badge-repository.js +++ b/api/lib/infrastructure/repositories/badge-repository.js @@ -1,87 +1,100 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const Badge = require('../../domain/models/Badge.js'); -const SkillSet = require('../../domain/models/SkillSet.js'); -const BadgeCriterion = require('../../domain/models/BadgeCriterion.js'); -const omit = require('lodash/omit'); -const knexUtils = require('../utils/knex-utils.js'); -const { AlreadyExistingEntityError } = require('../../domain/errors.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { Badge } from '../../domain/models/Badge.js'; +import { SkillSet } from '../../domain/models/SkillSet.js'; +import { BadgeCriterion } from '../../domain/models/BadgeCriterion.js'; +import lodash from 'lodash'; + +const { omit } = lodash; + +import * as knexUtils from '../utils/knex-utils.js'; +import { AlreadyExistingEntityError } from '../../domain/errors.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; const TABLE_NAME = 'badges'; -module.exports = { - async findByCampaignId(campaignId) { - const badges = await knex(TABLE_NAME) - .select(`${TABLE_NAME}.*`) - .join('target-profiles', 'target-profiles.id', `${TABLE_NAME}.targetProfileId`) - .join('campaigns', 'campaigns.targetProfileId', 'target-profiles.id') - .where('campaigns.id', campaignId); - - return Promise.all( - badges.map(async (badge) => { - const { badgeCriteria, skillSets } = await _addCriteriaInformation(badge); - return new Badge({ ...badge, badgeCriteria, skillSets }); - }) - ); - }, - - async isAssociated(badgeId, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const associatedBadge = await (knexTransaction ?? knex)('badge-acquisitions').where({ badgeId }).first(); - return !!associatedBadge; - }, - - async isRelatedToCertification(badgeId, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const complementaryCertificationBadge = await (knexTransaction ?? knex)('complementary-certification-badges') - .where({ badgeId }) - .first(); - return !!complementaryCertificationBadge; - }, - - async get(id) { - const badge = await knex(TABLE_NAME).select('*').where({ id }).first(); - const { badgeCriteria, skillSets } = await _addCriteriaInformation(badge); - return new Badge({ ...badge, badgeCriteria, skillSets }); - }, - - async getByKey(key) { - const badge = await knex(TABLE_NAME).select('*').where({ key }).first(); - const { badgeCriteria, skillSets } = await _addCriteriaInformation(badge); - return new Badge({ ...badge, badgeCriteria, skillSets }); - }, - - async save(badge, { knexTransaction } = DomainTransaction.emptyTransaction()) { - try { - const [savedBadge] = await (knexTransaction ?? knex)(TABLE_NAME).insert(_adaptModelToDb(badge)).returning('*'); - return new Badge(savedBadge); - } catch (err) { - if (knexUtils.isUniqConstraintViolated(err)) { - throw new AlreadyExistingEntityError(`The badge key ${badge.key} already exists`); - } - throw err; - } - }, +const findByCampaignId = async function (campaignId) { + const badges = await knex(TABLE_NAME) + .select(`${TABLE_NAME}.*`) + .join('target-profiles', 'target-profiles.id', `${TABLE_NAME}.targetProfileId`) + .join('campaigns', 'campaigns.targetProfileId', 'target-profiles.id') + .where('campaigns.id', campaignId); + + return Promise.all( + badges.map(async (badge) => { + const { badgeCriteria, skillSets } = await _addCriteriaInformation(badge); + return new Badge({ ...badge, badgeCriteria, skillSets }); + }) + ); +}; - async update(badge) { - const [updatedBadge] = await knex(TABLE_NAME).update(_adaptModelToDb(badge)).where({ id: badge.id }).returning('*'); - return new Badge({ ...badge, ...updatedBadge }); - }, +const isAssociated = async function (badgeId, { knexTransaction } = DomainTransaction.emptyTransaction()) { + const associatedBadge = await (knexTransaction ?? knex)('badge-acquisitions').where({ badgeId }).first(); + return !!associatedBadge; +}; + +const isRelatedToCertification = async function (badgeId, { knexTransaction } = DomainTransaction.emptyTransaction()) { + const complementaryCertificationBadge = await (knexTransaction ?? knex)('complementary-certification-badges') + .where({ badgeId }) + .first(); + return !!complementaryCertificationBadge; +}; + +const get = async function (id) { + const badge = await knex(TABLE_NAME).select('*').where({ id }).first(); + const { badgeCriteria, skillSets } = await _addCriteriaInformation(badge); + return new Badge({ ...badge, badgeCriteria, skillSets }); +}; - async isKeyAvailable(key, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const result = await (knexTransaction ?? knex)(TABLE_NAME).select('key').where('key', key); - if (result.length) { - throw new AlreadyExistingEntityError(`The badge key ${key} already exists`); +const getByKey = async function (key) { + const badge = await knex(TABLE_NAME).select('*').where({ key }).first(); + const { badgeCriteria, skillSets } = await _addCriteriaInformation(badge); + return new Badge({ ...badge, badgeCriteria, skillSets }); +}; + +const save = async function (badge, { knexTransaction } = DomainTransaction.emptyTransaction()) { + try { + const [savedBadge] = await (knexTransaction ?? knex)(TABLE_NAME).insert(_adaptModelToDb(badge)).returning('*'); + return new Badge(savedBadge); + } catch (err) { + if (knexUtils.isUniqConstraintViolated(err)) { + throw new AlreadyExistingEntityError(`The badge key ${badge.key} already exists`); } - return true; - }, + throw err; + } +}; + +const update = async function (badge) { + const [updatedBadge] = await knex(TABLE_NAME).update(_adaptModelToDb(badge)).where({ id: badge.id }).returning('*'); + return new Badge({ ...badge, ...updatedBadge }); +}; - async delete(badgeId, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const knexConn = knexTransaction ?? knex; - await knexConn('badge-criteria').where({ badgeId }).del(); - await knexConn('skill-sets').where({ badgeId }).del(); - await knexConn('badges').where({ id: badgeId }).del(); +const isKeyAvailable = async function (key, { knexTransaction } = DomainTransaction.emptyTransaction()) { + const result = await (knexTransaction ?? knex)(TABLE_NAME).select('key').where('key', key); + if (result.length) { + throw new AlreadyExistingEntityError(`The badge key ${key} already exists`); + } + return true; +}; + +const remove = async function (badgeId, { knexTransaction } = DomainTransaction.emptyTransaction()) { + const knexConn = knexTransaction ?? knex; + await knexConn('badge-criteria').where({ badgeId }).del(); + await knexConn('skill-sets').where({ badgeId }).del(); + await knexConn('badges').where({ id: badgeId }).del(); + + return true; +}; - return true; - }, +export { + findByCampaignId, + isAssociated, + isRelatedToCertification, + get, + getByKey, + save, + update, + isKeyAvailable, + remove, }; async function _addCriteriaInformation(badge) { diff --git a/api/lib/infrastructure/repositories/campaign-analysis-repository.js b/api/lib/infrastructure/repositories/campaign-analysis-repository.js index f922d1e3319..1e5b31fc9ca 100644 --- a/api/lib/infrastructure/repositories/campaign-analysis-repository.js +++ b/api/lib/infrastructure/repositories/campaign-analysis-repository.js @@ -1,56 +1,61 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { knex } = require('../../../db/knex-database-connection.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); -const CampaignAnalysis = require('../../domain/read-models/CampaignAnalysis.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); -const { constants } = require('../constants.js'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import { knex } from '../../../db/knex-database-connection.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; +import { CampaignAnalysis } from '../../domain/read-models/CampaignAnalysis.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; +import { constants } from '../constants.js'; const { SHARED } = CampaignParticipationStatuses; -module.exports = { - async getCampaignAnalysis(campaignId, campaignLearningContent, tutorials) { - const userIdsAndSharedDates = await _getSharedParticipationsWithUserIdsAndDates(campaignId); - const userIdsAndSharedDatesChunks = _.chunk(userIdsAndSharedDates, constants.CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING); - const participantCount = userIdsAndSharedDates.length; +const getCampaignAnalysis = async function (campaignId, campaignLearningContent, tutorials) { + const userIdsAndSharedDates = await _getSharedParticipationsWithUserIdsAndDates(campaignId); + const userIdsAndSharedDatesChunks = _.chunk(userIdsAndSharedDates, constants.CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING); + const participantCount = userIdsAndSharedDates.length; - const campaignAnalysis = new CampaignAnalysis({ - campaignId, - campaignLearningContent, - tutorials, - participantCount, - }); - - await bluebird.mapSeries(userIdsAndSharedDatesChunks, async (userIdsAndSharedDates) => { - const knowledgeElementsByTube = await knowledgeElementRepository.findValidatedGroupedByTubesWithinCampaign( - Object.fromEntries(userIdsAndSharedDates), - campaignLearningContent - ); - campaignAnalysis.addToTubeRecommendations({ knowledgeElementsByTube }); - }); - campaignAnalysis.finalize(); - return campaignAnalysis; - }, - - async getCampaignParticipationAnalysis(campaignId, campaignParticipation, campaignLearningContent, tutorials) { - const campaignAnalysis = new CampaignAnalysis({ - campaignId, - campaignLearningContent, - tutorials, - participantCount: 1, - }); + const campaignAnalysis = new CampaignAnalysis({ + campaignId, + campaignLearningContent, + tutorials, + participantCount, + }); + await bluebird.mapSeries(userIdsAndSharedDatesChunks, async (userIdsAndSharedDates) => { const knowledgeElementsByTube = await knowledgeElementRepository.findValidatedGroupedByTubesWithinCampaign( - { [campaignParticipation.userId]: campaignParticipation.sharedAt }, + Object.fromEntries(userIdsAndSharedDates), campaignLearningContent ); campaignAnalysis.addToTubeRecommendations({ knowledgeElementsByTube }); + }); + campaignAnalysis.finalize(); + return campaignAnalysis; +}; - campaignAnalysis.finalize(1); - return campaignAnalysis; - }, +const getCampaignParticipationAnalysis = async function ( + campaignId, + campaignParticipation, + campaignLearningContent, + tutorials +) { + const campaignAnalysis = new CampaignAnalysis({ + campaignId, + campaignLearningContent, + tutorials, + participantCount: 1, + }); + + const knowledgeElementsByTube = await knowledgeElementRepository.findValidatedGroupedByTubesWithinCampaign( + { [campaignParticipation.userId]: campaignParticipation.sharedAt }, + campaignLearningContent + ); + campaignAnalysis.addToTubeRecommendations({ knowledgeElementsByTube }); + + campaignAnalysis.finalize(1); + return campaignAnalysis; }; +export { getCampaignAnalysis, getCampaignParticipationAnalysis }; + async function _getSharedParticipationsWithUserIdsAndDates(campaignId) { const results = await knex('campaign-participations') .select('userId', 'sharedAt') diff --git a/api/lib/infrastructure/repositories/campaign-assessment-participation-repository.js b/api/lib/infrastructure/repositories/campaign-assessment-participation-repository.js index 94202bd0974..a19e12c77a1 100644 --- a/api/lib/infrastructure/repositories/campaign-assessment-participation-repository.js +++ b/api/lib/infrastructure/repositories/campaign-assessment-participation-repository.js @@ -1,23 +1,20 @@ -const _ = require('lodash'); -const { NotFoundError } = require('../../../lib/domain/errors.js'); -const CampaignAssessmentParticipation = require('../../../lib/domain/read-models/CampaignAssessmentParticipation.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); -const campaignRepository = require('./campaign-repository.js'); - -const Assessment = require('../../../lib/domain/models/Assessment.js'); - -module.exports = { - async getByCampaignIdAndCampaignParticipationId({ campaignId, campaignParticipationId }) { - const result = await _fetchCampaignAssessmentAttributesFromCampaignParticipation( - campaignId, - campaignParticipationId - ); - - return _buildCampaignAssessmentParticipation(result); - }, +import _ from 'lodash'; +import { NotFoundError } from '../../../lib/domain/errors.js'; +import { CampaignAssessmentParticipation } from '../../../lib/domain/read-models/CampaignAssessmentParticipation.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; +import * as campaignRepository from './campaign-repository.js'; + +import { Assessment } from '../../../lib/domain/models/Assessment.js'; + +const getByCampaignIdAndCampaignParticipationId = async function ({ campaignId, campaignParticipationId }) { + const result = await _fetchCampaignAssessmentAttributesFromCampaignParticipation(campaignId, campaignParticipationId); + + return _buildCampaignAssessmentParticipation(result); }; +export { getByCampaignIdAndCampaignParticipationId }; + async function _fetchCampaignAssessmentAttributesFromCampaignParticipation(campaignId, campaignParticipationId) { const [campaignAssessmentParticipation] = await knex .with('campaignAssessmentParticipation', (qb) => { diff --git a/api/lib/infrastructure/repositories/campaign-assessment-participation-result-list-repository.js b/api/lib/infrastructure/repositories/campaign-assessment-participation-result-list-repository.js index ba7a94eb652..b95be5c4d12 100644 --- a/api/lib/infrastructure/repositories/campaign-assessment-participation-result-list-repository.js +++ b/api/lib/infrastructure/repositories/campaign-assessment-participation-result-list-repository.js @@ -1,9 +1,9 @@ -const bluebird = require('bluebird'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const stageCollectionRepository = require('./user-campaign-results/stage-collection-repository'); -const CampaignAssessmentParticipationResultMinimal = require('../../domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); +import bluebird from 'bluebird'; +import { knex } from '../../../db/knex-database-connection.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import * as stageCollectionRepository from './user-campaign-results/stage-collection-repository.js'; +import { CampaignAssessmentParticipationResultMinimal } from '../../domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; @@ -157,6 +157,4 @@ async function getAcquiredBadges(campaignParticipationId) { .where({ campaignParticipationId: campaignParticipationId }); } -module.exports = { - findPaginatedByCampaignId, -}; +export { findPaginatedByCampaignId }; diff --git a/api/lib/infrastructure/repositories/campaign-assessment-participation-result-repository.js b/api/lib/infrastructure/repositories/campaign-assessment-participation-result-repository.js index f43f46c9e50..0915c454053 100644 --- a/api/lib/infrastructure/repositories/campaign-assessment-participation-result-repository.js +++ b/api/lib/infrastructure/repositories/campaign-assessment-participation-result-repository.js @@ -1,23 +1,23 @@ -const CampaignAssessmentParticipationResult = require('../../../lib/domain/read-models/CampaignAssessmentParticipationResult.js'); -const { NotFoundError } = require('../../../lib/domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); -const learningContentRepository = require('./learning-content-repository.js'); -const CampaignLearningContent = require('../../domain/models/CampaignLearningContent.js'); +import { CampaignAssessmentParticipationResult } from '../../../lib/domain/read-models/CampaignAssessmentParticipationResult.js'; +import { NotFoundError } from '../../../lib/domain/errors.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; +import * as learningContentRepository from './learning-content-repository.js'; +import { CampaignLearningContent } from '../../domain/models/CampaignLearningContent.js'; -module.exports = { - async getByCampaignIdAndCampaignParticipationId({ campaignId, campaignParticipationId, locale }) { - const learningContent = await learningContentRepository.findByCampaignId(campaignId, locale); - const campaignLearningContent = new CampaignLearningContent(learningContent); - const result = await _fetchCampaignAssessmentParticipationResultAttributesFromCampaignParticipation( - campaignId, - campaignParticipationId - ); +const getByCampaignIdAndCampaignParticipationId = async function ({ campaignId, campaignParticipationId, locale }) { + const learningContent = await learningContentRepository.findByCampaignId(campaignId, locale); + const campaignLearningContent = new CampaignLearningContent(learningContent); + const result = await _fetchCampaignAssessmentParticipationResultAttributesFromCampaignParticipation( + campaignId, + campaignParticipationId + ); - return _buildCampaignAssessmentParticipationResults(result, campaignLearningContent); - }, + return _buildCampaignAssessmentParticipationResults(result, campaignLearningContent); }; +export { getByCampaignIdAndCampaignParticipationId }; + async function _fetchCampaignAssessmentParticipationResultAttributesFromCampaignParticipation( campaignId, campaignParticipationId diff --git a/api/lib/infrastructure/repositories/campaign-collective-result-repository.js b/api/lib/infrastructure/repositories/campaign-collective-result-repository.js index 262e801b2e2..a70360c612e 100644 --- a/api/lib/infrastructure/repositories/campaign-collective-result-repository.js +++ b/api/lib/infrastructure/repositories/campaign-collective-result-repository.js @@ -1,40 +1,38 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignCollectiveResult = require('../../domain/read-models/CampaignCollectiveResult.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); -const { constants } = require('../constants.js'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignCollectiveResult } from '../../domain/read-models/CampaignCollectiveResult.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; +import { constants } from '../constants.js'; const { SHARED } = CampaignParticipationStatuses; -module.exports = { - async getCampaignCollectiveResult(campaignId, campaignLearningContent) { - const campaignCollectiveResult = new CampaignCollectiveResult({ - id: campaignId, - campaignLearningContent, - }); - - const userIdsAndSharedDatesChunks = await _getChunksSharedParticipationsWithUserIdsAndDates(campaignId); - - let participantCount = 0; - await bluebird.mapSeries(userIdsAndSharedDatesChunks, async (userIdsAndSharedDates) => { - participantCount += userIdsAndSharedDates.length; - const validatedTargetedKnowledgeElementsCountByCompetenceId = - await knowledgeElementRepository.countValidatedByCompetencesForUsersWithinCampaign( - Object.fromEntries(userIdsAndSharedDates), - campaignLearningContent - ); - campaignCollectiveResult.addValidatedSkillCountToCompetences( - validatedTargetedKnowledgeElementsCountByCompetenceId +const getCampaignCollectiveResult = async function (campaignId, campaignLearningContent) { + const campaignCollectiveResult = new CampaignCollectiveResult({ + id: campaignId, + campaignLearningContent, + }); + + const userIdsAndSharedDatesChunks = await _getChunksSharedParticipationsWithUserIdsAndDates(campaignId); + + let participantCount = 0; + await bluebird.mapSeries(userIdsAndSharedDatesChunks, async (userIdsAndSharedDates) => { + participantCount += userIdsAndSharedDates.length; + const validatedTargetedKnowledgeElementsCountByCompetenceId = + await knowledgeElementRepository.countValidatedByCompetencesForUsersWithinCampaign( + Object.fromEntries(userIdsAndSharedDates), + campaignLearningContent ); - }); + campaignCollectiveResult.addValidatedSkillCountToCompetences(validatedTargetedKnowledgeElementsCountByCompetenceId); + }); - campaignCollectiveResult.finalize(participantCount); - return campaignCollectiveResult; - }, + campaignCollectiveResult.finalize(participantCount); + return campaignCollectiveResult; }; +export { getCampaignCollectiveResult }; + async function _getChunksSharedParticipationsWithUserIdsAndDates(campaignId) { const results = await knex('campaign-participations') .select('userId', 'sharedAt') diff --git a/api/lib/infrastructure/repositories/campaign-creator-repository.js b/api/lib/infrastructure/repositories/campaign-creator-repository.js index 2d43ff60855..c73a2d772ce 100644 --- a/api/lib/infrastructure/repositories/campaign-creator-repository.js +++ b/api/lib/infrastructure/repositories/campaign-creator-repository.js @@ -1,6 +1,6 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignCreator = require('../../../lib/domain/models/CampaignCreator.js'); -const { UserNotAuthorizedToCreateCampaignError } = require('../../domain/errors.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignCreator } from '../../../lib/domain/models/CampaignCreator.js'; +import { UserNotAuthorizedToCreateCampaignError } from '../../domain/errors.js'; async function get({ userId, organizationId, ownerId }) { await _checkUserIsAMemberOfOrganization({ organizationId, userId }); @@ -19,9 +19,7 @@ async function get({ userId, organizationId, ownerId }) { return new CampaignCreator(availableTargetProfiles); } -module.exports = { - get, -}; +export { get }; async function _checkUserIsAMemberOfOrganization({ organizationId, userId }) { const membership = await knex('memberships').where({ organizationId, userId }).first(); diff --git a/api/lib/infrastructure/repositories/campaign-management-repository.js b/api/lib/infrastructure/repositories/campaign-management-repository.js index c471d2edf35..e58b0705f87 100644 --- a/api/lib/infrastructure/repositories/campaign-management-repository.js +++ b/api/lib/infrastructure/repositories/campaign-management-repository.js @@ -1,96 +1,95 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignManagement = require('../../domain/read-models/CampaignManagement.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const CampaignParticipationStatuses = require('../../../lib/domain/models/CampaignParticipationStatuses.js'); - -const CampaignTypes = require('../../domain/models/CampaignTypes.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignManagement } from '../../domain/read-models/CampaignManagement.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { CampaignParticipationStatuses } from '../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { CampaignTypes } from '../../domain/models/CampaignTypes.js'; const { SHARED, TO_SHARE, STARTED } = CampaignParticipationStatuses; -module.exports = { - async get(campaignId) { - let campaign = await knex('campaigns') - .select({ - id: 'campaigns.id', - code: 'campaigns.code', - name: 'campaigns.name', - idPixLabel: 'campaigns.idPixLabel', - createdAt: 'campaigns.createdAt', - archivedAt: 'campaigns.archivedAt', - type: 'campaigns.type', - creatorLastName: 'users.lastName', - creatorFirstName: 'users.firstName', - creatorId: 'users.id', - organizationId: 'campaigns.organizationId', - organizationName: 'organizations.name', - targetProfileId: 'campaigns.targetProfileId', - targetProfileName: 'target-profiles.name', - title: 'campaigns.title', - ownerId: 'ownerUser.id', - ownerLastName: 'ownerUser.lastName', - ownerFirstName: 'ownerUser.firstName', - customLandingPageText: 'campaigns.customLandingPageText', - customResultPageText: 'campaigns.customResultPageText', - customResultPageButtonText: 'campaigns.customResultPageButtonText', - customResultPageButtonUrl: 'campaigns.customResultPageButtonUrl', - multipleSendings: 'campaigns.multipleSendings', - }) - .join('users', 'users.id', 'campaigns.creatorId') - .join('users AS ownerUser', 'ownerUser.id', 'campaigns.ownerId') - .join('organizations', 'organizations.id', 'campaigns.organizationId') - .leftJoin('target-profiles', 'target-profiles.id', 'campaigns.targetProfileId') - .where('campaigns.id', campaignId) - .first(); +const get = async function (campaignId) { + let campaign = await knex('campaigns') + .select({ + id: 'campaigns.id', + code: 'campaigns.code', + name: 'campaigns.name', + idPixLabel: 'campaigns.idPixLabel', + createdAt: 'campaigns.createdAt', + archivedAt: 'campaigns.archivedAt', + type: 'campaigns.type', + creatorLastName: 'users.lastName', + creatorFirstName: 'users.firstName', + creatorId: 'users.id', + organizationId: 'campaigns.organizationId', + organizationName: 'organizations.name', + targetProfileId: 'campaigns.targetProfileId', + targetProfileName: 'target-profiles.name', + title: 'campaigns.title', + ownerId: 'ownerUser.id', + ownerLastName: 'ownerUser.lastName', + ownerFirstName: 'ownerUser.firstName', + customLandingPageText: 'campaigns.customLandingPageText', + customResultPageText: 'campaigns.customResultPageText', + customResultPageButtonText: 'campaigns.customResultPageButtonText', + customResultPageButtonUrl: 'campaigns.customResultPageButtonUrl', + multipleSendings: 'campaigns.multipleSendings', + }) + .join('users', 'users.id', 'campaigns.creatorId') + .join('users AS ownerUser', 'ownerUser.id', 'campaigns.ownerId') + .join('organizations', 'organizations.id', 'campaigns.organizationId') + .leftJoin('target-profiles', 'target-profiles.id', 'campaigns.targetProfileId') + .where('campaigns.id', campaignId) + .first(); - const participationCountByStatus = await _countParticipationsByStatus(campaignId, campaign.type); - campaign = { ...campaign, ...participationCountByStatus }; - const campaignManagement = new CampaignManagement(campaign); - return campaignManagement; - }, + const participationCountByStatus = await _countParticipationsByStatus(campaignId, campaign.type); + campaign = { ...campaign, ...participationCountByStatus }; + const campaignManagement = new CampaignManagement(campaign); + return campaignManagement; +}; - async findPaginatedCampaignManagements({ organizationId, page }) { - const query = knex('campaigns') - .select({ - id: 'campaigns.id', - code: 'campaigns.code', - name: 'campaigns.name', - idPixLabel: 'campaigns.idPixLabel', - createdAt: 'campaigns.createdAt', - archivedAt: 'campaigns.archivedAt', - type: 'campaigns.type', - creatorLastName: 'creatorUser.lastName', - creatorFirstName: 'creatorUser.firstName', - creatorId: 'creatorUser.id', - ownerId: 'ownerUser.id', - ownerLastName: 'ownerUser.lastName', - ownerFirstName: 'ownerUser.firstName', - }) - .join('users AS creatorUser', 'creatorUser.id', 'campaigns.creatorId') - .join('users AS ownerUser', 'ownerUser.id', 'campaigns.ownerId') - .where('organizationId', organizationId) - .orderBy('campaigns.createdAt', 'DESC'); +const findPaginatedCampaignManagements = async function ({ organizationId, page }) { + const query = knex('campaigns') + .select({ + id: 'campaigns.id', + code: 'campaigns.code', + name: 'campaigns.name', + idPixLabel: 'campaigns.idPixLabel', + createdAt: 'campaigns.createdAt', + archivedAt: 'campaigns.archivedAt', + type: 'campaigns.type', + creatorLastName: 'creatorUser.lastName', + creatorFirstName: 'creatorUser.firstName', + creatorId: 'creatorUser.id', + ownerId: 'ownerUser.id', + ownerLastName: 'ownerUser.lastName', + ownerFirstName: 'ownerUser.firstName', + }) + .join('users AS creatorUser', 'creatorUser.id', 'campaigns.creatorId') + .join('users AS ownerUser', 'ownerUser.id', 'campaigns.ownerId') + .where('organizationId', organizationId) + .orderBy('campaigns.createdAt', 'DESC'); - const { results, pagination } = await fetchPage(query, page); + const { results, pagination } = await fetchPage(query, page); - const campaignManagement = results.map((attributes) => new CampaignManagement(attributes)); - return { models: campaignManagement, meta: { ...pagination } }; - }, + const campaignManagement = results.map((attributes) => new CampaignManagement(attributes)); + return { models: campaignManagement, meta: { ...pagination } }; +}; - update({ campaignId, campaignAttributes }) { - const editableAttributes = _.pick(campaignAttributes, [ - 'name', - 'title', - 'customLandingPageText', - 'customResultPageText', - 'customResultPageButtonText', - 'customResultPageButtonUrl', - 'multipleSendings', - ]); - return knex('campaigns').where({ id: campaignId }).update(editableAttributes); - }, +const update = function ({ campaignId, campaignAttributes }) { + const editableAttributes = _.pick(campaignAttributes, [ + 'name', + 'title', + 'customLandingPageText', + 'customResultPageText', + 'customResultPageButtonText', + 'customResultPageButtonUrl', + 'multipleSendings', + ]); + return knex('campaigns').where({ id: campaignId }).update(editableAttributes); }; +export { get, findPaginatedCampaignManagements, update }; + async function _countParticipationsByStatus(campaignId, campaignType) { const row = await knex('campaign-participations') .select([ diff --git a/api/lib/infrastructure/repositories/campaign-participant-activity-repository.js b/api/lib/infrastructure/repositories/campaign-participant-activity-repository.js index 4c498b5c92f..ec72c7ffc56 100644 --- a/api/lib/infrastructure/repositories/campaign-participant-activity-repository.js +++ b/api/lib/infrastructure/repositories/campaign-participant-activity-repository.js @@ -1,7 +1,7 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignParticipantActivity = require('../../domain/read-models/CampaignParticipantActivity.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const { filterByFullName } = require('../utils/filter-utils.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignParticipantActivity } from '../../domain/read-models/CampaignParticipantActivity.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { filterByFullName } from '../utils/filter-utils.js'; const campaignParticipantActivityRepository = { async findPaginatedByCampaignId({ page = { size: 25 }, campaignId, filters = {} }) { @@ -91,4 +91,4 @@ function _filterByGroup(queryBuilder, filters) { } } -module.exports = campaignParticipantActivityRepository; +export { campaignParticipantActivityRepository }; diff --git a/api/lib/infrastructure/repositories/campaign-participant-repository.js b/api/lib/infrastructure/repositories/campaign-participant-repository.js index 76a80db9f0e..c47be0872c1 100644 --- a/api/lib/infrastructure/repositories/campaign-participant-repository.js +++ b/api/lib/infrastructure/repositories/campaign-participant-repository.js @@ -1,9 +1,12 @@ -const pick = require('lodash/pick'); -const CampaignParticipant = require('../../domain/models/CampaignParticipant.js'); -const CampaignToStartParticipation = require('../../domain/models/CampaignToStartParticipation.js'); -const { AlreadyExistingCampaignParticipationError, NotFoundError } = require('../../domain/errors.js'); -const campaignRepository = require('../repositories/campaign-repository.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import lodash from 'lodash'; + +const { pick } = lodash; + +import { CampaignParticipant } from '../../domain/models/CampaignParticipant.js'; +import { CampaignToStartParticipation } from '../../domain/models/CampaignToStartParticipation.js'; +import { AlreadyExistingCampaignParticipationError, NotFoundError } from '../../domain/errors.js'; +import * as campaignRepository from '../repositories/campaign-repository.js'; +import { knex } from '../../../db/knex-database-connection.js'; async function save(campaignParticipant, domainTransaction) { const newlyCreatedOrganizationLearnerId = await _createNewOrganizationLearner( @@ -182,7 +185,4 @@ async function _findpreviousCampaignParticipationForUser(campaignId, userId, dom }; } -module.exports = { - get, - save, -}; +export { get, save }; diff --git a/api/lib/infrastructure/repositories/campaign-participation-info-repository.js b/api/lib/infrastructure/repositories/campaign-participation-info-repository.js index 5fcb541163d..ab21b398402 100644 --- a/api/lib/infrastructure/repositories/campaign-participation-info-repository.js +++ b/api/lib/infrastructure/repositories/campaign-participation-info-repository.js @@ -1,37 +1,37 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const Assessment = require('../../domain/models/Assessment.js'); -const CampaignParticipationInfo = require('../../domain/read-models/CampaignParticipationInfo.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { Assessment } from '../../domain/models/Assessment.js'; +import { CampaignParticipationInfo } from '../../domain/read-models/CampaignParticipationInfo.js'; -module.exports = { - async findByCampaignId(campaignId) { - const results = await knex - .with('campaignParticipationWithUserAndRankedAssessment', (qb) => { - qb.select([ - 'campaign-participations.*', - 'assessments.state', - _assessmentRankByCreationDate(), - 'view-active-organization-learners.firstName', - 'view-active-organization-learners.lastName', - 'view-active-organization-learners.studentNumber', - 'view-active-organization-learners.division', - 'view-active-organization-learners.group', - ]) - .from('campaign-participations') - .join('assessments', 'campaign-participations.id', 'assessments.campaignParticipationId') - .join( - 'view-active-organization-learners', - 'view-active-organization-learners.id', - 'campaign-participations.organizationLearnerId' - ) - .where({ campaignId, isImproved: false, 'campaign-participations.deletedAt': null }); - }) - .from('campaignParticipationWithUserAndRankedAssessment') - .where({ rank: 1 }); +const findByCampaignId = async function (campaignId) { + const results = await knex + .with('campaignParticipationWithUserAndRankedAssessment', (qb) => { + qb.select([ + 'campaign-participations.*', + 'assessments.state', + _assessmentRankByCreationDate(), + 'view-active-organization-learners.firstName', + 'view-active-organization-learners.lastName', + 'view-active-organization-learners.studentNumber', + 'view-active-organization-learners.division', + 'view-active-organization-learners.group', + ]) + .from('campaign-participations') + .join('assessments', 'campaign-participations.id', 'assessments.campaignParticipationId') + .join( + 'view-active-organization-learners', + 'view-active-organization-learners.id', + 'campaign-participations.organizationLearnerId' + ) + .where({ campaignId, isImproved: false, 'campaign-participations.deletedAt': null }); + }) + .from('campaignParticipationWithUserAndRankedAssessment') + .where({ rank: 1 }); - return results.map(_rowToCampaignParticipationInfo); - }, + return results.map(_rowToCampaignParticipationInfo); }; +export { findByCampaignId }; + function _assessmentRankByCreationDate() { return knex.raw('ROW_NUMBER() OVER (PARTITION BY ?? ORDER BY ?? DESC) AS rank', [ 'assessments.campaignParticipationId', diff --git a/api/lib/infrastructure/repositories/campaign-participation-overview-repository.js b/api/lib/infrastructure/repositories/campaign-participation-overview-repository.js index 38b2d35166b..e8c7bce6e66 100644 --- a/api/lib/infrastructure/repositories/campaign-participation-overview-repository.js +++ b/api/lib/infrastructure/repositories/campaign-participation-overview-repository.js @@ -1,30 +1,30 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignTypes = require('../../domain/models/CampaignTypes.js'); -const CampaignParticipationOverview = require('../../domain/read-models/CampaignParticipationOverview.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const bluebird = require('bluebird'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); -const stageCollectionRepository = require('./user-campaign-results/stage-collection-repository'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignTypes } from '../../domain/models/CampaignTypes.js'; +import { CampaignParticipationOverview } from '../../domain/read-models/CampaignParticipationOverview.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import bluebird from 'bluebird'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; +import * as stageCollectionRepository from './user-campaign-results/stage-collection-repository.js'; -module.exports = { - async findByUserIdWithFilters({ userId, states, page }) { - const queryBuilder = _findByUserId({ userId }); +const findByUserIdWithFilters = async function ({ userId, states, page }) { + const queryBuilder = _findByUserId({ userId }); - if (states && states.length > 0) { - _filterByStates(queryBuilder, states); - } + if (states && states.length > 0) { + _filterByStates(queryBuilder, states); + } - const { results, pagination } = await fetchPage(queryBuilder, page); + const { results, pagination } = await fetchPage(queryBuilder, page); - const campaignParticipationOverviews = await _toReadModel(results); + const campaignParticipationOverviews = await _toReadModel(results); - return { - campaignParticipationOverviews, - pagination, - }; - }, + return { + campaignParticipationOverviews, + pagination, + }; }; +export { findByUserIdWithFilters }; + function _findByUserId({ userId }) { return knex .with('campaign-participation-overviews', (qb) => { diff --git a/api/lib/infrastructure/repositories/campaign-participation-repository.js b/api/lib/infrastructure/repositories/campaign-participation-repository.js index 60f1b046ebc..031ca1716c8 100644 --- a/api/lib/infrastructure/repositories/campaign-participation-repository.js +++ b/api/lib/infrastructure/repositories/campaign-participation-repository.js @@ -1,209 +1,228 @@ -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); -const CampaignTypes = require('../../domain/models/CampaignTypes.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); -const knowledgeElementSnapshotRepository = require('./knowledge-element-snapshot-repository.js'); -const CampaignParticipation = require('../../domain/models/CampaignParticipation.js'); -const Assessment = require('../../domain/models/Assessment.js'); -const Campaign = require('../../domain/models/Campaign.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; +import { CampaignTypes } from '../../domain/models/CampaignTypes.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; +import * as knowledgeElementSnapshotRepository from './knowledge-element-snapshot-repository.js'; +import { CampaignParticipation } from '../../domain/models/CampaignParticipation.js'; +import { Assessment } from '../../domain/models/Assessment.js'; +import { Campaign } from '../../domain/models/Campaign.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { NotFoundError } from '../../domain/errors.js'; const { SHARED, TO_SHARE, STARTED } = CampaignParticipationStatuses; -module.exports = { - async hasAssessmentParticipations(userId) { - const { count } = await knex('campaign-participations') - .count('campaign-participations.id') - .join('campaigns', 'campaigns.id', 'campaignId') - .where('campaigns.type', '=', CampaignTypes.ASSESSMENT) - .andWhere({ userId }) - .first(); - return count > 0; - }, - async getCodeOfLastParticipationToProfilesCollectionCampaignForUser(userId) { - const result = await knex('campaign-participations') - .select('campaigns.code') - .join('campaigns', 'campaigns.id', 'campaignId') - .where({ userId }) - .whereNull('deletedAt') - .whereNull('archivedAt') - .andWhere({ status: TO_SHARE }) - .andWhere({ 'campaigns.type': CampaignTypes.PROFILES_COLLECTION }) - .orderBy('campaign-participations.createdAt', 'desc') - .first(); - return result?.code || null; - }, - async get(id, domainTransaction = DomainTransaction.emptyTransaction()) { - const knexConn = domainTransaction.knexTransaction || knex; - const campaignParticipation = await knexConn('campaign-participations').where({ id }).first(); - const campaign = await knexConn('campaigns').where({ id: campaignParticipation.campaignId }).first(); - const assessments = await knexConn('assessments').where({ campaignParticipationId: id }); +const hasAssessmentParticipations = async function (userId) { + const { count } = await knex('campaign-participations') + .count('campaign-participations.id') + .join('campaigns', 'campaigns.id', 'campaignId') + .where('campaigns.type', '=', CampaignTypes.ASSESSMENT) + .andWhere({ userId }) + .first(); + return count > 0; +}; + +const getCodeOfLastParticipationToProfilesCollectionCampaignForUser = async function (userId) { + const result = await knex('campaign-participations') + .select('campaigns.code') + .join('campaigns', 'campaigns.id', 'campaignId') + .where({ userId }) + .whereNull('deletedAt') + .whereNull('archivedAt') + .andWhere({ status: TO_SHARE }) + .andWhere({ 'campaigns.type': CampaignTypes.PROFILES_COLLECTION }) + .orderBy('campaign-participations.createdAt', 'desc') + .first(); + return result?.code || null; +}; + +const get = async function (id, domainTransaction = DomainTransaction.emptyTransaction()) { + const knexConn = domainTransaction.knexTransaction || knex; + const campaignParticipation = await knexConn('campaign-participations').where({ id }).first(); + const campaign = await knexConn('campaigns').where({ id: campaignParticipation.campaignId }).first(); + const assessments = await knexConn('assessments').where({ campaignParticipationId: id }); + return new CampaignParticipation({ + ...campaignParticipation, + campaign: new Campaign(campaign), + assessments: assessments.map((assessment) => new Assessment(assessment)), + }); +}; + +const update = async function (campaignParticipation, domainTransaction = DomainTransaction.emptyTransaction()) { + const knexConn = domainTransaction.knexTransaction || knex; + const attributes = _getAttributes(campaignParticipation); + + await knexConn.from('campaign-participations').where({ id: campaignParticipation.id }).update(attributes); +}; + +const findProfilesCollectionResultDataByCampaignId = async function (campaignId) { + const results = await knex('campaign-participations') + .select([ + 'campaign-participations.*', + 'view-active-organization-learners.studentNumber', + 'view-active-organization-learners.division', + 'view-active-organization-learners.group', + 'view-active-organization-learners.firstName', + 'view-active-organization-learners.lastName', + ]) + .join( + 'view-active-organization-learners', + 'view-active-organization-learners.id', + 'campaign-participations.organizationLearnerId' + ) + .where({ campaignId, isImproved: false, 'campaign-participations.deletedAt': null }); + + return results.map(_rowToResult); +}; + +const findLatestOngoingByUserId = async function (userId) { + const campaignParticipations = await knex('campaign-participations') + .join('campaigns', 'campaigns.id', 'campaign-participations.campaignId') + .whereNull('campaigns.archivedAt') + .where({ userId }) + .orderBy('campaign-participations.createdAt', 'DESC') + .select('campaign-participations.*'); + const campaigns = await knex('campaigns').whereIn( + 'id', + campaignParticipations.map((campaignParticipation) => campaignParticipation.campaignId) + ); + const assessments = await knex('assessments') + .whereIn( + 'campaignParticipationId', + campaignParticipations.map((campaignParticipation) => campaignParticipation.id) + ) + .orderBy('createdAt'); + return campaignParticipations.map((campaignParticipation) => { + const campaign = campaigns.find((campaign) => campaign.id === campaignParticipation.campaignId); return new CampaignParticipation({ ...campaignParticipation, campaign: new Campaign(campaign), - assessments: assessments.map((assessment) => new Assessment(assessment)), + assessments: assessments + .filter((assessment) => assessment.campaignParticipationId === campaignParticipation.id) + .map((assessment) => new Assessment(assessment)), }); - }, - - async update(campaignParticipation, domainTransaction = DomainTransaction.emptyTransaction()) { - const knexConn = domainTransaction.knexTransaction || knex; - const attributes = _getAttributes(campaignParticipation); - - await knexConn.from('campaign-participations').where({ id: campaignParticipation.id }).update(attributes); - }, - - async findProfilesCollectionResultDataByCampaignId(campaignId) { - const results = await knex('campaign-participations') - .select([ - 'campaign-participations.*', - 'view-active-organization-learners.studentNumber', - 'view-active-organization-learners.division', - 'view-active-organization-learners.group', - 'view-active-organization-learners.firstName', - 'view-active-organization-learners.lastName', - ]) - .join( - 'view-active-organization-learners', - 'view-active-organization-learners.id', - 'campaign-participations.organizationLearnerId' - ) - .where({ campaignId, isImproved: false, 'campaign-participations.deletedAt': null }); - - return results.map(_rowToResult); - }, - - async findLatestOngoingByUserId(userId) { - const campaignParticipations = await knex('campaign-participations') - .join('campaigns', 'campaigns.id', 'campaign-participations.campaignId') - .whereNull('campaigns.archivedAt') - .where({ userId }) - .orderBy('campaign-participations.createdAt', 'DESC') - .select('campaign-participations.*'); - const campaigns = await knex('campaigns').whereIn( - 'id', - campaignParticipations.map((campaignParticipation) => campaignParticipation.campaignId) - ); - const assessments = await knex('assessments') - .whereIn( - 'campaignParticipationId', - campaignParticipations.map((campaignParticipation) => campaignParticipation.id) - ) - .orderBy('createdAt'); - return campaignParticipations.map((campaignParticipation) => { - const campaign = campaigns.find((campaign) => campaign.id === campaignParticipation.campaignId); - return new CampaignParticipation({ - ...campaignParticipation, - campaign: new Campaign(campaign), - assessments: assessments - .filter((assessment) => assessment.campaignParticipationId === campaignParticipation.id) - .map((assessment) => new Assessment(assessment)), - }); - }); - }, - - async findOneByCampaignIdAndUserId({ campaignId, userId }) { - const campaignParticipation = await knex('campaign-participations') - .where({ userId, isImproved: false, campaignId }) - .first(); - if (!campaignParticipation) return null; - const assessments = await knex('assessments').where({ campaignParticipationId: campaignParticipation.id }); - return new CampaignParticipation({ - ...campaignParticipation, - assessments: assessments.map((assessment) => new Assessment(assessment)), - }); - }, + }); +}; - async updateWithSnapshot(campaignParticipation, domainTransaction = DomainTransaction.emptyTransaction()) { - await this.update(campaignParticipation, domainTransaction); +const findOneByCampaignIdAndUserId = async function ({ campaignId, userId }) { + const campaignParticipation = await knex('campaign-participations') + .where({ userId, isImproved: false, campaignId }) + .first(); + if (!campaignParticipation) return null; + const assessments = await knex('assessments').where({ campaignParticipationId: campaignParticipation.id }); + return new CampaignParticipation({ + ...campaignParticipation, + assessments: assessments.map((assessment) => new Assessment(assessment)), + }); +}; - const knowledgeElements = await knowledgeElementRepository.findUniqByUserId({ - userId: campaignParticipation.userId, - limitDate: campaignParticipation.sharedAt, - domainTransaction, - }); - await knowledgeElementSnapshotRepository.save({ - userId: campaignParticipation.userId, - snappedAt: campaignParticipation.sharedAt, - knowledgeElements, - domainTransaction, - }); - }, - - async isRetrying({ campaignParticipationId }) { - const { id: campaignId, userId } = await knex('campaigns') - .select('campaigns.id', 'userId') - .join('campaign-participations', 'campaigns.id', 'campaignId') - .where({ 'campaign-participations.id': campaignParticipationId }) - .first(); - - const campaignParticipations = await knex('campaign-participations') - .select('sharedAt', 'isImproved') - .where({ campaignId, userId }); - - return ( - campaignParticipations.length > 1 && - campaignParticipations.some((participation) => !participation.isImproved && !participation.sharedAt) +const updateWithSnapshot = async function ( + campaignParticipation, + domainTransaction = DomainTransaction.emptyTransaction() +) { + await this.update(campaignParticipation, domainTransaction); + + const knowledgeElements = await knowledgeElementRepository.findUniqByUserId({ + userId: campaignParticipation.userId, + limitDate: campaignParticipation.sharedAt, + domainTransaction, + }); + await knowledgeElementSnapshotRepository.save({ + userId: campaignParticipation.userId, + snappedAt: campaignParticipation.sharedAt, + knowledgeElements, + domainTransaction, + }); +}; + +const isRetrying = async function ({ campaignParticipationId }) { + const { id: campaignId, userId } = await knex('campaigns') + .select('campaigns.id', 'userId') + .join('campaign-participations', 'campaigns.id', 'campaignId') + .where({ 'campaign-participations.id': campaignParticipationId }) + .first(); + + const campaignParticipations = await knex('campaign-participations') + .select('sharedAt', 'isImproved') + .where({ campaignId, userId }); + + return ( + campaignParticipations.length > 1 && + campaignParticipations.some((participation) => !participation.isImproved && !participation.sharedAt) + ); +}; + +const getAllParticipationsByCampaignId = async function (campaignId) { + const result = await knex + .select('masteryRate', 'validatedSkillsCount') + .from('campaign-participations') + .where('campaign-participations.campaignId', '=', campaignId) + .where('campaign-participations.isImproved', '=', false) + .where('campaign-participations.deletedAt', 'is', null) + .where('campaign-participations.status', 'SHARED'); + + return result; +}; + +const countParticipationsByStatus = async function (campaignId, campaignType) { + const row = await knex('campaign-participations') + .select([ + knex.raw(`sum(case when status = ? then 1 else 0 end) as shared`, SHARED), + knex.raw(`sum(case when status = ? then 1 else 0 end) as completed`, TO_SHARE), + knex.raw(`sum(case when status = ? then 1 else 0 end) as started`, STARTED), + ]) + .where({ campaignId, isImproved: false, deletedAt: null }) + .groupBy('campaignId') + .first(); + + return mapToParticipationByStatus(row, campaignType); +}; + +const getAllCampaignParticipationsInCampaignForASameLearner = async function ({ + campaignId, + campaignParticipationId, + domainTransaction, +}) { + const knexConn = domainTransaction.knexTransaction; + const result = await knexConn('campaign-participations') + .select('organizationLearnerId') + .where({ id: campaignParticipationId, campaignId }) + .first(); + + if (!result) { + throw new NotFoundError( + `There is no campaign participation with the id "${campaignParticipationId}" for the campaign wih the id "${campaignId}"` ); - }, - - async getAllParticipationsByCampaignId(campaignId) { - const result = await knex - .select('masteryRate', 'validatedSkillsCount') - .from('campaign-participations') - .where('campaign-participations.campaignId', '=', campaignId) - .where('campaign-participations.isImproved', '=', false) - .where('campaign-participations.deletedAt', 'is', null) - .where('campaign-participations.status', 'SHARED'); - - return result; - }, - - async countParticipationsByStatus(campaignId, campaignType) { - const row = await knex('campaign-participations') - .select([ - knex.raw(`sum(case when status = ? then 1 else 0 end) as shared`, SHARED), - knex.raw(`sum(case when status = ? then 1 else 0 end) as completed`, TO_SHARE), - knex.raw(`sum(case when status = ? then 1 else 0 end) as started`, STARTED), - ]) - .where({ campaignId, isImproved: false, deletedAt: null }) - .groupBy('campaignId') - .first(); - - return mapToParticipationByStatus(row, campaignType); - }, - - async getAllCampaignParticipationsInCampaignForASameLearner({ + } + + const campaignParticipations = await knexConn('campaign-participations').where({ campaignId, - campaignParticipationId, - domainTransaction, - }) { - const knexConn = domainTransaction.knexTransaction; - const result = await knexConn('campaign-participations') - .select('organizationLearnerId') - .where({ id: campaignParticipationId, campaignId }) - .first(); - - if (!result) { - throw new NotFoundError( - `There is no campaign participation with the id "${campaignParticipationId}" for the campaign wih the id "${campaignId}"` - ); - } - - const campaignParticipations = await knexConn('campaign-participations').where({ - campaignId, - organizationLearnerId: result.organizationLearnerId, - deletedAt: null, - deletedBy: null, - }); + organizationLearnerId: result.organizationLearnerId, + deletedAt: null, + deletedBy: null, + }); - return campaignParticipations.map((campaignParticipation) => new CampaignParticipation(campaignParticipation)); - }, + return campaignParticipations.map((campaignParticipation) => new CampaignParticipation(campaignParticipation)); +}; + +const remove = async function ({ id, deletedAt, deletedBy, domainTransaction }) { + const knexConn = domainTransaction.knexTransaction; + return await knexConn('campaign-participations').where({ id }).update({ deletedAt, deletedBy }); +}; - async delete({ id, deletedAt, deletedBy, domainTransaction }) { - const knexConn = domainTransaction.knexTransaction; - return await knexConn('campaign-participations').where({ id }).update({ deletedAt, deletedBy }); - }, +export { + hasAssessmentParticipations, + getCodeOfLastParticipationToProfilesCollectionCampaignForUser, + get, + update, + findProfilesCollectionResultDataByCampaignId, + findLatestOngoingByUserId, + findOneByCampaignIdAndUserId, + updateWithSnapshot, + isRetrying, + getAllParticipationsByCampaignId, + countParticipationsByStatus, + getAllCampaignParticipationsInCampaignForASameLearner, + remove, }; function _rowToResult(row) { diff --git a/api/lib/infrastructure/repositories/campaign-participation-result-repository.js b/api/lib/infrastructure/repositories/campaign-participation-result-repository.js index 9ed6b6595f6..99adfd2f787 100644 --- a/api/lib/infrastructure/repositories/campaign-participation-result-repository.js +++ b/api/lib/infrastructure/repositories/campaign-participation-result-repository.js @@ -1,10 +1,10 @@ -const CampaignParticipationResult = require('../../domain/models/CampaignParticipationResult.js'); -const campaignParticipationRepository = require('./campaign-participation-repository.js'); -const campaignRepository = require('./campaign-repository.js'); -const competenceRepository = require('./competence-repository.js'); -const areaRepository = require('./area-repository.js'); -const assessmentRepository = require('./assessment-repository.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); +import { CampaignParticipationResult } from '../../domain/models/CampaignParticipationResult.js'; +import * as campaignParticipationRepository from './campaign-participation-repository.js'; +import * as campaignRepository from './campaign-repository.js'; +import * as competenceRepository from './competence-repository.js'; +import * as areaRepository from './area-repository.js'; +import * as assessmentRepository from './assessment-repository.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; const campaignParticipationResultRepository = { async getByParticipationId(campaignParticipationId) { @@ -31,4 +31,4 @@ const campaignParticipationResultRepository = { }, }; -module.exports = campaignParticipationResultRepository; +export { campaignParticipationResultRepository }; diff --git a/api/lib/infrastructure/repositories/campaign-participations-stats-repository.js b/api/lib/infrastructure/repositories/campaign-participations-stats-repository.js index d36a3f1a8f7..45a809879c8 100644 --- a/api/lib/infrastructure/repositories/campaign-participations-stats-repository.js +++ b/api/lib/infrastructure/repositories/campaign-participations-stats-repository.js @@ -1,5 +1,5 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; @@ -36,4 +36,4 @@ async function _getCumulativeParticipationCountsByDay(campaignId, column) { return data.map(({ day, count }) => ({ day, count: Number(count) })); } -module.exports = CampaignParticipationsStatsRepository; +export { CampaignParticipationsStatsRepository }; diff --git a/api/lib/infrastructure/repositories/campaign-profile-repository.js b/api/lib/infrastructure/repositories/campaign-profile-repository.js index 6166435518a..d3980b4ee35 100644 --- a/api/lib/infrastructure/repositories/campaign-profile-repository.js +++ b/api/lib/infrastructure/repositories/campaign-profile-repository.js @@ -1,28 +1,28 @@ -const CampaignProfile = require('../../../lib/domain/read-models/CampaignProfile.js'); -const placementProfileService = require('../../domain/services/placement-profile-service.js'); -const { NotFoundError } = require('../../../lib/domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const competenceRepository = require('./competence-repository.js'); -const areaRepository = require('./area-repository.js'); +import { CampaignProfile } from '../../../lib/domain/read-models/CampaignProfile.js'; +import * as placementProfileService from '../../domain/services/placement-profile-service.js'; +import { NotFoundError } from '../../../lib/domain/errors.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import * as competenceRepository from './competence-repository.js'; +import * as areaRepository from './area-repository.js'; -module.exports = { - async findProfile({ campaignId, campaignParticipationId, locale }) { - const profile = await _fetchCampaignProfileAttributesFromCampaignParticipation(campaignId, campaignParticipationId); - const competences = await competenceRepository.listPixCompetencesOnly({ locale }); - const allAreas = await areaRepository.list({ locale }); +const findProfile = async function ({ campaignId, campaignParticipationId, locale }) { + const profile = await _fetchCampaignProfileAttributesFromCampaignParticipation(campaignId, campaignParticipationId); + const competences = await competenceRepository.listPixCompetencesOnly({ locale }); + const allAreas = await areaRepository.list({ locale }); - const { sharedAt, userId } = profile; - const placementProfile = await placementProfileService.getPlacementProfileWithSnapshotting({ - userId, - limitDate: sharedAt, - allowExcessPixAndLevels: false, - competences, - }); + const { sharedAt, userId } = profile; + const placementProfile = await placementProfileService.getPlacementProfileWithSnapshotting({ + userId, + limitDate: sharedAt, + allowExcessPixAndLevels: false, + competences, + }); - return new CampaignProfile({ ...profile, placementProfile, allAreas }); - }, + return new CampaignProfile({ ...profile, placementProfile, allAreas }); }; +export { findProfile }; + async function _fetchCampaignProfileAttributesFromCampaignParticipation(campaignId, campaignParticipationId) { const [profile] = await knex .with('campaignProfile', (qb) => { diff --git a/api/lib/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository.js b/api/lib/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository.js index 5107877371e..92b4e2e633d 100644 --- a/api/lib/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository.js +++ b/api/lib/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository.js @@ -1,60 +1,61 @@ -const chunk = require('lodash/chunk'); -const bluebird = require('bluebird'); -const { knex } = require('../../../db/knex-database-connection.js'); -const placementProfileService = require('../../domain/services/placement-profile-service.js'); -const CampaignProfilesCollectionParticipationSummary = require('../../domain/read-models/CampaignProfilesCollectionParticipationSummary.js'); -const competenceRepository = require('../../infrastructure/repositories/competence-repository.js'); -const { constants } = require('../constants.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const { filterByFullName } = require('../utils/filter-utils.js'); - -const CampaignProfilesCollectionParticipationSummaryRepository = { - async findPaginatedByCampaignId(campaignId, page, filters = {}) { - const query = knex - .select( - 'campaign-participations.id AS campaignParticipationId', - 'campaign-participations.userId AS userId', - knex.raw('LOWER("view-active-organization-learners"."firstName") AS "lowerFirstName"'), - knex.raw('LOWER("view-active-organization-learners"."lastName") AS "lowerLastName"'), - 'view-active-organization-learners.firstName AS firstName', - 'view-active-organization-learners.lastName AS lastName', - 'campaign-participations.participantExternalId', - 'campaign-participations.sharedAt', - 'campaign-participations.pixScore AS pixScore' - ) - .from('campaign-participations') - .join( - 'view-active-organization-learners', - 'view-active-organization-learners.id', - 'campaign-participations.organizationLearnerId' - ) - .where('campaign-participations.campaignId', '=', campaignId) - .where('campaign-participations.isImproved', '=', false) - .where('campaign-participations.deletedAt', 'IS', null) - .whereRaw('"campaign-participations"."sharedAt" IS NOT NULL') - .orderByRaw('?? ASC, ?? ASC', ['lowerLastName', 'lowerFirstName']) - .modify(_filterQuery, filters); - - const { results, pagination } = await fetchPage(query, page); - - const getPlacementProfileForUser = await _makeMemoizedGetPlacementProfileForUser(results); - - const data = results.map((result) => { - if (!result.sharedAt) { - return new CampaignProfilesCollectionParticipationSummary(result); - } - - const placementProfile = getPlacementProfileForUser(result.userId); - - return new CampaignProfilesCollectionParticipationSummary({ - ...result, - certifiable: placementProfile.isCertifiable(), - certifiableCompetencesCount: placementProfile.getCertifiableCompetencesCount(), - }); +import lodash from 'lodash'; + +const { chunk } = lodash; + +import bluebird from 'bluebird'; +import { knex } from '../../../db/knex-database-connection.js'; +import * as placementProfileService from '../../domain/services/placement-profile-service.js'; +import { CampaignProfilesCollectionParticipationSummary } from '../../domain/read-models/CampaignProfilesCollectionParticipationSummary.js'; +import * as competenceRepository from '../../infrastructure/repositories/competence-repository.js'; +import { constants } from '../constants.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { filterByFullName } from '../utils/filter-utils.js'; + +const findPaginatedByCampaignId = async function (campaignId, page, filters = {}) { + const query = knex + .select( + 'campaign-participations.id AS campaignParticipationId', + 'campaign-participations.userId AS userId', + knex.raw('LOWER("view-active-organization-learners"."firstName") AS "lowerFirstName"'), + knex.raw('LOWER("view-active-organization-learners"."lastName") AS "lowerLastName"'), + 'view-active-organization-learners.firstName AS firstName', + 'view-active-organization-learners.lastName AS lastName', + 'campaign-participations.participantExternalId', + 'campaign-participations.sharedAt', + 'campaign-participations.pixScore AS pixScore' + ) + .from('campaign-participations') + .join( + 'view-active-organization-learners', + 'view-active-organization-learners.id', + 'campaign-participations.organizationLearnerId' + ) + .where('campaign-participations.campaignId', '=', campaignId) + .where('campaign-participations.isImproved', '=', false) + .where('campaign-participations.deletedAt', 'IS', null) + .whereRaw('"campaign-participations"."sharedAt" IS NOT NULL') + .orderByRaw('?? ASC, ?? ASC', ['lowerLastName', 'lowerFirstName']) + .modify(_filterQuery, filters); + + const { results, pagination } = await fetchPage(query, page); + + const getPlacementProfileForUser = await _makeMemoizedGetPlacementProfileForUser(results); + + const data = results.map((result) => { + if (!result.sharedAt) { + return new CampaignProfilesCollectionParticipationSummary(result); + } + + const placementProfile = getPlacementProfileForUser(result.userId); + + return new CampaignProfilesCollectionParticipationSummary({ + ...result, + certifiable: placementProfile.isCertifiable(), + certifiableCompetencesCount: placementProfile.getCertifiableCompetencesCount(), }); + }); - return { data, pagination }; - }, + return { data, pagination }; }; async function _makeMemoizedGetPlacementProfileForUser(results) { @@ -102,4 +103,4 @@ function _filterQuery(queryBuilder, filters) { } } -module.exports = CampaignProfilesCollectionParticipationSummaryRepository; +export { findPaginatedByCampaignId }; diff --git a/api/lib/infrastructure/repositories/campaign-report-repository.js b/api/lib/infrastructure/repositories/campaign-report-repository.js index e6cd83ce06c..12e3ba47f2b 100644 --- a/api/lib/infrastructure/repositories/campaign-report-repository.js +++ b/api/lib/infrastructure/repositories/campaign-report-repository.js @@ -1,13 +1,12 @@ -const { knex } = require('../../../db/knex-database-connection.js'); - -const CampaignReport = require('../../domain/read-models/CampaignReport.js'); -const TargetProfileForSpecifier = require('../../domain/read-models/campaign/TargetProfileForSpecifier.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const _ = require('lodash'); -const { filterByFullName } = require('../utils/filter-utils.js'); -const campaignRepository = require('./campaign-repository.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignReport } from '../../domain/read-models/CampaignReport.js'; +import { TargetProfileForSpecifier } from '../../domain/read-models/campaign/TargetProfileForSpecifier.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { NotFoundError } from '../../domain/errors.js'; +import _ from 'lodash'; +import { filterByFullName } from '../utils/filter-utils.js'; +import * as campaignRepository from './campaign-repository.js'; const { SHARED } = CampaignParticipationStatuses; @@ -28,116 +27,116 @@ function _setSearchFiltersForQueryBuilder(qb, { name, ongoing = true, ownerName, } } -module.exports = { - async get(id) { - const result = await knex('campaigns') - .select({ - id: 'campaigns.id', - name: 'campaigns.name', - code: 'campaigns.code', - title: 'campaigns.title', - idPixLabel: 'campaigns.idPixLabel', - createdAt: 'campaigns.createdAt', - customLandingPageText: 'campaigns.customLandingPageText', - archivedAt: 'campaigns.archivedAt', - type: 'campaigns.type', - ownerId: 'users.id', - ownerLastName: 'users.lastName', - ownerFirstName: 'users.firstName', - targetProfileId: 'target-profiles.id', - targetProfileDescription: 'target-profiles.description', - targetProfileName: 'target-profiles.name', - multipleSendings: 'campaigns.multipleSendings', - }) - .select( - knex.raw('ARRAY_AGG("badges"."id") AS "badgeIds"'), - knex.raw('ARRAY_AGG("stages"."id") AS "stageIds"'), - knex.raw( - '(SELECT COUNT(*) from "campaign-participations" WHERE "campaign-participations"."campaignId" = "campaigns"."id" AND "campaign-participations"."isImproved" IS FALSE AND "campaign-participations"."deletedAt" IS NULL) AS "participationsCount"' - ), - knex.raw( - '(SELECT COUNT(*) from "campaign-participations" WHERE "campaign-participations"."campaignId" = "campaigns"."id" AND "campaign-participations"."status" = \'SHARED\' AND "campaign-participations"."isImproved" IS FALSE AND "campaign-participations"."deletedAt" IS NULL) AS "sharedParticipationsCount"' - ) +const get = async function (id) { + const result = await knex('campaigns') + .select({ + id: 'campaigns.id', + name: 'campaigns.name', + code: 'campaigns.code', + title: 'campaigns.title', + idPixLabel: 'campaigns.idPixLabel', + createdAt: 'campaigns.createdAt', + customLandingPageText: 'campaigns.customLandingPageText', + archivedAt: 'campaigns.archivedAt', + type: 'campaigns.type', + ownerId: 'users.id', + ownerLastName: 'users.lastName', + ownerFirstName: 'users.firstName', + targetProfileId: 'target-profiles.id', + targetProfileDescription: 'target-profiles.description', + targetProfileName: 'target-profiles.name', + multipleSendings: 'campaigns.multipleSendings', + }) + .select( + knex.raw('ARRAY_AGG("badges"."id") AS "badgeIds"'), + knex.raw('ARRAY_AGG("stages"."id") AS "stageIds"'), + knex.raw( + '(SELECT COUNT(*) from "campaign-participations" WHERE "campaign-participations"."campaignId" = "campaigns"."id" AND "campaign-participations"."isImproved" IS FALSE AND "campaign-participations"."deletedAt" IS NULL) AS "participationsCount"' + ), + knex.raw( + '(SELECT COUNT(*) from "campaign-participations" WHERE "campaign-participations"."campaignId" = "campaigns"."id" AND "campaign-participations"."status" = \'SHARED\' AND "campaign-participations"."isImproved" IS FALSE AND "campaign-participations"."deletedAt" IS NULL) AS "sharedParticipationsCount"' ) - .join('users', 'users.id', 'campaigns.ownerId') - .leftJoin('target-profiles', 'target-profiles.id', 'campaigns.targetProfileId') - .leftJoin('badges', 'badges.targetProfileId', 'target-profiles.id') - .leftJoin('stages', 'stages.targetProfileId', 'target-profiles.id') - .where('campaigns.id', id) - .groupBy('campaigns.id', 'users.id', 'target-profiles.id') - .first(); - - if (!result) { - throw new NotFoundError(`La campagne d'id ${id} n'existe pas ou son accès est restreint`); - } - - const campaignReport = new CampaignReport({ ...result, id }); - - if (campaignReport.isAssessment) { - const skills = await campaignRepository.findSkills({ campaignId: id, filterByStatus: 'all' }); - - const targetProfile = new TargetProfileForSpecifier({ - id: result.targetProfileId, - name: result.targetProfileName, - tubeCount: _.uniqBy(skills, 'tubeId').length, - thematicResultCount: _.uniq(result.badgeIds).filter((id) => id).length, - hasStage: result.stageIds.some((stage) => stage), - description: result.targetProfileDescription, - }); - - campaignReport.setTargetProfileInformation(targetProfile); - } - - return campaignReport; - }, - - async findMasteryRatesAndValidatedSkillsCount(campaignId) { - const results = await knex('campaign-participations') - .select('masteryRate', 'validatedSkillsCount') - .where('isImproved', false) - .andWhere('status', SHARED) - .andWhere('deletedAt', null) - .andWhere({ campaignId }); - - const aggregatedResults = { - masteryRates: [], - validatedSkillsCounts: [], - }; - - results.forEach((result) => { - aggregatedResults.masteryRates.push(Number(result.masteryRate)); - aggregatedResults.validatedSkillsCounts.push(Number(result.validatedSkillsCount)); + ) + .join('users', 'users.id', 'campaigns.ownerId') + .leftJoin('target-profiles', 'target-profiles.id', 'campaigns.targetProfileId') + .leftJoin('badges', 'badges.targetProfileId', 'target-profiles.id') + .leftJoin('stages', 'stages.targetProfileId', 'target-profiles.id') + .where('campaigns.id', id) + .groupBy('campaigns.id', 'users.id', 'target-profiles.id') + .first(); + + if (!result) { + throw new NotFoundError(`La campagne d'id ${id} n'existe pas ou son accès est restreint`); + } + + const campaignReport = new CampaignReport({ ...result, id }); + + if (campaignReport.isAssessment) { + const skills = await campaignRepository.findSkills({ campaignId: id, filterByStatus: 'all' }); + + const targetProfile = new TargetProfileForSpecifier({ + id: result.targetProfileId, + name: result.targetProfileName, + tubeCount: _.uniqBy(skills, 'tubeId').length, + thematicResultCount: _.uniq(result.badgeIds).filter((id) => id).length, + hasStage: result.stageIds.some((stage) => stage), + description: result.targetProfileDescription, }); - return aggregatedResults; - }, - - async findPaginatedFilteredByOrganizationId({ organizationId, filter, page, userId }) { - const query = knex('campaigns') - .distinct('campaigns.id') - .select( - 'campaigns.*', - 'users.id AS "ownerId"', - 'users.firstName AS ownerFirstName', - 'users.lastName AS ownerLastName', - knex.raw( - 'COUNT(*) FILTER (WHERE "campaign-participations"."id" IS NOT NULL AND "campaign-participations"."isImproved" IS FALSE AND "campaign-participations"."deletedAt" IS NULL) OVER (partition by "campaigns"."id") AS "participationsCount"' - ), - knex.raw( - 'COUNT(*) FILTER (WHERE "campaign-participations"."id" IS NOT NULL AND "campaign-participations"."status" = \'SHARED\' AND "campaign-participations"."isImproved" IS FALSE AND "campaign-participations"."deletedAt" IS NULL) OVER (partition by "campaigns"."id") AS "sharedParticipationsCount"' - ) + campaignReport.setTargetProfileInformation(targetProfile); + } + + return campaignReport; +}; + +const findMasteryRatesAndValidatedSkillsCount = async function (campaignId) { + const results = await knex('campaign-participations') + .select('masteryRate', 'validatedSkillsCount') + .where('isImproved', false) + .andWhere('status', SHARED) + .andWhere('deletedAt', null) + .andWhere({ campaignId }); + + const aggregatedResults = { + masteryRates: [], + validatedSkillsCounts: [], + }; + + results.forEach((result) => { + aggregatedResults.masteryRates.push(Number(result.masteryRate)); + aggregatedResults.validatedSkillsCounts.push(Number(result.validatedSkillsCount)); + }); + + return aggregatedResults; +}; + +const findPaginatedFilteredByOrganizationId = async function ({ organizationId, filter, page, userId }) { + const query = knex('campaigns') + .distinct('campaigns.id') + .select( + 'campaigns.*', + 'users.id AS "ownerId"', + 'users.firstName AS ownerFirstName', + 'users.lastName AS ownerLastName', + knex.raw( + 'COUNT(*) FILTER (WHERE "campaign-participations"."id" IS NOT NULL AND "campaign-participations"."isImproved" IS FALSE AND "campaign-participations"."deletedAt" IS NULL) OVER (partition by "campaigns"."id") AS "participationsCount"' + ), + knex.raw( + 'COUNT(*) FILTER (WHERE "campaign-participations"."id" IS NOT NULL AND "campaign-participations"."status" = \'SHARED\' AND "campaign-participations"."isImproved" IS FALSE AND "campaign-participations"."deletedAt" IS NULL) OVER (partition by "campaigns"."id") AS "sharedParticipationsCount"' ) - .join('users', 'users.id', 'campaigns.ownerId') - .leftJoin('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') - .where('campaigns.organizationId', organizationId) - .modify(_setSearchFiltersForQueryBuilder, filter, userId) - .orderBy('campaigns.createdAt', 'DESC'); - - const { results, pagination } = await fetchPage(query, page); - const atLeastOneCampaign = await knex('campaigns').select('id').where({ organizationId }).first(1); - const hasCampaigns = Boolean(atLeastOneCampaign); - - const campaignReports = results.map((result) => new CampaignReport(result)); - return { models: campaignReports, meta: { ...pagination, hasCampaigns } }; - }, + ) + .join('users', 'users.id', 'campaigns.ownerId') + .leftJoin('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') + .where('campaigns.organizationId', organizationId) + .modify(_setSearchFiltersForQueryBuilder, filter, userId) + .orderBy('campaigns.createdAt', 'DESC'); + + const { results, pagination } = await fetchPage(query, page); + const atLeastOneCampaign = await knex('campaigns').select('id').where({ organizationId }).first(1); + const hasCampaigns = Boolean(atLeastOneCampaign); + + const campaignReports = results.map((result) => new CampaignReport(result)); + return { models: campaignReports, meta: { ...pagination, hasCampaigns } }; }; + +export { get, findMasteryRatesAndValidatedSkillsCount, findPaginatedFilteredByOrganizationId }; diff --git a/api/lib/infrastructure/repositories/campaign-repository.js b/api/lib/infrastructure/repositories/campaign-repository.js index 1ae99f9b878..bd38a065705 100644 --- a/api/lib/infrastructure/repositories/campaign-repository.js +++ b/api/lib/infrastructure/repositories/campaign-repository.js @@ -1,159 +1,174 @@ -const _ = require('lodash'); -const { NotFoundError } = require('../../domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const Campaign = require('../../domain/models/Campaign.js'); -const skillRepository = require('./skill-repository.js'); +import _ from 'lodash'; +import { NotFoundError } from '../../domain/errors.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { Campaign } from '../../domain/models/Campaign.js'; +import * as skillRepository from './skill-repository.js'; const CAMPAIGNS_TABLE = 'campaigns'; -module.exports = { - async isCodeAvailable(code) { - return !(await knex('campaigns').first('id').where({ code })); - }, - - async getByCode(code) { - const campaign = await knex('campaigns').first().where({ code }); - if (!campaign) return null; - return new Campaign({ ...campaign, organization: { id: campaign.organizationId } }); - }, - - async get(id) { - const campaign = await knex('campaigns').where({ id }).first(); - if (!campaign) { - throw new NotFoundError(`Not found campaign for ID ${id}`); - } - return new Campaign({ - ...campaign, - organization: { id: campaign.organizationId }, - targetProfile: { id: campaign.targetProfileId }, - creator: { id: campaign.creatorId }, - }); - }, - - async save(campaign) { - const trx = await knex.transaction(); - const campaignAttributes = _.pick(campaign, [ - 'name', - 'code', - 'title', - 'type', - 'idPixLabel', - 'customLandingPageText', - 'creatorId', - 'ownerId', - 'organizationId', - 'targetProfileId', - 'multipleSendings', - ]); - try { - const [createdCampaignDTO] = await trx(CAMPAIGNS_TABLE).insert(campaignAttributes).returning('*'); - const createdCampaign = new Campaign(createdCampaignDTO); - if (createdCampaign.isAssessment()) { - const cappedTubes = await trx('target-profile_tubes') - .select('tubeId', 'level') - .where('targetProfileId', campaignAttributes.targetProfileId); - const skillData = []; - for (const cappedTube of cappedTubes) { - const allLevelSkills = await skillRepository.findActiveByTubeId(cappedTube.tubeId); - const rightLevelSkills = allLevelSkills.filter((skill) => skill.difficulty <= cappedTube.level); - skillData.push(...rightLevelSkills.map((skill) => ({ skillId: skill.id, campaignId: createdCampaign.id }))); - } - await trx.batchInsert('campaign_skills', skillData); +const isCodeAvailable = async function (code) { + return !(await knex('campaigns').first('id').where({ code })); +}; + +const getByCode = async function (code) { + const campaign = await knex('campaigns').first().where({ code }); + if (!campaign) return null; + return new Campaign({ ...campaign, organization: { id: campaign.organizationId } }); +}; + +const get = async function (id) { + const campaign = await knex('campaigns').where({ id }).first(); + if (!campaign) { + throw new NotFoundError(`Not found campaign for ID ${id}`); + } + return new Campaign({ + ...campaign, + organization: { id: campaign.organizationId }, + targetProfile: { id: campaign.targetProfileId }, + creator: { id: campaign.creatorId }, + }); +}; + +const save = async function (campaign, dependencies = { skillRepository }) { + const trx = await knex.transaction(); + const campaignAttributes = _.pick(campaign, [ + 'name', + 'code', + 'title', + 'type', + 'idPixLabel', + 'customLandingPageText', + 'creatorId', + 'ownerId', + 'organizationId', + 'targetProfileId', + 'multipleSendings', + ]); + try { + const [createdCampaignDTO] = await trx(CAMPAIGNS_TABLE).insert(campaignAttributes).returning('*'); + const createdCampaign = new Campaign(createdCampaignDTO); + if (createdCampaign.isAssessment()) { + const cappedTubes = await trx('target-profile_tubes') + .select('tubeId', 'level') + .where('targetProfileId', campaignAttributes.targetProfileId); + const skillData = []; + for (const cappedTube of cappedTubes) { + const allLevelSkills = await dependencies.skillRepository.findActiveByTubeId(cappedTube.tubeId); + const rightLevelSkills = allLevelSkills.filter((skill) => skill.difficulty <= cappedTube.level); + skillData.push(...rightLevelSkills.map((skill) => ({ skillId: skill.id, campaignId: createdCampaign.id }))); } - await trx.commit(); - return createdCampaign; - } catch (err) { - await trx.rollback(); - throw err; + await trx.batchInsert('campaign_skills', skillData); } - }, - - async update(campaign) { - const editedAttributes = _.pick(campaign, [ - 'name', - 'title', - 'customLandingPageText', - 'archivedAt', - 'archivedBy', - 'ownerId', - ]); - - const [editedCampaign] = await knex('campaigns').update(editedAttributes).where({ id: campaign.id }).returning('*'); - - return new Campaign(editedCampaign); - }, - - async checkIfUserOrganizationHasAccessToCampaign(campaignId, userId) { - const campaign = await knex('campaigns') - .innerJoin('memberships', 'memberships.organizationId', 'campaigns.organizationId') - .innerJoin('organizations', 'organizations.id', 'campaigns.organizationId') - .where({ 'campaigns.id': campaignId, 'memberships.userId': userId, 'memberships.disabledAt': null }) - .first('campaigns.id'); - return Boolean(campaign); - }, - - async checkIfCampaignIsArchived(campaignId) { - const { archivedAt } = await knex('campaigns').where({ id: campaignId }).first('archivedAt'); - return Boolean(archivedAt); - }, - - async getCampaignTitleByCampaignParticipationId(campaignParticipationId) { - const campaign = await knex('campaigns') - .select('title') - .join('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') - .where({ 'campaign-participations.id': campaignParticipationId }) - .first(); - - if (!campaign) return null; - return campaign.title; - }, - - async getCampaignCodeByCampaignParticipationId(campaignParticipationId) { - const campaign = await knex('campaigns') - .select('code') - .join('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') - .where({ 'campaign-participations.id': campaignParticipationId }) - .first(); - - if (!campaign) return null; - return campaign.code; - }, - - async getCampaignIdByCampaignParticipationId(campaignParticipationId) { - const campaign = await knex('campaigns') - .select('campaigns.id') - .join('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') - .where({ 'campaign-participations.id': campaignParticipationId }) - .first(); - - if (!campaign) return null; - return campaign.id; - }, - - async findSkillIds({ campaignId, domainTransaction, filterByStatus = 'operative' }) { - if (filterByStatus === 'all') { - return _findSkillIds({ campaignId, domainTransaction }); - } - const skills = await this.findSkills({ campaignId, domainTransaction, filterByStatus }); - return skills.map(({ id }) => id); - }, - - findSkills({ campaignId, domainTransaction, filterByStatus }) { - return _findSkills({ campaignId, domainTransaction, filterByStatus }); - }, - - async findSkillsByCampaignParticipationId({ campaignParticipationId, domainTransaction }) { - const knexConn = domainTransaction?.knexTransaction ?? knex; - const [campaignId] = await knexConn('campaign-participations') - .where({ id: campaignParticipationId }) - .pluck('campaignId'); - return this.findSkills({ campaignId }); - }, - - async findSkillIdsByCampaignParticipationId({ campaignParticipationId, domainTransaction }) { - const skills = await this.findSkillsByCampaignParticipationId({ campaignParticipationId, domainTransaction }); - return skills.map(({ id }) => id); - }, + await trx.commit(); + return createdCampaign; + } catch (err) { + await trx.rollback(); + throw err; + } +}; + +const update = async function (campaign) { + const editedAttributes = _.pick(campaign, [ + 'name', + 'title', + 'customLandingPageText', + 'archivedAt', + 'archivedBy', + 'ownerId', + ]); + + const [editedCampaign] = await knex('campaigns').update(editedAttributes).where({ id: campaign.id }).returning('*'); + + return new Campaign(editedCampaign); +}; + +const checkIfUserOrganizationHasAccessToCampaign = async function (campaignId, userId) { + const campaign = await knex('campaigns') + .innerJoin('memberships', 'memberships.organizationId', 'campaigns.organizationId') + .innerJoin('organizations', 'organizations.id', 'campaigns.organizationId') + .where({ 'campaigns.id': campaignId, 'memberships.userId': userId, 'memberships.disabledAt': null }) + .first('campaigns.id'); + return Boolean(campaign); +}; + +const checkIfCampaignIsArchived = async function (campaignId) { + const { archivedAt } = await knex('campaigns').where({ id: campaignId }).first('archivedAt'); + return Boolean(archivedAt); +}; + +const getCampaignTitleByCampaignParticipationId = async function (campaignParticipationId) { + const campaign = await knex('campaigns') + .select('title') + .join('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') + .where({ 'campaign-participations.id': campaignParticipationId }) + .first(); + + if (!campaign) return null; + return campaign.title; +}; + +const getCampaignCodeByCampaignParticipationId = async function (campaignParticipationId) { + const campaign = await knex('campaigns') + .select('code') + .join('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') + .where({ 'campaign-participations.id': campaignParticipationId }) + .first(); + + if (!campaign) return null; + return campaign.code; +}; + +const getCampaignIdByCampaignParticipationId = async function (campaignParticipationId) { + const campaign = await knex('campaigns') + .select('campaigns.id') + .join('campaign-participations', 'campaign-participations.campaignId', 'campaigns.id') + .where({ 'campaign-participations.id': campaignParticipationId }) + .first(); + + if (!campaign) return null; + return campaign.id; +}; + +const findSkillIds = async function ({ campaignId, domainTransaction, filterByStatus = 'operative' }) { + if (filterByStatus === 'all') { + return _findSkillIds({ campaignId, domainTransaction }); + } + const skills = await this.findSkills({ campaignId, domainTransaction, filterByStatus }); + return skills.map(({ id }) => id); +}; + +const findSkills = function ({ campaignId, domainTransaction, filterByStatus }) { + return _findSkills({ campaignId, domainTransaction, filterByStatus }); +}; + +const findSkillsByCampaignParticipationId = async function ({ campaignParticipationId, domainTransaction }) { + const knexConn = domainTransaction?.knexTransaction ?? knex; + const [campaignId] = await knexConn('campaign-participations') + .where({ id: campaignParticipationId }) + .pluck('campaignId'); + return this.findSkills({ campaignId }); +}; + +const findSkillIdsByCampaignParticipationId = async function ({ campaignParticipationId, domainTransaction }) { + const skills = await this.findSkillsByCampaignParticipationId({ campaignParticipationId, domainTransaction }); + return skills.map(({ id }) => id); +}; + +export { + isCodeAvailable, + getByCode, + get, + save, + update, + checkIfUserOrganizationHasAccessToCampaign, + checkIfCampaignIsArchived, + getCampaignTitleByCampaignParticipationId, + getCampaignCodeByCampaignParticipationId, + getCampaignIdByCampaignParticipationId, + findSkillIds, + findSkills, + findSkillsByCampaignParticipationId, + findSkillIdsByCampaignParticipationId, }; async function _findSkills({ campaignId, domainTransaction, filterByStatus = 'operative' }) { diff --git a/api/lib/infrastructure/repositories/campaign-to-join-repository.js b/api/lib/infrastructure/repositories/campaign-to-join-repository.js index 2b9d7596471..28143fd980b 100644 --- a/api/lib/infrastructure/repositories/campaign-to-join-repository.js +++ b/api/lib/infrastructure/repositories/campaign-to-join-repository.js @@ -1,61 +1,61 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignToJoin = require('../../domain/read-models/CampaignToJoin.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignToJoin } from '../../domain/read-models/CampaignToJoin.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { DomainTransaction } from '../DomainTransaction.js'; -module.exports = { - async get(id, domainTransaction = DomainTransaction.emptyTransaction()) { - const knexConn = domainTransaction.knexTransaction || knex; - const result = await knexConn('campaigns') - .select('campaigns.*') - .select({ - organizationId: 'organizations.id', - organizationName: 'organizations.name', - organizationType: 'organizations.type', - organizationLogoUrl: 'organizations.logoUrl', - organizationIsManagingStudents: 'organizations.isManagingStudents', - organizationShowNPS: 'organizations.showNPS', - organizationFormNPSUrl: 'organizations.formNPSUrl', - targetProfileName: 'target-profiles.name', - targetProfileImageUrl: 'target-profiles.imageUrl', - }) - .join('organizations', 'organizations.id', 'campaigns.organizationId') - .leftJoin('target-profiles', 'target-profiles.id', 'campaigns.targetProfileId') - .where('campaigns.id', id) - .first(); +const get = async function (id, domainTransaction = DomainTransaction.emptyTransaction()) { + const knexConn = domainTransaction.knexTransaction || knex; + const result = await knexConn('campaigns') + .select('campaigns.*') + .select({ + organizationId: 'organizations.id', + organizationName: 'organizations.name', + organizationType: 'organizations.type', + organizationLogoUrl: 'organizations.logoUrl', + organizationIsManagingStudents: 'organizations.isManagingStudents', + organizationShowNPS: 'organizations.showNPS', + organizationFormNPSUrl: 'organizations.formNPSUrl', + targetProfileName: 'target-profiles.name', + targetProfileImageUrl: 'target-profiles.imageUrl', + }) + .join('organizations', 'organizations.id', 'campaigns.organizationId') + .leftJoin('target-profiles', 'target-profiles.id', 'campaigns.targetProfileId') + .where('campaigns.id', id) + .first(); - if (!result) { - throw new NotFoundError(`La campagne d'id ${id} n'existe pas ou son accès est restreint`); - } + if (!result) { + throw new NotFoundError(`La campagne d'id ${id} n'existe pas ou son accès est restreint`); + } - return new CampaignToJoin(result); - }, + return new CampaignToJoin(result); +}; - async getByCode(code) { - const result = await knex('campaigns') - .select('campaigns.*') - .select({ - organizationId: 'organizations.id', - organizationName: 'organizations.name', - organizationType: 'organizations.type', - organizationLogoUrl: 'organizations.logoUrl', - organizationIsManagingStudents: 'organizations.isManagingStudents', - organizationShowNPS: 'organizations.showNPS', - organizationFormNPSUrl: 'organizations.formNPSUrl', - targetProfileName: 'target-profiles.name', - targetProfileImageUrl: 'target-profiles.imageUrl', - targetProfileIsSimplifiedAccess: 'target-profiles.isSimplifiedAccess', - identityProvider: 'organizations.identityProviderForCampaigns', - }) - .join('organizations', 'organizations.id', 'campaigns.organizationId') - .leftJoin('target-profiles', 'target-profiles.id', 'campaigns.targetProfileId') - .where('campaigns.code', code) - .first(); +const getByCode = async function (code) { + const result = await knex('campaigns') + .select('campaigns.*') + .select({ + organizationId: 'organizations.id', + organizationName: 'organizations.name', + organizationType: 'organizations.type', + organizationLogoUrl: 'organizations.logoUrl', + organizationIsManagingStudents: 'organizations.isManagingStudents', + organizationShowNPS: 'organizations.showNPS', + organizationFormNPSUrl: 'organizations.formNPSUrl', + targetProfileName: 'target-profiles.name', + targetProfileImageUrl: 'target-profiles.imageUrl', + targetProfileIsSimplifiedAccess: 'target-profiles.isSimplifiedAccess', + identityProvider: 'organizations.identityProviderForCampaigns', + }) + .join('organizations', 'organizations.id', 'campaigns.organizationId') + .leftJoin('target-profiles', 'target-profiles.id', 'campaigns.targetProfileId') + .where('campaigns.code', code) + .first(); - if (!result) { - throw new NotFoundError(`La campagne au code ${code} n'existe pas ou son accès est restreint`); - } + if (!result) { + throw new NotFoundError(`La campagne au code ${code} n'existe pas ou son accès est restreint`); + } - return new CampaignToJoin(result); - }, + return new CampaignToJoin(result); }; + +export { get, getByCode }; diff --git a/api/lib/infrastructure/repositories/campaign/campaign-for-archiving-repository.js b/api/lib/infrastructure/repositories/campaign/campaign-for-archiving-repository.js index 5865076ecf0..bf53ebe0b21 100644 --- a/api/lib/infrastructure/repositories/campaign/campaign-for-archiving-repository.js +++ b/api/lib/infrastructure/repositories/campaign/campaign-for-archiving-repository.js @@ -1,8 +1,7 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const Campaign = require('../../../domain/models/CampaignForArchiving.js'); -const knexUtils = require('../../utils/knex-utils.js'); - -const { NotFoundError, UserNotFoundError } = require('../../../domain/errors.js'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { CampaignForArchiving } from '../../../domain/models/CampaignForArchiving.js'; +import * as knexUtils from '../../utils/knex-utils.js'; +import { NotFoundError, UserNotFoundError } from '../../../domain/errors.js'; async function save(campaign) { try { @@ -19,7 +18,7 @@ async function getByCode(code) { if (!row) { throw new NotFoundError('Campaign Not Found'); } - return new Campaign(row); + return new CampaignForArchiving(row); } async function get(id) { @@ -27,11 +26,7 @@ async function get(id) { if (!row) { throw new NotFoundError(); } - return new Campaign(row); + return new CampaignForArchiving(row); } -module.exports = { - save, - getByCode, - get, -}; +export { save, getByCode, get }; diff --git a/api/lib/infrastructure/repositories/campaign/target-profile-for-specifier-repository.js b/api/lib/infrastructure/repositories/campaign/target-profile-for-specifier-repository.js index df2e2901096..e26d0d19cdb 100644 --- a/api/lib/infrastructure/repositories/campaign/target-profile-for-specifier-repository.js +++ b/api/lib/infrastructure/repositories/campaign/target-profile-for-specifier-repository.js @@ -1,6 +1,6 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const TargetProfileForSpecifier = require('../../../domain/read-models/campaign/TargetProfileForSpecifier.js'); -const bluebird = require('bluebird'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { TargetProfileForSpecifier } from '../../../domain/read-models/campaign/TargetProfileForSpecifier.js'; +import bluebird from 'bluebird'; async function availableForOrganization(organizationId) { const targetProfileRows = await _fetchTargetProfiles(organizationId); @@ -51,6 +51,4 @@ async function _buildTargetProfileForSpecifier(row) { }); } -module.exports = { - availableForOrganization, -}; +export { availableForOrganization }; diff --git a/api/lib/infrastructure/repositories/campaigns-administration/campaign-repository.js b/api/lib/infrastructure/repositories/campaigns-administration/campaign-repository.js index 07ca2bb3198..215ab3d3c8a 100644 --- a/api/lib/infrastructure/repositories/campaigns-administration/campaign-repository.js +++ b/api/lib/infrastructure/repositories/campaigns-administration/campaign-repository.js @@ -1,10 +1,10 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); +import { knex } from '../../../../db/knex-database-connection.js'; -module.exports = { - archiveCampaigns(campaignIds, userId) { - return knex('campaigns').whereNull('archivedAt').whereInArray('id', campaignIds).update({ - archivedBy: userId, - archivedAt: new Date(), - }); - }, +const archiveCampaigns = function (campaignIds, userId) { + return knex('campaigns').whereNull('archivedAt').whereInArray('id', campaignIds).update({ + archivedBy: userId, + archivedAt: new Date(), + }); }; + +export { archiveCampaigns }; diff --git a/api/lib/infrastructure/repositories/certifiable-badge-acquisition-repository.js b/api/lib/infrastructure/repositories/certifiable-badge-acquisition-repository.js index d763e22bcc5..71f4b1c1f47 100644 --- a/api/lib/infrastructure/repositories/certifiable-badge-acquisition-repository.js +++ b/api/lib/infrastructure/repositories/certifiable-badge-acquisition-repository.js @@ -1,61 +1,61 @@ -const CertifiableBadgeAcquisition = require('../../domain/models/CertifiableBadgeAcquisition.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const _ = require('lodash'); +import { CertifiableBadgeAcquisition } from '../../domain/models/CertifiableBadgeAcquisition.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import _ from 'lodash'; const BADGE_ACQUISITIONS_TABLE = 'badge-acquisitions'; -module.exports = { - async findHighestCertifiable({ userId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction.knexTransaction || knex; - const certifiableBadgeAcquisitions = await knexConn(BADGE_ACQUISITIONS_TABLE) - .select({ - badgeId: 'badges.id', - badgeKey: 'badges.key', - campaignId: 'campaign-participations.campaignId', - complementaryCertificationId: 'complementary-certifications.id', - complementaryCertificationKey: 'complementary-certifications.key', - complementaryCertificationBadgeId: 'complementary-certification-badges.id', - complementaryCertificationBadgeImageUrl: 'complementary-certification-badges.imageUrl', - complementaryCertificationBadgeLabel: 'complementary-certification-badges.label', - complementaryCertificationBadgeLevel: 'complementary-certification-badges.level', - }) - .join('badges', 'badges.id', 'badge-acquisitions.badgeId') - .join('complementary-certification-badges', 'badges.id', 'complementary-certification-badges.badgeId') - .join( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-badges.complementaryCertificationId' - ) - .join('campaign-participations', 'campaign-participations.id', 'badge-acquisitions.campaignParticipationId') - .where({ - 'badge-acquisitions.userId': userId, - 'badges.isCertifiable': true, - }) - .whereRaw( - `"badge-acquisitions"."createdAt" = - (select max(ba."createdAt") from "complementary-certification-badges" ccb - join "badges" b on ccb."badgeId" = b.id - join "badge-acquisitions" ba on ba."badgeId" = b.id - where "complementary-certification-badges"."complementaryCertificationId" = ccb."complementaryCertificationId" - and ba."userId" = ? and b."isCertifiable" = true) - `, - userId - ); +const findHighestCertifiable = async function ({ userId, domainTransaction = DomainTransaction.emptyTransaction() }) { + const knexConn = domainTransaction.knexTransaction || knex; + const certifiableBadgeAcquisitions = await knexConn(BADGE_ACQUISITIONS_TABLE) + .select({ + badgeId: 'badges.id', + badgeKey: 'badges.key', + campaignId: 'campaign-participations.campaignId', + complementaryCertificationId: 'complementary-certifications.id', + complementaryCertificationKey: 'complementary-certifications.key', + complementaryCertificationBadgeId: 'complementary-certification-badges.id', + complementaryCertificationBadgeImageUrl: 'complementary-certification-badges.imageUrl', + complementaryCertificationBadgeLabel: 'complementary-certification-badges.label', + complementaryCertificationBadgeLevel: 'complementary-certification-badges.level', + }) + .join('badges', 'badges.id', 'badge-acquisitions.badgeId') + .join('complementary-certification-badges', 'badges.id', 'complementary-certification-badges.badgeId') + .join( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-badges.complementaryCertificationId' + ) + .join('campaign-participations', 'campaign-participations.id', 'badge-acquisitions.campaignParticipationId') + .where({ + 'badge-acquisitions.userId': userId, + 'badges.isCertifiable': true, + }) + .whereRaw( + `"badge-acquisitions"."createdAt" = + (select max(ba."createdAt") from "complementary-certification-badges" ccb + join "badges" b on ccb."badgeId" = b.id + join "badge-acquisitions" ba on ba."badgeId" = b.id + where "complementary-certification-badges"."complementaryCertificationId" = ccb."complementaryCertificationId" + and ba."userId" = ? and b."isCertifiable" = true) + `, + userId + ); - const highestCertifiableBadgeAcquisitionByComplementaryCertificationId = _(certifiableBadgeAcquisitions) - .groupBy('complementaryCertificationId') - .values() - .map((certifiableBadgeAcquisitionByComplementaryCertifications) => - _.maxBy(certifiableBadgeAcquisitionByComplementaryCertifications, 'complementaryCertificationBadgeLevel') - ) - .flatten() - .value(); + const highestCertifiableBadgeAcquisitionByComplementaryCertificationId = _(certifiableBadgeAcquisitions) + .groupBy('complementaryCertificationId') + .values() + .map((certifiableBadgeAcquisitionByComplementaryCertifications) => + _.maxBy(certifiableBadgeAcquisitionByComplementaryCertifications, 'complementaryCertificationBadgeLevel') + ) + .flatten() + .value(); - return _toDomain(highestCertifiableBadgeAcquisitionByComplementaryCertificationId); - }, + return _toDomain(highestCertifiableBadgeAcquisitionByComplementaryCertificationId); }; +export { findHighestCertifiable }; + function _toDomain(certifiableBadgeAcquisitionsDto) { return certifiableBadgeAcquisitionsDto.map( (certifiableBadgeAcquisitionDto) => new CertifiableBadgeAcquisition(certifiableBadgeAcquisitionDto) diff --git a/api/lib/infrastructure/repositories/certifiable-profile-for-learning-content-repository.js b/api/lib/infrastructure/repositories/certifiable-profile-for-learning-content-repository.js index 4c5fc230a40..a92ecf616bb 100644 --- a/api/lib/infrastructure/repositories/certifiable-profile-for-learning-content-repository.js +++ b/api/lib/infrastructure/repositories/certifiable-profile-for-learning-content-repository.js @@ -1,24 +1,24 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const CertifiableProfileForLearningContent = require('../../domain/models/CertifiableProfileForLearningContent.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { CertifiableProfileForLearningContent } from '../../domain/models/CertifiableProfileForLearningContent.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; -module.exports = { - async get({ id, profileDate, learningContent }) { - const knowledgeElements = await knowledgeElementRepository.findUniqByUserId({ userId: id, limitDate: profileDate }); - const answerIds = _.map(knowledgeElements, 'answerId'); - const answerAndChallengeIds = await knex - .select('answers.id', 'answers.challengeId') - .from('answers') - .whereIn('id', answerIds); - const answerAndChallengeIdsByAnswerId = _.keyBy(answerAndChallengeIds, 'id'); +const get = async function ({ id, profileDate, learningContent }) { + const knowledgeElements = await knowledgeElementRepository.findUniqByUserId({ userId: id, limitDate: profileDate }); + const answerIds = _.map(knowledgeElements, 'answerId'); + const answerAndChallengeIds = await knex + .select('answers.id', 'answers.challengeId') + .from('answers') + .whereIn('id', answerIds); + const answerAndChallengeIdsByAnswerId = _.keyBy(answerAndChallengeIds, 'id'); - return new CertifiableProfileForLearningContent({ - userId: id, - profileDate, - learningContent, - knowledgeElements, - answerAndChallengeIdsByAnswerId, - }); - }, + return new CertifiableProfileForLearningContent({ + userId: id, + profileDate, + learningContent, + knowledgeElements, + answerAndChallengeIdsByAnswerId, + }); }; + +export { get }; diff --git a/api/lib/infrastructure/repositories/certificate-repository.js b/api/lib/infrastructure/repositories/certificate-repository.js index 21e0c7bf21d..1f98ff8ddef 100644 --- a/api/lib/infrastructure/repositories/certificate-repository.js +++ b/api/lib/infrastructure/repositories/certificate-repository.js @@ -1,128 +1,129 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const PrivateCertificate = require('../../domain/models/PrivateCertificate.js'); -const ShareableCertificate = require('../../domain/models/ShareableCertificate.js'); -const CertificationAttestation = require('../../domain/models/CertificationAttestation.js'); -const CertifiedBadge = require('../../../lib/domain/read-models/CertifiedBadge.js'); -const { NotFoundError } = require('../../../lib/domain/errors.js'); -const competenceTreeRepository = require('./competence-tree-repository.js'); -const ResultCompetenceTree = require('../../domain/models/ResultCompetenceTree.js'); -const CompetenceMark = require('../../domain/models/CompetenceMark.js'); -const AssessmentResult = require('../../domain/models/AssessmentResult.js'); - -module.exports = { - async getPrivateCertificate(id, { locale } = {}) { - const certificationCourseDTO = await _selectPrivateCertificates() - .where('certification-courses.id', '=', id) - .groupBy('certification-courses.id', 'sessions.id', 'assessment-results.id') - .where('certification-courses.isPublished', true) - .where('certification-courses.isCancelled', false) - .where('assessment-results.status', AssessmentResult.status.VALIDATED) - .first(); - - if (!certificationCourseDTO) { - throw new NotFoundError(`Certificate not found for ID ${id}`); - } - - const certifiedBadges = await _getCertifiedBadges(id); - - const competenceTree = await competenceTreeRepository.get({ locale }); - - return _toDomainForPrivateCertificate({ +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { PrivateCertificate } from '../../domain/models/PrivateCertificate.js'; +import { ShareableCertificate } from '../../domain/models/ShareableCertificate.js'; +import { CertificationAttestation } from '../../domain/models/CertificationAttestation.js'; +import { CertifiedBadge } from '../../../lib/domain/read-models/CertifiedBadge.js'; +import { NotFoundError } from '../../../lib/domain/errors.js'; +import * as competenceTreeRepository from './competence-tree-repository.js'; +import { ResultCompetenceTree } from '../../domain/models/ResultCompetenceTree.js'; +import { CompetenceMark } from '../../domain/models/CompetenceMark.js'; +import { AssessmentResult } from '../../domain/models/AssessmentResult.js'; + +const getPrivateCertificate = async function (id, { locale } = {}) { + const certificationCourseDTO = await _selectPrivateCertificates() + .where('certification-courses.id', '=', id) + .groupBy('certification-courses.id', 'sessions.id', 'assessment-results.id') + .where('certification-courses.isPublished', true) + .where('certification-courses.isCancelled', false) + .where('assessment-results.status', AssessmentResult.status.VALIDATED) + .first(); + + if (!certificationCourseDTO) { + throw new NotFoundError(`Certificate not found for ID ${id}`); + } + + const certifiedBadges = await _getCertifiedBadges(id); + + const competenceTree = await competenceTreeRepository.get({ locale }); + + return _toDomainForPrivateCertificate({ + certificationCourseDTO, + competenceTree, + certifiedBadges, + }); +}; + +const findPrivateCertificatesByUserId = async function ({ userId }) { + const certificationCourseDTOs = await _selectPrivateCertificates() + .where('certification-courses.userId', '=', userId) + .groupBy('certification-courses.id', 'sessions.id', 'assessment-results.id') + .orderBy('certification-courses.createdAt', 'DESC'); + + const privateCertificates = certificationCourseDTOs.map((certificationCourseDTO) => + _toDomainForPrivateCertificate({ certificationCourseDTO, - competenceTree, - certifiedBadges, - }); - }, - - async findPrivateCertificatesByUserId({ userId }) { - const certificationCourseDTOs = await _selectPrivateCertificates() - .where('certification-courses.userId', '=', userId) - .groupBy('certification-courses.id', 'sessions.id', 'assessment-results.id') - .orderBy('certification-courses.createdAt', 'DESC'); - - const privateCertificates = certificationCourseDTOs.map((certificationCourseDTO) => - _toDomainForPrivateCertificate({ - certificationCourseDTO, - }) - ); - return privateCertificates; - }, - - async getShareableCertificateByVerificationCode(verificationCode, { locale } = {}) { - const shareableCertificateDTO = await _selectShareableCertificates() - .groupBy('certification-courses.id', 'sessions.id', 'assessment-results.id') - .where({ verificationCode }) - .first(); - - if (!shareableCertificateDTO) { - throw new NotFoundError(`There is no certification course with verification code "${verificationCode}"`); - } - - const competenceTree = await competenceTreeRepository.get({ locale }); - - const certifiedBadges = await _getCertifiedBadges(shareableCertificateDTO.id); - - return _toDomainForShareableCertificate({ shareableCertificateDTO, competenceTree, certifiedBadges }); - }, - - async getCertificationAttestation(id) { - const certificationCourseDTO = await _selectCertificationAttestations() - .where('certification-courses.id', '=', id) - .groupBy('certification-courses.id', 'sessions.id', 'assessment-results.id') - .first(); - - if (!certificationCourseDTO) { - throw new NotFoundError(`There is no certification course with id "${id}"`); - } - - const competenceTree = await competenceTreeRepository.get(); - const certifiedBadges = await _getCertifiedBadges(certificationCourseDTO.id); - - return _toDomainForCertificationAttestation({ certificationCourseDTO, competenceTree, certifiedBadges }); - }, - - async findByDivisionForScoIsManagingStudentsOrganization({ organizationId, division }) { - const certificationCourseDTOs = await _selectCertificationAttestations() - .select({ organizationLearnerId: 'view-active-organization-learners.id' }) - .innerJoin('certification-candidates', function () { - this.on({ 'certification-candidates.sessionId': 'certification-courses.sessionId' }).andOn({ - 'certification-candidates.userId': 'certification-courses.userId', - }); - }) - .innerJoin( - 'view-active-organization-learners', - 'view-active-organization-learners.id', - 'certification-candidates.organizationLearnerId' - ) - .innerJoin('organizations', 'organizations.id', 'view-active-organization-learners.organizationId') - .where({ - 'view-active-organization-learners.organizationId': organizationId, - 'view-active-organization-learners.isDisabled': false, - }) - .whereRaw('LOWER("view-active-organization-learners"."division") = ?', division.toLowerCase()) - .whereRaw('"certification-candidates"."userId" = "certification-courses"."userId"') - .whereRaw('"certification-candidates"."sessionId" = "certification-courses"."sessionId"') - .modify(_checkOrganizationIsScoIsManagingStudents) - .groupBy( - 'view-active-organization-learners.id', - 'certification-courses.id', - 'sessions.id', - 'assessment-results.id' - ) - .orderBy('certification-courses.createdAt', 'DESC'); - - const competenceTree = await competenceTreeRepository.get(); - - const mostRecentCertificationsPerOrganizationLearner = - _filterMostRecentCertificationCoursePerOrganizationLearner(certificationCourseDTOs); - return _(mostRecentCertificationsPerOrganizationLearner) - .orderBy(['lastName', 'firstName'], ['asc', 'asc']) - .map((certificationCourseDTO) => { - return _toDomainForCertificationAttestation({ certificationCourseDTO, competenceTree, certifiedBadges: [] }); - }) - .value(); - }, + }) + ); + return privateCertificates; +}; + +const getShareableCertificateByVerificationCode = async function (verificationCode, { locale } = {}) { + const shareableCertificateDTO = await _selectShareableCertificates() + .groupBy('certification-courses.id', 'sessions.id', 'assessment-results.id') + .where({ verificationCode }) + .first(); + + if (!shareableCertificateDTO) { + throw new NotFoundError(`There is no certification course with verification code "${verificationCode}"`); + } + + const competenceTree = await competenceTreeRepository.get({ locale }); + + const certifiedBadges = await _getCertifiedBadges(shareableCertificateDTO.id); + + return _toDomainForShareableCertificate({ shareableCertificateDTO, competenceTree, certifiedBadges }); +}; + +const getCertificationAttestation = async function (id) { + const certificationCourseDTO = await _selectCertificationAttestations() + .where('certification-courses.id', '=', id) + .groupBy('certification-courses.id', 'sessions.id', 'assessment-results.id') + .first(); + + if (!certificationCourseDTO) { + throw new NotFoundError(`There is no certification course with id "${id}"`); + } + + const competenceTree = await competenceTreeRepository.get(); + const certifiedBadges = await _getCertifiedBadges(certificationCourseDTO.id); + + return _toDomainForCertificationAttestation({ certificationCourseDTO, competenceTree, certifiedBadges }); +}; + +const findByDivisionForScoIsManagingStudentsOrganization = async function ({ organizationId, division }) { + const certificationCourseDTOs = await _selectCertificationAttestations() + .select({ organizationLearnerId: 'view-active-organization-learners.id' }) + .innerJoin('certification-candidates', function () { + this.on({ 'certification-candidates.sessionId': 'certification-courses.sessionId' }).andOn({ + 'certification-candidates.userId': 'certification-courses.userId', + }); + }) + .innerJoin( + 'view-active-organization-learners', + 'view-active-organization-learners.id', + 'certification-candidates.organizationLearnerId' + ) + .innerJoin('organizations', 'organizations.id', 'view-active-organization-learners.organizationId') + .where({ + 'view-active-organization-learners.organizationId': organizationId, + 'view-active-organization-learners.isDisabled': false, + }) + .whereRaw('LOWER("view-active-organization-learners"."division") = ?', division.toLowerCase()) + .whereRaw('"certification-candidates"."userId" = "certification-courses"."userId"') + .whereRaw('"certification-candidates"."sessionId" = "certification-courses"."sessionId"') + .modify(_checkOrganizationIsScoIsManagingStudents) + .groupBy('view-active-organization-learners.id', 'certification-courses.id', 'sessions.id', 'assessment-results.id') + .orderBy('certification-courses.createdAt', 'DESC'); + + const competenceTree = await competenceTreeRepository.get(); + + const mostRecentCertificationsPerOrganizationLearner = + _filterMostRecentCertificationCoursePerOrganizationLearner(certificationCourseDTOs); + return _(mostRecentCertificationsPerOrganizationLearner) + .orderBy(['lastName', 'firstName'], ['asc', 'asc']) + .map((certificationCourseDTO) => { + return _toDomainForCertificationAttestation({ certificationCourseDTO, competenceTree, certifiedBadges: [] }); + }) + .value(); +}; + +export { + getPrivateCertificate, + findPrivateCertificatesByUserId, + getShareableCertificateByVerificationCode, + getCertificationAttestation, + findByDivisionForScoIsManagingStudentsOrganization, }; async function _getCertifiedBadges(certificationCourseId) { diff --git a/api/lib/infrastructure/repositories/certification-assessment-repository.js b/api/lib/infrastructure/repositories/certification-assessment-repository.js index 95a79b11145..779983da3e2 100644 --- a/api/lib/infrastructure/repositories/certification-assessment-repository.js +++ b/api/lib/infrastructure/repositories/certification-assessment-repository.js @@ -1,12 +1,12 @@ -const _ = require('lodash'); -const DomainTransaction = require('../DomainTransaction.js'); -const CertificationAssessment = require('../../domain/models/CertificationAssessment.js'); -const CertificationChallengeWithType = require('../../domain/models/CertificationChallengeWithType.js'); -const Answer = require('../../domain/models/Answer.js'); -const challengeRepository = require('./challenge-repository.js'); -const answerStatusDatabaseAdapter = require('../adapters/answer-status-database-adapter.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import _ from 'lodash'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { CertificationAssessment } from '../../domain/models/CertificationAssessment.js'; +import { CertificationChallengeWithType } from '../../domain/models/CertificationChallengeWithType.js'; +import { Answer } from '../../domain/models/Answer.js'; +import * as challengeRepository from './challenge-repository.js'; +import * as answerStatusDatabaseAdapter from '../adapters/answer-status-database-adapter.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../domain/errors.js'; async function _getCertificationChallenges(certificationCourseId, knexConn) { const allChallenges = await challengeRepository.findOperative(); @@ -37,87 +37,87 @@ async function _getCertificationAnswersByDate(certificationAssessmentId, knexCon ); } -module.exports = { - async get(id) { - const certificationAssessmentRows = await knex('assessments') - .join('certification-courses', 'certification-courses.id', 'assessments.certificationCourseId') - .select({ - id: 'assessments.id', - userId: 'assessments.userId', - certificationCourseId: 'certification-courses.id', - createdAt: 'certification-courses.createdAt', - completedAt: 'certification-courses.completedAt', - isV2Certification: 'certification-courses.isV2Certification', - state: 'assessments.state', - }) - .where('assessments.id', '=', id) - .limit(1); - if (!certificationAssessmentRows[0]) { - throw new NotFoundError(`L'assessment de certification ${id} n'existe pas ou son accès est restreint`); - } - const certificationChallenges = await _getCertificationChallenges( - certificationAssessmentRows[0].certificationCourseId, - knex - ); - const certificationAnswersByDate = await _getCertificationAnswersByDate(certificationAssessmentRows[0].id, knex); +const get = async function (id) { + const certificationAssessmentRows = await knex('assessments') + .join('certification-courses', 'certification-courses.id', 'assessments.certificationCourseId') + .select({ + id: 'assessments.id', + userId: 'assessments.userId', + certificationCourseId: 'certification-courses.id', + createdAt: 'certification-courses.createdAt', + completedAt: 'certification-courses.completedAt', + isV2Certification: 'certification-courses.isV2Certification', + state: 'assessments.state', + }) + .where('assessments.id', '=', id) + .limit(1); + if (!certificationAssessmentRows[0]) { + throw new NotFoundError(`L'assessment de certification ${id} n'existe pas ou son accès est restreint`); + } + const certificationChallenges = await _getCertificationChallenges( + certificationAssessmentRows[0].certificationCourseId, + knex + ); + const certificationAnswersByDate = await _getCertificationAnswersByDate(certificationAssessmentRows[0].id, knex); - return new CertificationAssessment({ - ...certificationAssessmentRows[0], - certificationChallenges, - certificationAnswersByDate, - }); - }, + return new CertificationAssessment({ + ...certificationAssessmentRows[0], + certificationChallenges, + certificationAnswersByDate, + }); +}; - async getByCertificationCourseId({ - certificationCourseId, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knexConn = domainTransaction.knexTransaction || knex; - const certificationAssessmentRow = await knexConn('assessments') - .join('certification-courses', 'certification-courses.id', 'assessments.certificationCourseId') - .select({ - id: 'assessments.id', - userId: 'assessments.userId', - certificationCourseId: 'certification-courses.id', - createdAt: 'certification-courses.createdAt', - completedAt: 'certification-courses.completedAt', - isV2Certification: 'certification-courses.isV2Certification', - state: 'assessments.state', - }) - .where('assessments.certificationCourseId', '=', certificationCourseId) - .first(); - if (!certificationAssessmentRow) { - throw new NotFoundError( - `L'assessment de certification avec un certificationCourseId de ${certificationCourseId} n'existe pas ou son accès est restreint` - ); - } - const certificationChallenges = await _getCertificationChallenges( - certificationAssessmentRow.certificationCourseId, - knexConn +const getByCertificationCourseId = async function ({ + certificationCourseId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction || knex; + const certificationAssessmentRow = await knexConn('assessments') + .join('certification-courses', 'certification-courses.id', 'assessments.certificationCourseId') + .select({ + id: 'assessments.id', + userId: 'assessments.userId', + certificationCourseId: 'certification-courses.id', + createdAt: 'certification-courses.createdAt', + completedAt: 'certification-courses.completedAt', + isV2Certification: 'certification-courses.isV2Certification', + state: 'assessments.state', + }) + .where('assessments.certificationCourseId', '=', certificationCourseId) + .first(); + if (!certificationAssessmentRow) { + throw new NotFoundError( + `L'assessment de certification avec un certificationCourseId de ${certificationCourseId} n'existe pas ou son accès est restreint` ); - const certificationAnswersByDate = await _getCertificationAnswersByDate(certificationAssessmentRow.id, knexConn); + } + const certificationChallenges = await _getCertificationChallenges( + certificationAssessmentRow.certificationCourseId, + knexConn + ); + const certificationAnswersByDate = await _getCertificationAnswersByDate(certificationAssessmentRow.id, knexConn); - return new CertificationAssessment({ - ...certificationAssessmentRow, - certificationChallenges, - certificationAnswersByDate, - }); - }, + return new CertificationAssessment({ + ...certificationAssessmentRow, + certificationChallenges, + certificationAnswersByDate, + }); +}; - async save(certificationAssessment) { - for (const challenge of certificationAssessment.certificationChallenges) { - await knex('certification-challenges') - .where({ id: challenge.id }) - .update(_.pick(challenge, ['isNeutralized', 'hasBeenSkippedAutomatically'])); - } - for (const answer of certificationAssessment.certificationAnswersByDate) { - await knex('answers') - .where({ id: answer.id }) - .update({ result: answerStatusDatabaseAdapter.toSQLString(answer.result) }); - } +const save = async function (certificationAssessment) { + for (const challenge of certificationAssessment.certificationChallenges) { + await knex('certification-challenges') + .where({ id: challenge.id }) + .update(_.pick(challenge, ['isNeutralized', 'hasBeenSkippedAutomatically'])); + } + for (const answer of certificationAssessment.certificationAnswersByDate) { + await knex('answers') + .where({ id: answer.id }) + .update({ result: answerStatusDatabaseAdapter.toSQLString(answer.result) }); + } - await knex('assessments') - .where({ certificationCourseId: certificationAssessment.certificationCourseId }) - .update({ state: certificationAssessment.state }); - }, + await knex('assessments') + .where({ certificationCourseId: certificationAssessment.certificationCourseId }) + .update({ state: certificationAssessment.state }); }; + +export { get, getByCertificationCourseId, save }; diff --git a/api/lib/infrastructure/repositories/certification-candidate-for-supervising-repository.js b/api/lib/infrastructure/repositories/certification-candidate-for-supervising-repository.js index 9dead6a9018..3afe3d4fd7b 100644 --- a/api/lib/infrastructure/repositories/certification-candidate-for-supervising-repository.js +++ b/api/lib/infrastructure/repositories/certification-candidate-for-supervising-repository.js @@ -1,34 +1,34 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const CertificationCandidateForSupervising = require('../../domain/models/CertificationCandidateForSupervising.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { CertificationCandidateForSupervising } from '../../domain/models/CertificationCandidateForSupervising.js'; -module.exports = { - async get(certificationCandidateId) { - const result = await knex('certification-candidates') - .select( - 'certification-candidates.*', - 'assessments.state AS assessmentStatus', - 'certification-courses.createdAt AS startDateTime' - ) - .leftJoin('certification-courses', function () { - this.on('certification-courses.sessionId', '=', 'certification-candidates.sessionId'); - this.on('certification-courses.userId', '=', 'certification-candidates.userId'); - }) - .leftJoin('assessments', 'assessments.certificationCourseId', 'certification-courses.id') - .where({ 'certification-candidates.id': certificationCandidateId }) - .first(); - return new CertificationCandidateForSupervising({ ...result }); - }, +const get = async function (certificationCandidateId) { + const result = await knex('certification-candidates') + .select( + 'certification-candidates.*', + 'assessments.state AS assessmentStatus', + 'certification-courses.createdAt AS startDateTime' + ) + .leftJoin('certification-courses', function () { + this.on('certification-courses.sessionId', '=', 'certification-candidates.sessionId'); + this.on('certification-courses.userId', '=', 'certification-candidates.userId'); + }) + .leftJoin('assessments', 'assessments.certificationCourseId', 'certification-courses.id') + .where({ 'certification-candidates.id': certificationCandidateId }) + .first(); + return new CertificationCandidateForSupervising({ ...result }); +}; - async update(certificationCandidateForSupervising) { - const result = await knex('certification-candidates') - .where({ - id: certificationCandidateForSupervising.id, - }) - .update({ authorizedToStart: certificationCandidateForSupervising.authorizedToStart }); +const update = async function (certificationCandidateForSupervising) { + const result = await knex('certification-candidates') + .where({ + id: certificationCandidateForSupervising.id, + }) + .update({ authorizedToStart: certificationCandidateForSupervising.authorizedToStart }); - if (result === 0) { - throw new NotFoundError('Aucun candidat trouvé'); - } - }, + if (result === 0) { + throw new NotFoundError('Aucun candidat trouvé'); + } }; + +export { get, update }; diff --git a/api/lib/infrastructure/repositories/certification-candidate-repository.js b/api/lib/infrastructure/repositories/certification-candidate-repository.js index 2260237cab5..ef3fa56fb7e 100644 --- a/api/lib/infrastructure/repositories/certification-candidate-repository.js +++ b/api/lib/infrastructure/repositories/certification-candidate-repository.js @@ -1,212 +1,231 @@ -const _ = require('lodash'); -const { normalize } = require('../utils/string-utils.js'); -const logger = require('../../infrastructure/logger.js'); -const CertificationCandidateBookshelf = require('../orm-models/CertificationCandidate.js'); -const bookshelfToDomainConverter = require('../../infrastructure/utils/bookshelf-to-domain-converter.js'); -const { PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR } = require('../../../db/pgsql-errors.js'); -const { +import _ from 'lodash'; +import { normalize } from '../utils/string-utils.js'; +import { logger } from '../../infrastructure/logger.js'; +import { BookshelfCertificationCandidate } from '../orm-models/CertificationCandidate.js'; +import * as bookshelfToDomainConverter from '../../infrastructure/utils/bookshelf-to-domain-converter.js'; +import { PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR } from '../../../db/pgsql-errors.js'; + +import { NotFoundError, CertificationCandidateCreationOrUpdateError, CertificationCandidateMultipleUserLinksWithinSessionError, -} = require('../../domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const CertificationCandidate = require('../../domain/models/CertificationCandidate.js'); -const ComplementaryCertification = require('../../domain/models/ComplementaryCertification.js'); -const DomainTransaction = require('../DomainTransaction.js'); - -module.exports = { - async linkToUser({ id, userId }) { - try { - const certificationCandidateBookshelf = new CertificationCandidateBookshelf({ id }); - await certificationCandidateBookshelf.save({ userId }, { patch: true, method: 'update' }); - } catch (bookshelfError) { - if (bookshelfError.code === PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR) { - throw new CertificationCandidateMultipleUserLinksWithinSessionError( - 'A user cannot be linked to several certification candidates within the same session' - ); - } - throw new CertificationCandidateCreationOrUpdateError( - 'An error occurred while linking the certification candidate to a user' +} from '../../domain/errors.js'; + +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationCandidate } from '../../domain/models/CertificationCandidate.js'; +import { ComplementaryCertification } from '../../domain/models/ComplementaryCertification.js'; +import { DomainTransaction } from '../DomainTransaction.js'; + +const linkToUser = async function ({ id, userId }) { + try { + const certificationCandidateBookshelf = new BookshelfCertificationCandidate({ id }); + await certificationCandidateBookshelf.save({ userId }, { patch: true, method: 'update' }); + } catch (bookshelfError) { + if (bookshelfError.code === PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR) { + throw new CertificationCandidateMultipleUserLinksWithinSessionError( + 'A user cannot be linked to several certification candidates within the same session' ); } - }, + throw new CertificationCandidateCreationOrUpdateError( + 'An error occurred while linking the certification candidate to a user' + ); + } +}; + +const saveInSession = async function ({ + certificationCandidate, + sessionId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const certificationCandidateDataToSave = _adaptModelToDb(certificationCandidate); + + try { + const insertCertificationCandidateQuery = knex('certification-candidates') + .insert({ ...certificationCandidateDataToSave, sessionId }) + .returning('*'); + + if (domainTransaction.knexTransaction) { + insertCertificationCandidateQuery.transacting(domainTransaction.knexTransaction); + } + + const [addedCertificationCandidate] = await insertCertificationCandidateQuery; - async saveInSession({ certificationCandidate, sessionId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const certificationCandidateDataToSave = _adaptModelToDb(certificationCandidate); + if (!_.isEmpty(certificationCandidate.complementaryCertifications)) { + const complementaryCertificationSubscriptionsToSave = certificationCandidate.complementaryCertifications.map( + (complementaryCertification) => { + return { + complementaryCertificationId: complementaryCertification.id, + certificationCandidateId: addedCertificationCandidate.id, + }; + } + ); - try { - const insertCertificationCandidateQuery = knex('certification-candidates') - .insert({ ...certificationCandidateDataToSave, sessionId }) - .returning('*'); + const insertComplementaryCertificationSubscriptionQuery = knex( + 'complementary-certification-subscriptions' + ).insert(complementaryCertificationSubscriptionsToSave); if (domainTransaction.knexTransaction) { - insertCertificationCandidateQuery.transacting(domainTransaction.knexTransaction); + insertComplementaryCertificationSubscriptionQuery.transacting(domainTransaction.knexTransaction); } - const [addedCertificationCandidate] = await insertCertificationCandidateQuery; + await insertComplementaryCertificationSubscriptionQuery; + } - if (!_.isEmpty(certificationCandidate.complementaryCertifications)) { - const complementaryCertificationSubscriptionsToSave = certificationCandidate.complementaryCertifications.map( - (complementaryCertification) => { - return { - complementaryCertificationId: complementaryCertification.id, - certificationCandidateId: addedCertificationCandidate.id, - }; - } - ); + return new CertificationCandidate(addedCertificationCandidate); + } catch (error) { + logger.error(error); + throw new CertificationCandidateCreationOrUpdateError( + 'An error occurred while saving the certification candidate in a session' + ); + } +}; - const insertComplementaryCertificationSubscriptionQuery = knex( - 'complementary-certification-subscriptions' - ).insert(complementaryCertificationSubscriptionsToSave); +const remove = async function (certificationCandidateId) { + await knex.transaction(async (trx) => { + await trx('complementary-certification-subscriptions').where({ certificationCandidateId }).del(); + return trx('certification-candidates').where({ id: certificationCandidateId }).del(); + }); - if (domainTransaction.knexTransaction) { - insertComplementaryCertificationSubscriptionQuery.transacting(domainTransaction.knexTransaction); - } + return true; +}; - await insertComplementaryCertificationSubscriptionQuery; - } +const isNotLinked = async function (certificationCandidateId) { + const notLinkedCandidate = await BookshelfCertificationCandidate.where({ + id: certificationCandidateId, + userId: null, + }).fetch({ require: false, columns: ['id'] }); - return new CertificationCandidate(addedCertificationCandidate); - } catch (error) { - logger.error(error); - throw new CertificationCandidateCreationOrUpdateError( - 'An error occurred while saving the certification candidate in a session' - ); - } - }, + return !!notLinkedCandidate; +}; - async delete(certificationCandidateId) { - await knex.transaction(async (trx) => { - await trx('complementary-certification-subscriptions').where({ certificationCandidateId }).del(); - return trx('certification-candidates').where({ id: certificationCandidateId }).del(); - }); +const getBySessionIdAndUserId = async function ({ sessionId, userId }) { + const certificationCandidate = await knex + .select('certification-candidates.*') + .select({ complementaryCertifications: knex.raw(`json_agg("complementary-certifications".*)`) }) + .from('certification-candidates') + .leftJoin( + 'complementary-certification-subscriptions', + 'certification-candidates.id', + 'complementary-certification-subscriptions.certificationCandidateId' + ) + .leftJoin( + 'complementary-certifications', + 'complementary-certification-subscriptions.complementaryCertificationId', + 'complementary-certifications.id' + ) + .where({ sessionId, userId }) + .groupBy('certification-candidates.id') + .first(); + return certificationCandidate ? _toDomain(certificationCandidate) : undefined; +}; + +const findBySessionId = async function (sessionId) { + const results = await knex + .select('certification-candidates.*') + .select({ complementaryCertifications: knex.raw(`json_agg("complementary-certifications".*)`) }) + .from('certification-candidates') + .where({ 'certification-candidates.sessionId': sessionId }) + .leftJoin( + 'complementary-certification-subscriptions', + 'certification-candidates.id', + 'complementary-certification-subscriptions.certificationCandidateId' + ) + .leftJoin( + 'complementary-certifications', + 'complementary-certification-subscriptions.complementaryCertificationId', + 'complementary-certifications.id' + ) + .groupBy('certification-candidates.id') + .orderByRaw('LOWER("certification-candidates"."lastName") asc') + .orderByRaw('LOWER("certification-candidates"."firstName") asc'); + return results.map(_toDomain); +}; + +const findBySessionIdAndPersonalInfo = async function ({ sessionId, firstName, lastName, birthdate }) { + const results = await BookshelfCertificationCandidate.where({ sessionId, birthdate }).fetchAll(); + + const certificationCandidates = _buildCertificationCandidates(results); - return true; - }, - - async isNotLinked(certificationCandidateId) { - const notLinkedCandidate = await CertificationCandidateBookshelf.where({ - id: certificationCandidateId, - userId: null, - }).fetch({ require: false, columns: ['id'] }); - - return !!notLinkedCandidate; - }, - - async getBySessionIdAndUserId({ sessionId, userId }) { - const certificationCandidate = await knex - .select('certification-candidates.*') - .select({ complementaryCertifications: knex.raw(`json_agg("complementary-certifications".*)`) }) - .from('certification-candidates') - .leftJoin( - 'complementary-certification-subscriptions', - 'certification-candidates.id', - 'complementary-certification-subscriptions.certificationCandidateId' - ) - .leftJoin( - 'complementary-certifications', - 'complementary-certification-subscriptions.complementaryCertificationId', - 'complementary-certifications.id' - ) - .where({ sessionId, userId }) - .groupBy('certification-candidates.id') - .first(); - return certificationCandidate ? _toDomain(certificationCandidate) : undefined; - }, - - async findBySessionId(sessionId) { - const results = await knex - .select('certification-candidates.*') - .select({ complementaryCertifications: knex.raw(`json_agg("complementary-certifications".*)`) }) - .from('certification-candidates') - .where({ 'certification-candidates.sessionId': sessionId }) - .leftJoin( - 'complementary-certification-subscriptions', - 'certification-candidates.id', - 'complementary-certification-subscriptions.certificationCandidateId' - ) - .leftJoin( - 'complementary-certifications', - 'complementary-certification-subscriptions.complementaryCertificationId', - 'complementary-certifications.id' - ) - .groupBy('certification-candidates.id') - .orderByRaw('LOWER("certification-candidates"."lastName") asc') - .orderByRaw('LOWER("certification-candidates"."firstName") asc'); - return results.map(_toDomain); - }, - - async findBySessionIdAndPersonalInfo({ sessionId, firstName, lastName, birthdate }) { - const results = await CertificationCandidateBookshelf.where({ sessionId, birthdate }).fetchAll(); - - const certificationCandidates = _buildCertificationCandidates(results); - - const normalizedInputNames = { - lastName: normalize(lastName), - firstName: normalize(firstName), + const normalizedInputNames = { + lastName: normalize(lastName), + firstName: normalize(firstName), + }; + return _.filter(certificationCandidates, (certificationCandidate) => { + const certificationCandidateNormalizedNames = { + lastName: normalize(certificationCandidate.lastName), + firstName: normalize(certificationCandidate.firstName), }; - return _.filter(certificationCandidates, (certificationCandidate) => { - const certificationCandidateNormalizedNames = { - lastName: normalize(certificationCandidate.lastName), - firstName: normalize(certificationCandidate.firstName), - }; - return _.isEqual(normalizedInputNames, certificationCandidateNormalizedNames); - }); - }, - - findOneBySessionIdAndUserId({ sessionId, userId }) { - return CertificationCandidateBookshelf.where({ sessionId, userId }) - .fetchAll() - .then((results) => _buildCertificationCandidates(results)[0]); - }, - - async doesLinkedCertificationCandidateInSessionExist({ sessionId }) { - const anyLinkedCandidateInSession = await CertificationCandidateBookshelf.query({ - where: { sessionId }, - whereNotNull: 'userId', - }).fetch({ require: false, columns: 'id' }); - - return anyLinkedCandidateInSession !== null; - }, - - async update(certificationCandidate) { - const result = await knex('certification-candidates') - .where({ id: certificationCandidate.id }) - .update({ authorizedToStart: certificationCandidate.authorizedToStart }); - - if (result === 0) { - throw new NotFoundError('Aucun candidat trouvé'); - } - }, - - async deleteBySessionId({ sessionId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction.knexTransaction ?? knex; - await knexConn('complementary-certification-subscriptions') - .whereIn('certificationCandidateId', knexConn.select('id').from('certification-candidates').where({ sessionId })) - .del(); - - await knexConn('certification-candidates').where({ sessionId }).del(); - }, - - async getWithComplementaryCertifications(id) { - const candidateData = await knex('certification-candidates') - .select('certification-candidates.*') - .select({ complementaryCertifications: knex.raw('json_agg("complementary-certifications".*)') }) - .leftJoin( - 'complementary-certification-subscriptions', - 'complementary-certification-subscriptions.certificationCandidateId', - 'certification-candidates.id' - ) - .leftJoin( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-subscriptions.complementaryCertificationId' - ) - .where('certification-candidates.id', id) - .groupBy('certification-candidates.id') - .first(); - return _toDomain(candidateData); - }, + return _.isEqual(normalizedInputNames, certificationCandidateNormalizedNames); + }); +}; + +const findOneBySessionIdAndUserId = function ({ sessionId, userId }) { + return BookshelfCertificationCandidate.where({ sessionId, userId }) + .fetchAll() + .then((results) => _buildCertificationCandidates(results)[0]); +}; + +const doesLinkedCertificationCandidateInSessionExist = async function ({ sessionId }) { + const anyLinkedCandidateInSession = await BookshelfCertificationCandidate.query({ + where: { sessionId }, + whereNotNull: 'userId', + }).fetch({ require: false, columns: 'id' }); + + return anyLinkedCandidateInSession !== null; +}; + +const update = async function (certificationCandidate) { + const result = await knex('certification-candidates') + .where({ id: certificationCandidate.id }) + .update({ authorizedToStart: certificationCandidate.authorizedToStart }); + + if (result === 0) { + throw new NotFoundError('Aucun candidat trouvé'); + } +}; + +const deleteBySessionId = async function ({ sessionId, domainTransaction = DomainTransaction.emptyTransaction() }) { + const knexConn = domainTransaction.knexTransaction ?? knex; + await knexConn('complementary-certification-subscriptions') + .whereIn('certificationCandidateId', knexConn.select('id').from('certification-candidates').where({ sessionId })) + .del(); + + await knexConn('certification-candidates').where({ sessionId }).del(); +}; + +const getWithComplementaryCertifications = async function (id) { + const candidateData = await knex('certification-candidates') + .select('certification-candidates.*') + .select({ complementaryCertifications: knex.raw('json_agg("complementary-certifications".*)') }) + .leftJoin( + 'complementary-certification-subscriptions', + 'complementary-certification-subscriptions.certificationCandidateId', + 'certification-candidates.id' + ) + .leftJoin( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-subscriptions.complementaryCertificationId' + ) + .where('certification-candidates.id', id) + .groupBy('certification-candidates.id') + .first(); + return _toDomain(candidateData); +}; + +export { + linkToUser, + saveInSession, + remove, + isNotLinked, + getBySessionIdAndUserId, + findBySessionId, + findBySessionIdAndPersonalInfo, + findOneBySessionIdAndUserId, + doesLinkedCertificationCandidateInSessionExist, + update, + deleteBySessionId, + getWithComplementaryCertifications, }; function _buildCertificationCandidates(results) { @@ -216,7 +235,7 @@ function _buildCertificationCandidates(results) { }); } - return bookshelfToDomainConverter.buildDomainObjects(CertificationCandidateBookshelf, results); + return bookshelfToDomainConverter.buildDomainObjects(BookshelfCertificationCandidate, results); } function _adaptModelToDb(certificationCandidateToSave) { diff --git a/api/lib/infrastructure/repositories/certification-center-for-admin-repository.js b/api/lib/infrastructure/repositories/certification-center-for-admin-repository.js index 13c9c940125..91896740ee0 100644 --- a/api/lib/infrastructure/repositories/certification-center-for-admin-repository.js +++ b/api/lib/infrastructure/repositories/certification-center-for-admin-repository.js @@ -1,81 +1,77 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { knex } = require('../../../db/knex-database-connection.js'); -const CertificationCenterForAdmin = require('../../domain/models/CertificationCenterForAdmin.js'); -const ComplementaryCertification = require('../../domain/models/ComplementaryCertification.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationCenterForAdmin } from '../../domain/models/CertificationCenterForAdmin.js'; +import { ComplementaryCertification } from '../../domain/models/ComplementaryCertification.js'; +import { NotFoundError } from '../../domain/errors.js'; const CERTIFICATION_CENTERS_TABLE_NAME = 'certification-centers'; -module.exports = { - async get(id) { - const certificationCenter = await knex(CERTIFICATION_CENTERS_TABLE_NAME) - .select({ - id: 'certification-centers.id', - name: 'certification-centers.name', - type: 'certification-centers.type', - externalId: 'certification-centers.externalId', - dataProtectionOfficerFirstName: 'data-protection-officers.firstName', - dataProtectionOfficerLastName: 'data-protection-officers.lastName', - dataProtectionOfficerEmail: 'data-protection-officers.email', - createdAt: 'certification-centers.createdAt', - updatedAt: 'certification-centers.updatedAt', - }) - .leftJoin( - 'data-protection-officers', - 'data-protection-officers.certificationCenterId', - 'certification-centers.id' - ) - .where('certification-centers.id', id) - .first(); +const get = async function (id) { + const certificationCenter = await knex(CERTIFICATION_CENTERS_TABLE_NAME) + .select({ + id: 'certification-centers.id', + name: 'certification-centers.name', + type: 'certification-centers.type', + externalId: 'certification-centers.externalId', + dataProtectionOfficerFirstName: 'data-protection-officers.firstName', + dataProtectionOfficerLastName: 'data-protection-officers.lastName', + dataProtectionOfficerEmail: 'data-protection-officers.email', + createdAt: 'certification-centers.createdAt', + updatedAt: 'certification-centers.updatedAt', + }) + .leftJoin('data-protection-officers', 'data-protection-officers.certificationCenterId', 'certification-centers.id') + .where('certification-centers.id', id) + .first(); - if (!certificationCenter) { - throw new NotFoundError(`Certification center with id: ${id} not found`); - } + if (!certificationCenter) { + throw new NotFoundError(`Certification center with id: ${id} not found`); + } - const habilitations = await knex('complementary-certification-habilitations') - .select({ - id: 'complementary-certification-habilitations.complementaryCertificationId', - label: 'complementary-certifications.label', - key: 'complementary-certifications.key', - }) - .join( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-habilitations.complementaryCertificationId' - ) - .where('complementary-certification-habilitations.certificationCenterId', id) - .orderBy('complementary-certification-habilitations.complementaryCertificationId', 'asc'); + const habilitations = await knex('complementary-certification-habilitations') + .select({ + id: 'complementary-certification-habilitations.complementaryCertificationId', + label: 'complementary-certifications.label', + key: 'complementary-certifications.key', + }) + .join( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-habilitations.complementaryCertificationId' + ) + .where('complementary-certification-habilitations.certificationCenterId', id) + .orderBy('complementary-certification-habilitations.complementaryCertificationId', 'asc'); - certificationCenter.habilitations = habilitations.map((habilitation) => { - return new ComplementaryCertification({ - id: habilitation.id, - key: habilitation.key, - label: habilitation.label, - }); + certificationCenter.habilitations = habilitations.map((habilitation) => { + return new ComplementaryCertification({ + id: habilitation.id, + key: habilitation.key, + label: habilitation.label, }); + }); - return _toDomain(certificationCenter); - }, + return _toDomain(certificationCenter); +}; - async save(certificationCenter) { - const data = _.pick(certificationCenter, ['name', 'type', 'externalId']); - const [certificationCenterCreated] = await knex(CERTIFICATION_CENTERS_TABLE_NAME).returning('*').insert(data); - return _toDomain(certificationCenterCreated); - }, +const save = async function (certificationCenter) { + const data = _.pick(certificationCenter, ['name', 'type', 'externalId']); + const [certificationCenterCreated] = await knex(CERTIFICATION_CENTERS_TABLE_NAME).returning('*').insert(data); + return _toDomain(certificationCenterCreated); +}; - async update(certificationCenter) { - const data = _.pick(certificationCenter, ['name', 'type', 'externalId']); +const update = async function (certificationCenter) { + const data = _.pick(certificationCenter, ['name', 'type', 'externalId']); - const [certificationCenterRow] = await knex(CERTIFICATION_CENTERS_TABLE_NAME) - .update(data) - .where({ id: certificationCenter.id }) - .returning('*'); + const [certificationCenterRow] = await knex(CERTIFICATION_CENTERS_TABLE_NAME) + .update(data) + .where({ id: certificationCenter.id }) + .returning('*'); - return _toDomain(certificationCenterRow); - }, + return _toDomain(certificationCenterRow); }; +export { get, save, update }; + function _toDomain(certificationCenterDTO) { return new CertificationCenterForAdmin({ id: certificationCenterDTO.id, diff --git a/api/lib/infrastructure/repositories/certification-center-invitation-repository.js b/api/lib/infrastructure/repositories/certification-center-invitation-repository.js index d0696b426ee..47a4fc3aa44 100644 --- a/api/lib/infrastructure/repositories/certification-center-invitation-repository.js +++ b/api/lib/infrastructure/repositories/certification-center-invitation-repository.js @@ -1,6 +1,6 @@ -const CertificationCenterInvitation = require('../../domain/models/CertificationCenterInvitation.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import { CertificationCenterInvitation } from '../../domain/models/CertificationCenterInvitation.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../domain/errors.js'; const CERTIFICATION_CENTER_INVITATIONS = 'certification-center-invitations'; @@ -16,99 +16,104 @@ function _toDomain(invitationDTO) { }); } -module.exports = { - async findPendingByCertificationCenterId({ certificationCenterId }) { - const pendingCertificationCenterInvitations = await knex(CERTIFICATION_CENTER_INVITATIONS) - .select('id', 'email', 'certificationCenterId', 'updatedAt') - .where({ certificationCenterId, status: CertificationCenterInvitation.StatusType.PENDING }) - .orderBy('updatedAt', 'desc'); - return pendingCertificationCenterInvitations.map(_toDomain); - }, - - async getByIdAndCode({ id, code }) { - const certificationCenterInvitation = await knex(CERTIFICATION_CENTER_INVITATIONS) - .select({ - id: 'certification-center-invitations.id', - status: 'certification-center-invitations.status', - certificationCenterId: 'certification-center-invitations.certificationCenterId', - certificationCenterName: 'certification-centers.name', - }) - .leftJoin( - 'certification-centers', - 'certification-centers.id', - 'certification-center-invitations.certificationCenterId' - ) - .where({ - 'certification-center-invitations.id': id, - code, - }) - .first(); - - if (!certificationCenterInvitation) { - throw new NotFoundError("L'invitation à ce centre de certification n'existe pas"); - } - - return _toDomain(certificationCenterInvitation); - }, - - async get(id) { - const certificationCenterInvitation = await knex(CERTIFICATION_CENTER_INVITATIONS) - .select('*') - .where({ id }) - .first(); - if (!certificationCenterInvitation) { - throw new NotFoundError("L'invitation à ce centre de certification n'existe pas"); - } - return _toDomain(certificationCenterInvitation); - }, - - async findOnePendingByEmailAndCertificationCenterId({ email, certificationCenterId }) { - const existingPendingInvitation = await knex(CERTIFICATION_CENTER_INVITATIONS) - .select('id') - .where({ email, certificationCenterId, status: CertificationCenterInvitation.StatusType.PENDING }) - .first(); - - return existingPendingInvitation ? _toDomain(existingPendingInvitation) : null; - }, - - async create(invitation) { - const [newInvitation] = await knex(CERTIFICATION_CENTER_INVITATIONS) - .insert(invitation) - .returning(['id', 'email', 'code', 'certificationCenterId', 'updatedAt']); - - const { name: certificationCenterName } = await knex('certification-centers') - .select('name') - .where({ id: newInvitation.certificationCenterId }) - .first(); - - return _toDomain({ ...newInvitation, certificationCenterName }); - }, - - async update(certificationCenterInvitation) { - const [updatedCertificationCenterInvitation] = await knex('certification-center-invitations') - .update({ updatedAt: new Date() }) - .where({ id: certificationCenterInvitation.id }) - .returning(['id', 'email', 'code', 'certificationCenterId', 'updatedAt']); - - const { name: certificationCenterName } = await knex('certification-centers') - .select('name') - .where({ id: updatedCertificationCenterInvitation.certificationCenterId }) - .first(); - - return _toDomain({ ...updatedCertificationCenterInvitation, certificationCenterName }); - }, - - async markAsCancelled({ id }) { - const [certificationCenterInvitation] = await knex('certification-center-invitations') - .where({ id }) - .update({ - status: CertificationCenterInvitation.StatusType.CANCELLED, - updatedAt: new Date(), - }) - .returning('*'); - if (!certificationCenterInvitation) { - throw new NotFoundError(`Certification center invitation of id ${id} is not found.`); - } - return _toDomain(certificationCenterInvitation); - }, +const findPendingByCertificationCenterId = async function ({ certificationCenterId }) { + const pendingCertificationCenterInvitations = await knex(CERTIFICATION_CENTER_INVITATIONS) + .select('id', 'email', 'certificationCenterId', 'updatedAt') + .where({ certificationCenterId, status: CertificationCenterInvitation.StatusType.PENDING }) + .orderBy('updatedAt', 'desc'); + return pendingCertificationCenterInvitations.map(_toDomain); +}; + +const getByIdAndCode = async function ({ id, code }) { + const certificationCenterInvitation = await knex(CERTIFICATION_CENTER_INVITATIONS) + .select({ + id: 'certification-center-invitations.id', + status: 'certification-center-invitations.status', + certificationCenterId: 'certification-center-invitations.certificationCenterId', + certificationCenterName: 'certification-centers.name', + }) + .leftJoin( + 'certification-centers', + 'certification-centers.id', + 'certification-center-invitations.certificationCenterId' + ) + .where({ + 'certification-center-invitations.id': id, + code, + }) + .first(); + + if (!certificationCenterInvitation) { + throw new NotFoundError("L'invitation à ce centre de certification n'existe pas"); + } + + return _toDomain(certificationCenterInvitation); +}; + +const get = async function (id) { + const certificationCenterInvitation = await knex(CERTIFICATION_CENTER_INVITATIONS).select('*').where({ id }).first(); + if (!certificationCenterInvitation) { + throw new NotFoundError("L'invitation à ce centre de certification n'existe pas"); + } + return _toDomain(certificationCenterInvitation); +}; + +const findOnePendingByEmailAndCertificationCenterId = async function ({ email, certificationCenterId }) { + const existingPendingInvitation = await knex(CERTIFICATION_CENTER_INVITATIONS) + .select('id') + .where({ email, certificationCenterId, status: CertificationCenterInvitation.StatusType.PENDING }) + .first(); + + return existingPendingInvitation ? _toDomain(existingPendingInvitation) : null; +}; + +const create = async function (invitation) { + const [newInvitation] = await knex(CERTIFICATION_CENTER_INVITATIONS) + .insert(invitation) + .returning(['id', 'email', 'code', 'certificationCenterId', 'updatedAt']); + + const { name: certificationCenterName } = await knex('certification-centers') + .select('name') + .where({ id: newInvitation.certificationCenterId }) + .first(); + + return _toDomain({ ...newInvitation, certificationCenterName }); +}; + +const update = async function (certificationCenterInvitation) { + const [updatedCertificationCenterInvitation] = await knex('certification-center-invitations') + .update({ updatedAt: new Date() }) + .where({ id: certificationCenterInvitation.id }) + .returning(['id', 'email', 'code', 'certificationCenterId', 'updatedAt']); + + const { name: certificationCenterName } = await knex('certification-centers') + .select('name') + .where({ id: updatedCertificationCenterInvitation.certificationCenterId }) + .first(); + + return _toDomain({ ...updatedCertificationCenterInvitation, certificationCenterName }); +}; + +const markAsCancelled = async function ({ id }) { + const [certificationCenterInvitation] = await knex('certification-center-invitations') + .where({ id }) + .update({ + status: CertificationCenterInvitation.StatusType.CANCELLED, + updatedAt: new Date(), + }) + .returning('*'); + if (!certificationCenterInvitation) { + throw new NotFoundError(`Certification center invitation of id ${id} is not found.`); + } + return _toDomain(certificationCenterInvitation); +}; + +export { + findPendingByCertificationCenterId, + getByIdAndCode, + get, + findOnePendingByEmailAndCertificationCenterId, + create, + update, + markAsCancelled, }; diff --git a/api/lib/infrastructure/repositories/certification-center-invited-user-repository.js b/api/lib/infrastructure/repositories/certification-center-invited-user-repository.js index a0cce401fcc..8f4900e1985 100644 --- a/api/lib/infrastructure/repositories/certification-center-invited-user-repository.js +++ b/api/lib/infrastructure/repositories/certification-center-invited-user-repository.js @@ -1,37 +1,37 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CertificationCenterInvitedUser = require('../../domain/models/CertificationCenterInvitedUser.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationCenterInvitedUser } from '../../domain/models/CertificationCenterInvitedUser.js'; +import { NotFoundError } from '../../domain/errors.js'; -module.exports = { - async get({ certificationCenterInvitationId, email }) { - const invitation = await knex('certification-center-invitations') - .select('id', 'certificationCenterId', 'code', 'status') - .where({ id: certificationCenterInvitationId }) - .first(); - if (!invitation) { - throw new NotFoundError(`No certification center invitation found for ID ${certificationCenterInvitationId}`); - } +const get = async function ({ certificationCenterInvitationId, email }) { + const invitation = await knex('certification-center-invitations') + .select('id', 'certificationCenterId', 'code', 'status') + .where({ id: certificationCenterInvitationId }) + .first(); + if (!invitation) { + throw new NotFoundError(`No certification center invitation found for ID ${certificationCenterInvitationId}`); + } - const user = await knex('users').select('id').where({ email }).first(); - if (!user) { - throw new NotFoundError(`No user found for email ${email} for this certification center invitation`); - } + const user = await knex('users').select('id').where({ email }).first(); + if (!user) { + throw new NotFoundError(`No user found for email ${email} for this certification center invitation`); + } - return new CertificationCenterInvitedUser({ - userId: user.id, - invitation, - status: invitation.status, - }); - }, + return new CertificationCenterInvitedUser({ + userId: user.id, + invitation, + status: invitation.status, + }); +}; - async save(certificationCenterInvitedUser) { - await knex('certification-center-memberships').insert({ - certificationCenterId: certificationCenterInvitedUser.invitation.certificationCenterId, - userId: certificationCenterInvitedUser.userId, - }); +const save = async function (certificationCenterInvitedUser) { + await knex('certification-center-memberships').insert({ + certificationCenterId: certificationCenterInvitedUser.invitation.certificationCenterId, + userId: certificationCenterInvitedUser.userId, + }); - await knex('certification-center-invitations') - .update({ status: certificationCenterInvitedUser.status, updatedAt: new Date() }) - .where({ id: certificationCenterInvitedUser.invitation.id }); - }, + await knex('certification-center-invitations') + .update({ status: certificationCenterInvitedUser.status, updatedAt: new Date() }) + .where({ id: certificationCenterInvitedUser.invitation.id }); }; + +export { get, save }; diff --git a/api/lib/infrastructure/repositories/certification-center-membership-repository.js b/api/lib/infrastructure/repositories/certification-center-membership-repository.js index a8dc215e93d..200b18fd717 100644 --- a/api/lib/infrastructure/repositories/certification-center-membership-repository.js +++ b/api/lib/infrastructure/repositories/certification-center-membership-repository.js @@ -1,16 +1,18 @@ -const bookshelfUtils = require('../utils/knex-utils.js'); -const BookshelfCertificationCenterMembership = require('../orm-models/CertificationCenterMembership.js'); -const bookshelfToDomainConverter = require('../../infrastructure/utils/bookshelf-to-domain-converter.js'); -const { +import * as knexUtils from '../utils/knex-utils.js'; +import { BookshelfCertificationCenterMembership } from '../orm-models/CertificationCenterMembership.js'; +import * as bookshelfToDomainConverter from '../../infrastructure/utils/bookshelf-to-domain-converter.js'; + +import { CertificationCenterMembershipCreationError, AlreadyExistingMembershipError, CertificationCenterMembershipDisableError, -} = require('../../domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const CertificationCenter = require('../../domain/models/CertificationCenter.js'); -const User = require('../../domain/models/User.js'); -const CertificationCenterMembership = require('../../domain/models/CertificationCenterMembership.js'); -const DomainTransaction = require('../DomainTransaction.js'); +} from '../../domain/errors.js'; + +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationCenter } from '../../domain/models/CertificationCenter.js'; +import { User } from '../../domain/models/User.js'; +import { CertificationCenterMembership } from '../../domain/models/CertificationCenterMembership.js'; +import { DomainTransaction } from '../DomainTransaction.js'; function _toDomain(certificationCenterMembershipDTO) { let user, certificationCenter; @@ -41,129 +43,142 @@ function _toDomain(certificationCenterMembershipDTO) { }); } -module.exports = { - async findByUserId(userId) { - const certificationCenterMemberships = await knex - .select( - 'certification-center-memberships.*', - 'certification-centers.name', - 'certification-centers.type', - 'certification-centers.externalId', - 'certification-centers.createdAt AS certificationCenterCreatedAt', - 'certification-centers.updatedAt AS certificationCenterUpdatedAt' - ) - .from('certification-center-memberships') - .leftJoin( - 'certification-centers', - 'certification-centers.id', - 'certification-center-memberships.certificationCenterId' - ) - .where({ - userId, - disabledAt: null, - }); - - return certificationCenterMemberships.map(_toDomain); - }, - - async findActiveByCertificationCenterIdSortedById({ certificationCenterId }) { - const certificationCenterMemberships = await BookshelfCertificationCenterMembership.where({ - certificationCenterId, +const findByUserId = async function (userId) { + const certificationCenterMemberships = await knex + .select( + 'certification-center-memberships.*', + 'certification-centers.name', + 'certification-centers.type', + 'certification-centers.externalId', + 'certification-centers.createdAt AS certificationCenterCreatedAt', + 'certification-centers.updatedAt AS certificationCenterUpdatedAt' + ) + .from('certification-center-memberships') + .leftJoin( + 'certification-centers', + 'certification-centers.id', + 'certification-center-memberships.certificationCenterId' + ) + .where({ + userId, disabledAt: null, + }); + + return certificationCenterMemberships.map(_toDomain); +}; + +const findActiveByCertificationCenterIdSortedById = async function ({ certificationCenterId }) { + const certificationCenterMemberships = await BookshelfCertificationCenterMembership.where({ + certificationCenterId, + disabledAt: null, + }) + .orderBy('id', 'ASC') + .fetchAll({ + withRelated: ['certificationCenter', 'user'], + }); + + return bookshelfToDomainConverter.buildDomainObjects( + BookshelfCertificationCenterMembership, + certificationCenterMemberships + ); +}; + +const save = async function ({ userId, certificationCenterId }) { + try { + const newCertificationCenterMembership = await new BookshelfCertificationCenterMembership({ + userId, + certificationCenterId, }) - .orderBy('id', 'ASC') - .fetchAll({ - withRelated: ['certificationCenter', 'user'], - }); + .save() + .then((model) => model.fetch({ withRelated: ['user', 'certificationCenter'] })); - return bookshelfToDomainConverter.buildDomainObjects( + return bookshelfToDomainConverter.buildDomainObject( BookshelfCertificationCenterMembership, - certificationCenterMemberships + newCertificationCenterMembership ); - }, - - async save({ userId, certificationCenterId }) { - try { - const newCertificationCenterMembership = await new BookshelfCertificationCenterMembership({ - userId, - certificationCenterId, - }) - .save() - .then((model) => model.fetch({ withRelated: ['user', 'certificationCenter'] })); - - return bookshelfToDomainConverter.buildDomainObject( - BookshelfCertificationCenterMembership, - newCertificationCenterMembership + } catch (err) { + if (knexUtils.isUniqConstraintViolated(err)) { + throw new AlreadyExistingMembershipError( + `User is already member of certification center ${certificationCenterId}` ); - } catch (err) { - if (bookshelfUtils.isUniqConstraintViolated(err)) { - throw new AlreadyExistingMembershipError( - `User is already member of certification center ${certificationCenterId}` - ); - } - if (bookshelfUtils.foreignKeyConstraintViolated(err)) { - throw new CertificationCenterMembershipCreationError(); - } - throw err; } - }, - - async isMemberOfCertificationCenter({ userId, certificationCenterId }) { - const certificationCenterMembershipId = await knex('certification-center-memberships') - .select('id') - .where({ - userId, - certificationCenterId, - disabledAt: null, - }) - .first(); - - return Boolean(certificationCenterMembershipId); - }, - - async disableById({ certificationCenterMembershipId }) { - try { - const now = new Date(); - const result = await knex('certification-center-memberships') - .where({ id: certificationCenterMembershipId }) - .update({ disabledAt: now }) - .returning('*'); - - if (result.length === 0) { - throw new CertificationCenterMembershipDisableError(); - } - } catch (e) { - throw new CertificationCenterMembershipDisableError(); + if (knexUtils.foreignKeyConstraintViolated(err)) { + throw new CertificationCenterMembershipCreationError(); } - }, + throw err; + } +}; + +const isMemberOfCertificationCenter = async function ({ userId, certificationCenterId }) { + const certificationCenterMembershipId = await knex('certification-center-memberships') + .select('id') + .where({ + userId, + certificationCenterId, + disabledAt: null, + }) + .first(); - async updateRefererStatusByUserIdAndCertificationCenterId({ userId, certificationCenterId, isReferer }) { - await knex('certification-center-memberships').where({ userId, certificationCenterId }).update({ isReferer }); - }, + return Boolean(certificationCenterMembershipId); +}; - async getRefererByCertificationCenterId({ certificationCenterId }) { - const refererCertificationCenterMembership = await knex('certification-center-memberships') - .select('certification-center-memberships.*', 'users.lastName', 'users.firstName', 'users.email') - .join('users', 'users.id', 'certification-center-memberships.userId') - .where({ certificationCenterId, isReferer: true }) - .first(); +const disableById = async function ({ certificationCenterMembershipId }) { + try { + const now = new Date(); + const result = await knex('certification-center-memberships') + .where({ id: certificationCenterMembershipId }) + .update({ disabledAt: now }) + .returning('*'); - if (!refererCertificationCenterMembership) { - return null; + if (result.length === 0) { + throw new CertificationCenterMembershipDisableError(); } + } catch (e) { + throw new CertificationCenterMembershipDisableError(); + } +}; + +const updateRefererStatusByUserIdAndCertificationCenterId = async function ({ + userId, + certificationCenterId, + isReferer, +}) { + await knex('certification-center-memberships').where({ userId, certificationCenterId }).update({ isReferer }); +}; + +const getRefererByCertificationCenterId = async function ({ certificationCenterId }) { + const refererCertificationCenterMembership = await knex('certification-center-memberships') + .select('certification-center-memberships.*', 'users.lastName', 'users.firstName', 'users.email') + .join('users', 'users.id', 'certification-center-memberships.userId') + .where({ certificationCenterId, isReferer: true }) + .first(); + + if (!refererCertificationCenterMembership) { + return null; + } + + return _toDomain(refererCertificationCenterMembership); +}; + +const disableMembershipsByUserId = async function ({ + userId, + updatedByUserId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction ?? knex; + await knexConn('certification-center-memberships') + .whereNull('disabledAt') + .andWhere({ userId }) + .update({ disabledAt: new Date(), updatedByUserId }); +}; - return _toDomain(refererCertificationCenterMembership); - }, - - async disableMembershipsByUserId({ - userId, - updatedByUserId, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knexConn = domainTransaction.knexTransaction ?? knex; - await knexConn('certification-center-memberships') - .whereNull('disabledAt') - .andWhere({ userId }) - .update({ disabledAt: new Date(), updatedByUserId }); - }, +export { + findByUserId, + findActiveByCertificationCenterIdSortedById, + save, + isMemberOfCertificationCenter, + disableById, + updateRefererStatusByUserIdAndCertificationCenterId, + getRefererByCertificationCenterId, + disableMembershipsByUserId, }; diff --git a/api/lib/infrastructure/repositories/certification-center-repository.js b/api/lib/infrastructure/repositories/certification-center-repository.js index 433408f04f0..c77fbb18a4a 100644 --- a/api/lib/infrastructure/repositories/certification-center-repository.js +++ b/api/lib/infrastructure/repositories/certification-center-repository.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const BookshelfCertificationCenter = require('../orm-models/CertificationCenter.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const CertificationCenter = require('../../domain/models/CertificationCenter.js'); -const ComplementaryCertification = require('../../domain/models/ComplementaryCertification.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import _ from 'lodash'; +import { BookshelfCertificationCenter } from '../orm-models/CertificationCenter.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationCenter } from '../../domain/models/CertificationCenter.js'; +import { ComplementaryCertification } from '../../domain/models/ComplementaryCertification.js'; +import { NotFoundError } from '../../domain/errors.js'; function _toDomain(bookshelfCertificationCenter) { const dbCertificationCenter = bookshelfCertificationCenter.toJSON(); @@ -37,62 +37,11 @@ function _setSearchFiltersForQueryBuilder(filters, qb) { } } -module.exports = { - async get(id) { - const certificationCenterBookshelf = await BookshelfCertificationCenter.query((q) => q.orderBy('id', 'desc')) - .where({ id }) - .fetch({ - require: false, - withRelated: [ - { - habilitations: function (query) { - query.orderBy('id'); - }, - }, - ], - }); - - if (certificationCenterBookshelf) { - return _toDomain(certificationCenterBookshelf); - } - throw new NotFoundError(`Certification center with id: ${id} not found`); - }, - - async getBySessionId(sessionId) { - const certificationCenterBookshelf = await BookshelfCertificationCenter.where({ 'sessions.id': sessionId }) - .query((qb) => { - qb.innerJoin('sessions', 'sessions.certificationCenterId', 'certification-centers.id'); - }) - .fetch({ - require: false, - withRelated: [ - { - habilitations: function (query) { - query.orderBy('id'); - }, - }, - ], - }); - - if (certificationCenterBookshelf) { - return _toDomain(certificationCenterBookshelf); - } - throw new NotFoundError(`Could not find certification center for sessionId ${sessionId}.`); - }, - async save(certificationCenter) { - const cleanedCertificationCenter = _.omit(certificationCenter, ['createdAt', 'habilitations']); - const certificationCenterBookshelf = await new BookshelfCertificationCenter(cleanedCertificationCenter).save(); - await certificationCenterBookshelf.related('habilitations').fetch(); - return _toDomain(certificationCenterBookshelf); - }, - - async findPaginatedFiltered({ filter, page }) { - const certificationCenterBookshelf = await BookshelfCertificationCenter.query((qb) => { - _setSearchFiltersForQueryBuilder(filter, qb); - qb.orderBy('id'); - }).fetchPage({ - page: page.number, - pageSize: page.size, +const get = async function (id) { + const certificationCenterBookshelf = await BookshelfCertificationCenter.query((q) => q.orderBy('id', 'desc')) + .where({ id }) + .fetch({ + require: false, withRelated: [ { habilitations: function (query) { @@ -101,12 +50,19 @@ module.exports = { }, ], }); - const { models, pagination } = certificationCenterBookshelf; - return { models: models.map(_toDomain), pagination }; - }, - async findByExternalId({ externalId }) { - const certificationCenterBookshelf = await BookshelfCertificationCenter.where({ externalId }).fetch({ + if (certificationCenterBookshelf) { + return _toDomain(certificationCenterBookshelf); + } + throw new NotFoundError(`Certification center with id: ${id} not found`); +}; + +const getBySessionId = async function (sessionId) { + const certificationCenterBookshelf = await BookshelfCertificationCenter.where({ 'sessions.id': sessionId }) + .query((qb) => { + qb.innerJoin('sessions', 'sessions.certificationCenterId', 'certification-centers.id'); + }) + .fetch({ require: false, withRelated: [ { @@ -117,21 +73,66 @@ module.exports = { ], }); - return certificationCenterBookshelf ? _toDomain(certificationCenterBookshelf) : null; - }, + if (certificationCenterBookshelf) { + return _toDomain(certificationCenterBookshelf); + } + throw new NotFoundError(`Could not find certification center for sessionId ${sessionId}.`); +}; - async getRefererEmails(certificationCenterId) { - const refererEmails = await knex('certification-centers') - .select('users.email') - .join( - 'certification-center-memberships', - 'certification-center-memberships.certificationCenterId', - 'certification-centers.id' - ) - .join('users', 'users.id', 'certification-center-memberships.userId') - .where('certification-centers.id', certificationCenterId) - .where('certification-center-memberships.isReferer', true); +const save = async function (certificationCenter) { + const cleanedCertificationCenter = _.omit(certificationCenter, ['createdAt', 'habilitations']); + const certificationCenterBookshelf = await new BookshelfCertificationCenter(cleanedCertificationCenter).save(); + await certificationCenterBookshelf.related('habilitations').fetch(); + return _toDomain(certificationCenterBookshelf); +}; - return refererEmails; - }, +const findPaginatedFiltered = async function ({ filter, page }) { + const certificationCenterBookshelf = await BookshelfCertificationCenter.query((qb) => { + _setSearchFiltersForQueryBuilder(filter, qb); + qb.orderBy('id'); + }).fetchPage({ + page: page.number, + pageSize: page.size, + withRelated: [ + { + habilitations: function (query) { + query.orderBy('id'); + }, + }, + ], + }); + const { models, pagination } = certificationCenterBookshelf; + return { models: models.map(_toDomain), pagination }; }; + +const findByExternalId = async function ({ externalId }) { + const certificationCenterBookshelf = await BookshelfCertificationCenter.where({ externalId }).fetch({ + require: false, + withRelated: [ + { + habilitations: function (query) { + query.orderBy('id'); + }, + }, + ], + }); + + return certificationCenterBookshelf ? _toDomain(certificationCenterBookshelf) : null; +}; + +const getRefererEmails = async function (certificationCenterId) { + const refererEmails = await knex('certification-centers') + .select('users.email') + .join( + 'certification-center-memberships', + 'certification-center-memberships.certificationCenterId', + 'certification-centers.id' + ) + .join('users', 'users.id', 'certification-center-memberships.userId') + .where('certification-centers.id', certificationCenterId) + .where('certification-center-memberships.isReferer', true); + + return refererEmails; +}; + +export { get, getBySessionId, save, findPaginatedFiltered, findByExternalId, getRefererEmails }; diff --git a/api/lib/infrastructure/repositories/certification-challenge-repository.js b/api/lib/infrastructure/repositories/certification-challenge-repository.js index c3b38e8403c..4a0fb0b3e29 100644 --- a/api/lib/infrastructure/repositories/certification-challenge-repository.js +++ b/api/lib/infrastructure/repositories/certification-challenge-repository.js @@ -1,47 +1,46 @@ -const Bookshelf = require('../bookshelf.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const CertificationChallengeBookshelf = require('../orm-models/CertificationChallenge.js'); -const logger = require('../../infrastructure/logger.js'); - -const { AssessmentEndedError } = require('../../domain/errors.js'); +import { Bookshelf } from '../bookshelf.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { BookshelfCertificationChallenge } from '../orm-models/CertificationChallenge.js'; +import { logger } from '../../infrastructure/logger.js'; +import { AssessmentEndedError } from '../../domain/errors.js'; const logContext = { zone: 'certificationChallengeRepository.getNextNonAnsweredChallengeByCourseId', type: 'repository', }; -module.exports = { - async save({ certificationChallenge, domainTransaction = DomainTransaction.emptyTransaction() }) { - const certificationChallengeToSave = new CertificationChallengeBookshelf({ - challengeId: certificationChallenge.challengeId, - competenceId: certificationChallenge.competenceId, - associatedSkillName: certificationChallenge.associatedSkillName, - associatedSkillId: certificationChallenge.associatedSkillId, - courseId: certificationChallenge.courseId, - certifiableBadgeKey: certificationChallenge.certifiableBadgeKey, - }); - const savedCertificationChallenge = await certificationChallengeToSave.save(null, { - transacting: domainTransaction.knexTransaction, - }); - return bookshelfToDomainConverter.buildDomainObject(CertificationChallengeBookshelf, savedCertificationChallenge); - }, +const save = async function ({ certificationChallenge, domainTransaction = DomainTransaction.emptyTransaction() }) { + const certificationChallengeToSave = new BookshelfCertificationChallenge({ + challengeId: certificationChallenge.challengeId, + competenceId: certificationChallenge.competenceId, + associatedSkillName: certificationChallenge.associatedSkillName, + associatedSkillId: certificationChallenge.associatedSkillId, + courseId: certificationChallenge.courseId, + certifiableBadgeKey: certificationChallenge.certifiableBadgeKey, + }); + const savedCertificationChallenge = await certificationChallengeToSave.save(null, { + transacting: domainTransaction.knexTransaction, + }); + return bookshelfToDomainConverter.buildDomainObject(BookshelfCertificationChallenge, savedCertificationChallenge); +}; - async getNextNonAnsweredChallengeByCourseId(assessmentId, courseId) { - const answeredChallengeIds = Bookshelf.knex('answers').select('challengeId').where({ assessmentId }); +const getNextNonAnsweredChallengeByCourseId = async function (assessmentId, courseId) { + const answeredChallengeIds = Bookshelf.knex('answers').select('challengeId').where({ assessmentId }); - const certificationChallenge = await CertificationChallengeBookshelf.where({ courseId }) - .query((knex) => knex.whereNotIn('challengeId', answeredChallengeIds)) - .orderBy('id', 'asc') - .fetch({ require: false }); + const certificationChallenge = await BookshelfCertificationChallenge.where({ courseId }) + .query((knex) => knex.whereNotIn('challengeId', answeredChallengeIds)) + .orderBy('id', 'asc') + .fetch({ require: false }); - if (certificationChallenge === null) { - logger.trace(logContext, 'no found challenges'); - throw new AssessmentEndedError(); - } + if (certificationChallenge === null) { + logger.trace(logContext, 'no found challenges'); + throw new AssessmentEndedError(); + } - logContext.challengeId = certificationChallenge.id; - logger.trace(logContext, 'found challenge'); - return bookshelfToDomainConverter.buildDomainObject(CertificationChallengeBookshelf, certificationChallenge); - }, + logContext.challengeId = certificationChallenge.id; + logger.trace(logContext, 'found challenge'); + return bookshelfToDomainConverter.buildDomainObject(BookshelfCertificationChallenge, certificationChallenge); }; + +export { save, getNextNonAnsweredChallengeByCourseId }; diff --git a/api/lib/infrastructure/repositories/certification-course-repository.js b/api/lib/infrastructure/repositories/certification-course-repository.js index b1313461c9b..7c103387324 100644 --- a/api/lib/infrastructure/repositories/certification-course-repository.js +++ b/api/lib/infrastructure/repositories/certification-course-repository.js @@ -1,22 +1,25 @@ -const { _ } = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const bluebird = require('bluebird'); -const CertificationCourseBookshelf = require('../orm-models/CertificationCourse.js'); -const AssessmentBookshelf = require('../orm-models/Assessment.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const CertificationCourse = require('../../domain/models/CertificationCourse.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const certificationChallengeRepository = require('./certification-challenge-repository.js'); -const CertificationIssueReport = require('../../domain/models/CertificationIssueReport.js'); -const ComplementaryCertificationCourse = require('../../domain/models/ComplementaryCertificationCourse.js'); -const Bookshelf = require('../bookshelf.js'); +import lodash from 'lodash'; + +const { _ } = lodash; + +import { knex } from '../../../db/knex-database-connection.js'; +import bluebird from 'bluebird'; +import { BookshelfCertificationCourse } from '../orm-models/CertificationCourse.js'; +import { BookshelfAssessment } from '../orm-models/Assessment.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { CertificationCourse } from '../../domain/models/CertificationCourse.js'; +import { NotFoundError } from '../../domain/errors.js'; +import * as certificationChallengeRepository from './certification-challenge-repository.js'; +import { CertificationIssueReport } from '../../domain/models/CertificationIssueReport.js'; +import { ComplementaryCertificationCourse } from '../../domain/models/ComplementaryCertificationCourse.js'; +import { Bookshelf } from '../bookshelf.js'; async function save({ certificationCourse, domainTransaction = DomainTransaction.emptyTransaction() }) { const knexConn = domainTransaction.knexTransaction || Bookshelf.knex; const certificationCourseToSaveDTO = _adaptModelToDb(certificationCourse); const options = { transacting: domainTransaction.knexTransaction }; - const savedCertificationCourseDTO = await new CertificationCourseBookshelf(certificationCourseToSaveDTO).save( + const savedCertificationCourseDTO = await new BookshelfCertificationCourse(certificationCourseToSaveDTO).save( null, options ); @@ -54,7 +57,7 @@ async function changeCompletionDate( completedAt = null, domainTransaction = DomainTransaction.emptyTransaction() ) { - const certificationCourseBookshelf = new CertificationCourseBookshelf({ id: certificationCourseId, completedAt }); + const certificationCourseBookshelf = new BookshelfCertificationCourse({ id: certificationCourseId, completedAt }); const savedCertificationCourse = await certificationCourseBookshelf.save(null, { transacting: domainTransaction.knexTransaction, }); @@ -63,12 +66,12 @@ async function changeCompletionDate( async function get(id) { try { - const certificationCourseBookshelf = await CertificationCourseBookshelf.where({ id }).fetch({ + const certificationCourseBookshelf = await BookshelfCertificationCourse.where({ id }).fetch({ withRelated: ['assessment', 'challenges', 'certificationIssueReports', 'complementaryCertificationCourses'], }); return toDomain(certificationCourseBookshelf); } catch (bookshelfError) { - if (bookshelfError instanceof CertificationCourseBookshelf.NotFoundError) { + if (bookshelfError instanceof BookshelfCertificationCourse.NotFoundError) { throw new NotFoundError(`Certification course of id ${id} does not exist.`); } throw bookshelfError; @@ -89,7 +92,7 @@ async function findOneCertificationCourseByUserIdAndSessionId({ sessionId, domainTransaction = DomainTransaction.emptyTransaction(), }) { - const certificationCourse = await CertificationCourseBookshelf.where({ userId, sessionId }) + const certificationCourse = await BookshelfCertificationCourse.where({ userId, sessionId }) .orderBy('createdAt', 'desc') .fetch({ require: false, @@ -101,12 +104,12 @@ async function findOneCertificationCourseByUserIdAndSessionId({ async function update(certificationCourse) { const certificationCourseData = _pickUpdatableProperties(certificationCourse); - const certificationCourseBookshelf = new CertificationCourseBookshelf(certificationCourseData); + const certificationCourseBookshelf = new BookshelfCertificationCourse(certificationCourseData); try { const certificationCourse = await certificationCourseBookshelf.save(); return toDomain(certificationCourse); } catch (err) { - if (err instanceof CertificationCourseBookshelf.NoRowsUpdatedError) { + if (err instanceof BookshelfCertificationCourse.NoRowsUpdatedError) { throw new NotFoundError(`No rows updated for certification course of id ${certificationCourse.getId()}.`); } throw err; @@ -123,7 +126,7 @@ async function isVerificationCodeAvailable(verificationCode) { } async function findCertificationCoursesBySessionId({ sessionId }) { - const bookshelfCertificationCourses = await CertificationCourseBookshelf.where({ sessionId }).fetchAll(); + const bookshelfCertificationCourses = await BookshelfCertificationCourse.where({ sessionId }).fetchAll(); return bookshelfCertificationCourses.map(toDomain); } @@ -133,7 +136,7 @@ function toDomain(bookshelfCertificationCourse) { } const assessment = bookshelfToDomainConverter.buildDomainObject( - AssessmentBookshelf, + BookshelfAssessment, bookshelfCertificationCourse.related('assessment') ); const dbCertificationCourse = bookshelfCertificationCourse.toJSON(); @@ -174,7 +177,7 @@ function toDomain(bookshelfCertificationCourse) { }); } -module.exports = { +export { save, changeCompletionDate, get, diff --git a/api/lib/infrastructure/repositories/certification-cpf-city-repository.js b/api/lib/infrastructure/repositories/certification-cpf-city-repository.js index 5c003c1aff6..cb4bdc8ee99 100644 --- a/api/lib/infrastructure/repositories/certification-cpf-city-repository.js +++ b/api/lib/infrastructure/repositories/certification-cpf-city-repository.js @@ -1,28 +1,28 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CertificationCpfCity = require('../../domain/models/CertificationCpfCity.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationCpfCity } from '../../domain/models/CertificationCpfCity.js'; const COLUMNS = ['id', 'name', 'postalCode', 'INSEECode', 'isActualName']; -module.exports = { - async findByINSEECode({ INSEECode }) { - const result = await knex - .select(COLUMNS) - .from('certification-cpf-cities') - .where({ INSEECode }) - .orderBy('isActualName', 'desc') - .orderBy('id'); +const findByINSEECode = async function ({ INSEECode }) { + const result = await knex + .select(COLUMNS) + .from('certification-cpf-cities') + .where({ INSEECode }) + .orderBy('isActualName', 'desc') + .orderBy('id'); - return result.map((city) => new CertificationCpfCity(city)); - }, + return result.map((city) => new CertificationCpfCity(city)); +}; - async findByPostalCode({ postalCode }) { - const result = await knex - .select(COLUMNS) - .from('certification-cpf-cities') - .where({ postalCode }) - .orderBy('isActualName', 'desc') - .orderBy('id'); +const findByPostalCode = async function ({ postalCode }) { + const result = await knex + .select(COLUMNS) + .from('certification-cpf-cities') + .where({ postalCode }) + .orderBy('isActualName', 'desc') + .orderBy('id'); - return result.map((city) => new CertificationCpfCity(city)); - }, + return result.map((city) => new CertificationCpfCity(city)); }; + +export { findByINSEECode, findByPostalCode }; diff --git a/api/lib/infrastructure/repositories/certification-cpf-country-repository.js b/api/lib/infrastructure/repositories/certification-cpf-country-repository.js index be580717503..d94a67c5623 100644 --- a/api/lib/infrastructure/repositories/certification-cpf-country-repository.js +++ b/api/lib/infrastructure/repositories/certification-cpf-country-repository.js @@ -1,16 +1,16 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CertificationCpfCountry = require('../../domain/models/CertificationCpfCountry.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationCpfCountry } from '../../domain/models/CertificationCpfCountry.js'; -module.exports = { - async getByMatcher({ matcher }) { - const COLUMNS = ['id', 'code', 'commonName', 'originalName', 'matcher']; +const getByMatcher = async function ({ matcher }) { + const COLUMNS = ['id', 'code', 'commonName', 'originalName', 'matcher']; - const result = await knex.select(COLUMNS).from('certification-cpf-countries').where({ matcher }).first(); + const result = await knex.select(COLUMNS).from('certification-cpf-countries').where({ matcher }).first(); - if (!result) { - return null; - } + if (!result) { + return null; + } - return new CertificationCpfCountry(result); - }, + return new CertificationCpfCountry(result); }; + +export { getByMatcher }; diff --git a/api/lib/infrastructure/repositories/certification-issue-report-repository.js b/api/lib/infrastructure/repositories/certification-issue-report-repository.js index 19523134736..997352b2a3d 100644 --- a/api/lib/infrastructure/repositories/certification-issue-report-repository.js +++ b/api/lib/infrastructure/repositories/certification-issue-report-repository.js @@ -1,32 +1,35 @@ -const omit = require('lodash/omit'); -const { knex } = require('../../../db/knex-database-connection.js'); -const CertificationIssueReport = require('../../domain/models/CertificationIssueReport.js'); - -module.exports = { - async save(certificationIssueReport) { - const [data] = await knex - .from('certification-issue-reports') - .insert(omit(certificationIssueReport, ['isImpactful'])) - .onConflict(['id']) - .merge() - .returning('*'); - - return new CertificationIssueReport(data); - }, - - async get(id) { - const certificationIssueReport = await knex('certification-issue-reports').where({ id }).first(); - return new CertificationIssueReport(certificationIssueReport); - }, - - async findByCertificationCourseId(certificationCourseId) { - const certificationIssueReports = await knex('certification-issue-reports').where({ certificationCourseId }); - return certificationIssueReports.map( - (certificationIssueReport) => new CertificationIssueReport(certificationIssueReport) - ); - }, - - async delete(id) { - return knex('certification-issue-reports').where({ id }).del(); - }, +import lodash from 'lodash'; + +const { omit } = lodash; + +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationIssueReport } from '../../domain/models/CertificationIssueReport.js'; + +const save = async function (certificationIssueReport) { + const [data] = await knex + .from('certification-issue-reports') + .insert(omit(certificationIssueReport, ['isImpactful'])) + .onConflict(['id']) + .merge() + .returning('*'); + + return new CertificationIssueReport(data); +}; + +const get = async function (id) { + const certificationIssueReport = await knex('certification-issue-reports').where({ id }).first(); + return new CertificationIssueReport(certificationIssueReport); }; + +const findByCertificationCourseId = async function (certificationCourseId) { + const certificationIssueReports = await knex('certification-issue-reports').where({ certificationCourseId }); + return certificationIssueReports.map( + (certificationIssueReport) => new CertificationIssueReport(certificationIssueReport) + ); +}; + +const remove = async function (id) { + return knex('certification-issue-reports').where({ id }).del(); +}; + +export { save, get, findByCertificationCourseId, remove }; diff --git a/api/lib/infrastructure/repositories/certification-livret-scolaire-repository.js b/api/lib/infrastructure/repositories/certification-livret-scolaire-repository.js index 89929784e9a..a06f3404b61 100644 --- a/api/lib/infrastructure/repositories/certification-livret-scolaire-repository.js +++ b/api/lib/infrastructure/repositories/certification-livret-scolaire-repository.js @@ -1,84 +1,84 @@ -const Certificate = require('../../domain/read-models/livret-scolaire/Certificate.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import { Certificate } from '../../domain/read-models/livret-scolaire/Certificate.js'; +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async getCertificatesByOrganizationUAI(uai) { - const result = await knex - .select({ - id: 'certification-courses.id', - firstName: 'view-active-organization-learners.firstName', - middleName: 'view-active-organization-learners.middleName', - thirdName: 'view-active-organization-learners.thirdName', - lastName: 'view-active-organization-learners.lastName', - birthdate: 'view-active-organization-learners.birthdate', - nationalStudentId: 'view-active-organization-learners.nationalStudentId', - date: 'certification-courses.createdAt', - verificationCode: 'certification-courses.verificationCode', - deliveredAt: 'sessions.publishedAt', - certificationCenter: 'sessions.certificationCenter', - isPublished: 'certification-courses.isPublished', - status: 'assessment-results.status', - pixScore: 'assessment-results.pixScore', - competenceResults: knex.raw(` - json_agg( - json_build_object('level', "competence-marks".level, 'competenceId', "competence-marks"."competence_code") - ORDER BY "competence-marks"."competence_code" asc - )`), - }) - .from('certification-courses') - .innerJoin( - 'view-active-organization-learners', - 'view-active-organization-learners.userId', - 'certification-courses.userId' - ) - .innerJoin('sessions', 'sessions.id', 'certification-courses.sessionId') - .innerJoin( - 'certification-courses-last-assessment-results', - 'certification-courses.id', - 'certification-courses-last-assessment-results.certificationCourseId' - ) - .innerJoin( - 'assessment-results', - 'assessment-results.id', - 'certification-courses-last-assessment-results.lastAssessmentResultId' - ) - .innerJoin('assessments', 'assessments.certificationCourseId', 'certification-courses.id') - .innerJoin('competence-marks', 'competence-marks.assessmentResultId', 'assessment-results.id') - .whereNotExists( - knex - .select(1) - .from({ 'last-certification-courses': 'certification-courses' }) - .whereRaw('"last-certification-courses"."userId" = "certification-courses"."userId"') - .whereRaw('"last-certification-courses"."isCancelled"= false') - .whereRaw('"certification-courses"."createdAt" < "last-certification-courses"."createdAt"') - ) +const getCertificatesByOrganizationUAI = async function (uai) { + const result = await knex + .select({ + id: 'certification-courses.id', + firstName: 'view-active-organization-learners.firstName', + middleName: 'view-active-organization-learners.middleName', + thirdName: 'view-active-organization-learners.thirdName', + lastName: 'view-active-organization-learners.lastName', + birthdate: 'view-active-organization-learners.birthdate', + nationalStudentId: 'view-active-organization-learners.nationalStudentId', + date: 'certification-courses.createdAt', + verificationCode: 'certification-courses.verificationCode', + deliveredAt: 'sessions.publishedAt', + certificationCenter: 'sessions.certificationCenter', + isPublished: 'certification-courses.isPublished', + status: 'assessment-results.status', + pixScore: 'assessment-results.pixScore', + competenceResults: knex.raw(` + json_agg( + json_build_object('level', "competence-marks".level, 'competenceId', "competence-marks"."competence_code") + ORDER BY "competence-marks"."competence_code" asc + )`), + }) + .from('certification-courses') + .innerJoin( + 'view-active-organization-learners', + 'view-active-organization-learners.userId', + 'certification-courses.userId' + ) + .innerJoin('sessions', 'sessions.id', 'certification-courses.sessionId') + .innerJoin( + 'certification-courses-last-assessment-results', + 'certification-courses.id', + 'certification-courses-last-assessment-results.certificationCourseId' + ) + .innerJoin( + 'assessment-results', + 'assessment-results.id', + 'certification-courses-last-assessment-results.lastAssessmentResultId' + ) + .innerJoin('assessments', 'assessments.certificationCourseId', 'certification-courses.id') + .innerJoin('competence-marks', 'competence-marks.assessmentResultId', 'assessment-results.id') + .whereNotExists( + knex + .select(1) + .from({ 'last-certification-courses': 'certification-courses' }) + .whereRaw('"last-certification-courses"."userId" = "certification-courses"."userId"') + .whereRaw('"last-certification-courses"."isCancelled"= false') + .whereRaw('"certification-courses"."createdAt" < "last-certification-courses"."createdAt"') + ) - .where({ 'certification-courses.isCancelled': false }) - .where({ 'view-active-organization-learners.isDisabled': false }) - .where( - 'view-active-organization-learners.organizationId', - '=', - knex.select('id').from('organizations').whereRaw('LOWER("externalId") = LOWER(?)', uai) - ) + .where({ 'certification-courses.isCancelled': false }) + .where({ 'view-active-organization-learners.isDisabled': false }) + .where( + 'view-active-organization-learners.organizationId', + '=', + knex.select('id').from('organizations').whereRaw('LOWER("externalId") = LOWER(?)', uai) + ) - .groupBy( - 'view-active-organization-learners.id', - 'view-active-organization-learners.firstName', - 'view-active-organization-learners.middleName', - 'view-active-organization-learners.thirdName', - 'view-active-organization-learners.lastName', - 'view-active-organization-learners.birthdate', - 'view-active-organization-learners.nationalStudentId', - 'certification-courses.id', - 'sessions.id', - 'assessments.id', - 'assessment-results.id' - ) + .groupBy( + 'view-active-organization-learners.id', + 'view-active-organization-learners.firstName', + 'view-active-organization-learners.middleName', + 'view-active-organization-learners.thirdName', + 'view-active-organization-learners.lastName', + 'view-active-organization-learners.birthdate', + 'view-active-organization-learners.nationalStudentId', + 'certification-courses.id', + 'sessions.id', + 'assessments.id', + 'assessment-results.id' + ) - .orderBy('lastName', 'ASC') - .orderBy('firstName', 'ASC') - .orderBy('id', 'ASC'); + .orderBy('lastName', 'ASC') + .orderBy('firstName', 'ASC') + .orderBy('id', 'ASC'); - return result.map(Certificate.from); - }, + return result.map(Certificate.from); }; + +export { getCertificatesByOrganizationUAI }; diff --git a/api/lib/infrastructure/repositories/certification-officer-repository.js b/api/lib/infrastructure/repositories/certification-officer-repository.js index eb2fdb7e8a2..f9d6f0170cf 100644 --- a/api/lib/infrastructure/repositories/certification-officer-repository.js +++ b/api/lib/infrastructure/repositories/certification-officer-repository.js @@ -1,25 +1,24 @@ -const BookshelfUser = require('../orm-models/User.js'); +import { BookshelfUser } from '../orm-models/User.js'; +import { UserNotFoundError } from '../../domain/errors.js'; +import { CertificationOfficer } from '../../domain/models/CertificationOfficer.js'; -const { UserNotFoundError } = require('../../domain/errors.js'); -const CertificationOfficer = require('../../domain/models/CertificationOfficer.js'); +const get = async function (certificationOfficerId) { + try { + const certificationOfficer = await BookshelfUser.where({ id: certificationOfficerId }).fetch({ + columns: ['id', 'firstName', 'lastName'], + }); -module.exports = { - async get(certificationOfficerId) { - try { - const certificationOfficer = await BookshelfUser.where({ id: certificationOfficerId }).fetch({ - columns: ['id', 'firstName', 'lastName'], - }); - - return _toDomain(certificationOfficer.attributes); - } catch (error) { - if (error instanceof BookshelfUser.NotFoundError) { - throw new UserNotFoundError(`User not found for ID ${certificationOfficerId}`); - } - throw error; + return _toDomain(certificationOfficer.attributes); + } catch (error) { + if (error instanceof BookshelfUser.NotFoundError) { + throw new UserNotFoundError(`User not found for ID ${certificationOfficerId}`); } - }, + throw error; + } }; +export { get }; + function _toDomain(certificationOfficer) { return new CertificationOfficer(certificationOfficer); } diff --git a/api/lib/infrastructure/repositories/certification-point-of-contact-repository.js b/api/lib/infrastructure/repositories/certification-point-of-contact-repository.js index 0ad937652a7..3c0d2776d32 100644 --- a/api/lib/infrastructure/repositories/certification-point-of-contact-repository.js +++ b/api/lib/infrastructure/repositories/certification-point-of-contact-repository.js @@ -1,48 +1,48 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const CertificationPointOfContact = require('../../domain/read-models/CertificationPointOfContact.js'); -const AllowedCertificationCenterAccess = require('../../domain/read-models/AllowedCertificationCenterAccess.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { CertificationPointOfContact } from '../../domain/read-models/CertificationPointOfContact.js'; +import { AllowedCertificationCenterAccess } from '../../domain/read-models/AllowedCertificationCenterAccess.js'; -module.exports = { - async get(userId) { - const certificationPointOfContactDTO = await knex - .select({ - id: 'users.id', - firstName: 'users.firstName', - lastName: 'users.lastName', - email: 'users.email', - lang: 'users.lang', - pixCertifTermsOfServiceAccepted: 'users.pixCertifTermsOfServiceAccepted', - certificationCenterIds: knex.raw('array_agg(?? order by ?? asc)', [ - 'certificationCenterId', - 'certificationCenterId', - ]), - }) - .from('users') - .leftJoin('certification-center-memberships', 'certification-center-memberships.userId', 'users.id') - .where('users.id', userId) - .groupByRaw('1, 2, 3, 4, 5') - .first(); +const get = async function (userId) { + const certificationPointOfContactDTO = await knex + .select({ + id: 'users.id', + firstName: 'users.firstName', + lastName: 'users.lastName', + email: 'users.email', + lang: 'users.lang', + pixCertifTermsOfServiceAccepted: 'users.pixCertifTermsOfServiceAccepted', + certificationCenterIds: knex.raw('array_agg(?? order by ?? asc)', [ + 'certificationCenterId', + 'certificationCenterId', + ]), + }) + .from('users') + .leftJoin('certification-center-memberships', 'certification-center-memberships.userId', 'users.id') + .where('users.id', userId) + .groupByRaw('1, 2, 3, 4, 5') + .first(); - if (!certificationPointOfContactDTO) { - throw new NotFoundError(`Le référent de certification ${userId} n'existe pas.`); - } + if (!certificationPointOfContactDTO) { + throw new NotFoundError(`Le référent de certification ${userId} n'existe pas.`); + } - const authorizedCertificationCenterIds = await _removeDisabledCertificationCenterAccesses({ - certificationPointOfContactDTO, - }); - const allowedCertificationCenterAccesses = await _findAllowedCertificationCenterAccesses( - authorizedCertificationCenterIds - ); + const authorizedCertificationCenterIds = await _removeDisabledCertificationCenterAccesses({ + certificationPointOfContactDTO, + }); + const allowedCertificationCenterAccesses = await _findAllowedCertificationCenterAccesses( + authorizedCertificationCenterIds + ); - return new CertificationPointOfContact({ - ...certificationPointOfContactDTO, - allowedCertificationCenterAccesses, - }); - }, + return new CertificationPointOfContact({ + ...certificationPointOfContactDTO, + allowedCertificationCenterAccesses, + }); }; +export { get }; + async function _removeDisabledCertificationCenterAccesses({ certificationPointOfContactDTO }) { const certificationCenters = await knex .select('certificationCenterId') diff --git a/api/lib/infrastructure/repositories/certification-report-repository.js b/api/lib/infrastructure/repositories/certification-report-repository.js index 34a59d51cc6..9147ededc66 100644 --- a/api/lib/infrastructure/repositories/certification-report-repository.js +++ b/api/lib/infrastructure/repositories/certification-report-repository.js @@ -1,47 +1,46 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); +import _ from 'lodash'; +import bluebird from 'bluebird'; -const Bookshelf = require('../bookshelf.js'); -const CertificationReport = require('../../domain/models/CertificationReport.js'); +import { Bookshelf } from '../bookshelf.js'; +import { CertificationReport } from '../../domain/models/CertificationReport.js'; +import { BookshelfCertificationCourse } from '../orm-models/CertificationCourse.js'; +import { CertificationCourseUpdateError } from '../../domain/errors.js'; +import { toDomain } from './certification-course-repository.js'; -const CertificationCourseBookshelf = require('../orm-models/CertificationCourse.js'); -const { CertificationCourseUpdateError } = require('../../domain/errors.js'); -const { toDomain } = require('./certification-course-repository.js'); +const findBySessionId = async function (sessionId) { + const results = await BookshelfCertificationCourse.where({ sessionId }) + .query((qb) => { + qb.orderByRaw('LOWER("lastName") asc'); + qb.orderByRaw('LOWER("firstName") asc'); + }) + .fetchAll({ + withRelated: ['certificationIssueReports', 'assessment'], + }); -module.exports = { - async findBySessionId(sessionId) { - const results = await CertificationCourseBookshelf.where({ sessionId }) - .query((qb) => { - qb.orderByRaw('LOWER("lastName") asc'); - qb.orderByRaw('LOWER("firstName") asc'); - }) - .fetchAll({ - withRelated: ['certificationIssueReports', 'assessment'], - }); - - const certificationCourses = results.map(toDomain); - return _.map(certificationCourses, CertificationReport.fromCertificationCourse); - }, + const certificationCourses = results.map(toDomain); + return _.map(certificationCourses, CertificationReport.fromCertificationCourse); +}; - async finalizeAll(certificationReports) { - try { - await Bookshelf.transaction((trx) => { - const finalizeReport = (certificationReport) => _finalize({ certificationReport, transaction: trx }); - return bluebird.mapSeries(certificationReports, finalizeReport); - }); - } catch (err) { - throw new CertificationCourseUpdateError('An error occurred while finalizing the session'); - } - }, +const finalizeAll = async function (certificationReports) { + try { + await Bookshelf.transaction((trx) => { + const finalizeReport = (certificationReport) => _finalize({ certificationReport, transaction: trx }); + return bluebird.mapSeries(certificationReports, finalizeReport); + }); + } catch (err) { + throw new CertificationCourseUpdateError('An error occurred while finalizing the session'); + } }; +export { findBySessionId, finalizeAll }; + async function _finalize({ certificationReport, transaction = undefined }) { const saveOptions = { patch: true, method: 'update' }; if (transaction) { saveOptions.transacting = transaction; } - await new CertificationCourseBookshelf({ id: certificationReport.certificationCourseId }).save( + await new BookshelfCertificationCourse({ id: certificationReport.certificationCourseId }).save( { hasSeenEndTestScreen: certificationReport.hasSeenEndTestScreen }, saveOptions ); diff --git a/api/lib/infrastructure/repositories/certification-repository.js b/api/lib/infrastructure/repositories/certification-repository.js index 52b079f8169..1366b45bb74 100644 --- a/api/lib/infrastructure/repositories/certification-repository.js +++ b/api/lib/infrastructure/repositories/certification-repository.js @@ -1,56 +1,55 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const { CertificationCourseNotPublishableError } = require('../../../lib/domain/errors.js'); -const { status } = require('../../../lib/domain/models/AssessmentResult.js'); - -module.exports = { - async publishCertificationCoursesBySessionId(sessionId) { - const certificationDTOs = await knex('certification-courses') - .select({ - certificationId: 'certification-courses.id', - isCancelled: 'certification-courses.isCancelled', - assessmentResultStatus: 'assessment-results.status', - }) - .where('certification-courses.sessionId', sessionId) - .join('assessments', 'assessments.certificationCourseId', 'certification-courses.id') - .leftJoin( - 'certification-courses-last-assessment-results', - 'certification-courses.id', - 'certification-courses-last-assessment-results.certificationCourseId' - ) - .leftJoin( - 'assessment-results', - 'assessment-results.id', - 'certification-courses-last-assessment-results.lastAssessmentResultId' - ); - - const hasCertificationInError = _hasCertificationInError(certificationDTOs); - const hasCertificationWithNoAssessmentResultStatus = - _hasCertificationWithNoAssessmentResultStatus(certificationDTOs); - if (hasCertificationInError || hasCertificationWithNoAssessmentResultStatus) { - throw new CertificationCourseNotPublishableError(); - } - - const certificationDataToUpdate = certificationDTOs.map(({ certificationId, assessmentResultStatus }) => ({ - id: certificationId, - pixCertificationStatus: assessmentResultStatus, - isPublished: true, - updatedAt: new Date(), - })); - - // Trick to .batchUpdate(), which does not exist in knex per say - await knex('certification-courses') - .insert(certificationDataToUpdate) - .onConflict('id') - .merge(['pixCertificationStatus', 'isPublished', 'updatedAt']); - }, - - async unpublishCertificationCoursesBySessionId(sessionId) { - await knex('certification-courses') - .where({ sessionId }) - .update({ isPublished: false, pixCertificationStatus: null, updatedAt: new Date() }); - }, +import { knex } from '../../../db/knex-database-connection.js'; +import { CertificationCourseNotPublishableError } from '../../../lib/domain/errors.js'; +import { status } from '../../../lib/domain/models/AssessmentResult.js'; + +const publishCertificationCoursesBySessionId = async function (sessionId) { + const certificationDTOs = await knex('certification-courses') + .select({ + certificationId: 'certification-courses.id', + isCancelled: 'certification-courses.isCancelled', + assessmentResultStatus: 'assessment-results.status', + }) + .where('certification-courses.sessionId', sessionId) + .join('assessments', 'assessments.certificationCourseId', 'certification-courses.id') + .leftJoin( + 'certification-courses-last-assessment-results', + 'certification-courses.id', + 'certification-courses-last-assessment-results.certificationCourseId' + ) + .leftJoin( + 'assessment-results', + 'assessment-results.id', + 'certification-courses-last-assessment-results.lastAssessmentResultId' + ); + + const hasCertificationInError = _hasCertificationInError(certificationDTOs); + const hasCertificationWithNoAssessmentResultStatus = _hasCertificationWithNoAssessmentResultStatus(certificationDTOs); + if (hasCertificationInError || hasCertificationWithNoAssessmentResultStatus) { + throw new CertificationCourseNotPublishableError(); + } + + const certificationDataToUpdate = certificationDTOs.map(({ certificationId, assessmentResultStatus }) => ({ + id: certificationId, + pixCertificationStatus: assessmentResultStatus, + isPublished: true, + updatedAt: new Date(), + })); + + // Trick to .batchUpdate(), which does not exist in knex per say + await knex('certification-courses') + .insert(certificationDataToUpdate) + .onConflict('id') + .merge(['pixCertificationStatus', 'isPublished', 'updatedAt']); }; +const unpublishCertificationCoursesBySessionId = async function (sessionId) { + await knex('certification-courses') + .where({ sessionId }) + .update({ isPublished: false, pixCertificationStatus: null, updatedAt: new Date() }); +}; + +export { publishCertificationCoursesBySessionId, unpublishCertificationCoursesBySessionId }; + function _hasCertificationInError(certificationDTOs) { return certificationDTOs.some((dto) => dto.assessmentResultStatus === status.ERROR); } diff --git a/api/lib/infrastructure/repositories/certification-result-repository.js b/api/lib/infrastructure/repositories/certification-result-repository.js index c2409b6341a..1a211017ab2 100644 --- a/api/lib/infrastructure/repositories/certification-result-repository.js +++ b/api/lib/infrastructure/repositories/certification-result-repository.js @@ -1,58 +1,60 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const ComplementaryCertificationCourseResult = require('../../domain/models/ComplementaryCertificationCourseResult.js'); -const CertificationResult = require('../../domain/models/CertificationResult.js'); -const isEmpty = require('lodash/isEmpty'); +import { knex } from '../../../db/knex-database-connection.js'; +import { ComplementaryCertificationCourseResult } from '../../domain/models/ComplementaryCertificationCourseResult.js'; +import { CertificationResult } from '../../domain/models/CertificationResult.js'; +import lodash from 'lodash'; -module.exports = { - async findBySessionId({ sessionId }) { - const certificationResultDTOs = await _selectCertificationResults() - .where('certification-courses.sessionId', sessionId) - .orderBy('certification-courses.lastName', 'ASC') - .orderBy('certification-courses.firstName', 'ASC'); +const { isEmpty } = lodash; - const complementaryCertificationCourseResultsByCertificationCourseId = - await _selectComplementaryCertificationCourseResultsBySessionId({ - sessionId, - }); +const findBySessionId = async function ({ sessionId }) { + const certificationResultDTOs = await _selectCertificationResults() + .where('certification-courses.sessionId', sessionId) + .orderBy('certification-courses.lastName', 'ASC') + .orderBy('certification-courses.firstName', 'ASC'); - return certificationResultDTOs.map((certificationResultDTO) => { - certificationResultDTO.complementaryCertificationCourseResults = - complementaryCertificationCourseResultsByCertificationCourseId.find( - ({ certificationCourseId }) => certificationCourseId === certificationResultDTO.id - )?.complementaryCertificationCourseResults; - return _toDomain(certificationResultDTO); + const complementaryCertificationCourseResultsByCertificationCourseId = + await _selectComplementaryCertificationCourseResultsBySessionId({ + sessionId, }); - }, - async findByCertificationCandidateIds({ certificationCandidateIds }) { - const certificationResultDTOs = await _selectCertificationResults() - .join('certification-candidates', function () { - this.on({ 'certification-candidates.sessionId': 'certification-courses.sessionId' }).andOn({ - 'certification-candidates.userId': 'certification-courses.userId', - }); - }) - .whereIn('certification-candidates.id', certificationCandidateIds) - .orderBy('certification-courses.lastName', 'ASC') - .orderBy('certification-courses.firstName', 'ASC'); + return certificationResultDTOs.map((certificationResultDTO) => { + certificationResultDTO.complementaryCertificationCourseResults = + complementaryCertificationCourseResultsByCertificationCourseId.find( + ({ certificationCourseId }) => certificationCourseId === certificationResultDTO.id + )?.complementaryCertificationCourseResults; + return _toDomain(certificationResultDTO); + }); +}; + +const findByCertificationCandidateIds = async function ({ certificationCandidateIds }) { + const certificationResultDTOs = await _selectCertificationResults() + .join('certification-candidates', function () { + this.on({ 'certification-candidates.sessionId': 'certification-courses.sessionId' }).andOn({ + 'certification-candidates.userId': 'certification-courses.userId', + }); + }) + .whereIn('certification-candidates.id', certificationCandidateIds) + .orderBy('certification-courses.lastName', 'ASC') + .orderBy('certification-courses.firstName', 'ASC'); - let complementaryCertificationCourseResultsByCertificationCourseId = []; - if (!isEmpty(certificationResultDTOs)) { - complementaryCertificationCourseResultsByCertificationCourseId = - await _selectComplementaryCertificationCourseResultsBySessionId({ - sessionId: certificationResultDTOs[0].sessionId, - }); - } + let complementaryCertificationCourseResultsByCertificationCourseId = []; + if (!isEmpty(certificationResultDTOs)) { + complementaryCertificationCourseResultsByCertificationCourseId = + await _selectComplementaryCertificationCourseResultsBySessionId({ + sessionId: certificationResultDTOs[0].sessionId, + }); + } - return certificationResultDTOs.map((certificationResultDTO) => { - certificationResultDTO.complementaryCertificationCourseResults = - complementaryCertificationCourseResultsByCertificationCourseId.find( - ({ certificationCourseId }) => certificationCourseId === certificationResultDTO.id - )?.complementaryCertificationCourseResults; - return _toDomain(certificationResultDTO); - }); - }, + return certificationResultDTOs.map((certificationResultDTO) => { + certificationResultDTO.complementaryCertificationCourseResults = + complementaryCertificationCourseResultsByCertificationCourseId.find( + ({ certificationCourseId }) => certificationCourseId === certificationResultDTO.id + )?.complementaryCertificationCourseResults; + return _toDomain(certificationResultDTO); + }); }; +export { findBySessionId, findByCertificationCandidateIds }; + function _selectCertificationResults() { return knex .select({ diff --git a/api/lib/infrastructure/repositories/certified-profile-repository.js b/api/lib/infrastructure/repositories/certified-profile-repository.js index d4bbb4fe2b5..6fb2ab2a642 100644 --- a/api/lib/infrastructure/repositories/certified-profile-repository.js +++ b/api/lib/infrastructure/repositories/certified-profile-repository.js @@ -1,64 +1,66 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; + +import { CertifiedProfile, CertifiedArea, CertifiedCompetence, CertifiedTube, CertifiedSkill, -} = require('../../domain/read-models/CertifiedProfile.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const { skillDatasource } = require('../datasources/learning-content/skill-datasource.js'); -const { tubeDatasource } = require('../datasources/learning-content/tube-datasource.js'); -const { competenceDatasource } = require('../datasources/learning-content/competence-datasource.js'); -const { areaDatasource } = require('../datasources/learning-content/area-datasource.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); +} from '../../domain/read-models/CertifiedProfile.js'; -module.exports = { - async get(certificationCourseId) { - const certificationDatas = await knex - .select({ - userId: 'certification-courses.userId', - createdAt: 'certification-courses.createdAt', - skillId: 'certification-challenges.associatedSkillId', - }) - .from('certification-courses') - .join('certification-challenges', 'certification-challenges.courseId', 'certification-courses.id') - .where('certification-courses.id', certificationCourseId); +import { NotFoundError } from '../../domain/errors.js'; +import { skillDatasource } from '../datasources/learning-content/skill-datasource.js'; +import { tubeDatasource } from '../datasources/learning-content/tube-datasource.js'; +import { competenceDatasource } from '../datasources/learning-content/competence-datasource.js'; +import { areaDatasource } from '../datasources/learning-content/area-datasource.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; - if (certificationDatas.length === 0) { - throw new NotFoundError(`Test de certification ${certificationCourseId} n'existe pas`); - } - const userId = certificationDatas[0].userId; - const createdAt = certificationDatas[0].createdAt; - const askedSkillIds = certificationDatas.map((data) => data.skillId); +const get = async function (certificationCourseId) { + const certificationDatas = await knex + .select({ + userId: 'certification-courses.userId', + createdAt: 'certification-courses.createdAt', + skillId: 'certification-challenges.associatedSkillId', + }) + .from('certification-courses') + .join('certification-challenges', 'certification-challenges.courseId', 'certification-courses.id') + .where('certification-courses.id', certificationCourseId); - const knowledgeElements = await knowledgeElementRepository.findUniqByUserId({ - userId, - limitDate: createdAt, - }); + if (certificationDatas.length === 0) { + throw new NotFoundError(`Test de certification ${certificationCourseId} n'existe pas`); + } + const userId = certificationDatas[0].userId; + const createdAt = certificationDatas[0].createdAt; + const askedSkillIds = certificationDatas.map((data) => data.skillId); - const isKnowledgeElementValidated = (knowledgeElement) => knowledgeElement.status === 'validated'; - const skillIds = knowledgeElements - .filter((knowledgeElement) => isKnowledgeElementValidated(knowledgeElement)) - .map((pixKnowledgeElement) => pixKnowledgeElement.skillId); + const knowledgeElements = await knowledgeElementRepository.findUniqByUserId({ + userId, + limitDate: createdAt, + }); - const certifiedSkills = await _createCertifiedSkills(skillIds, askedSkillIds); - const certifiedTubes = await _createCertifiedTubes(certifiedSkills); - const certifiedCompetences = await _createCertifiedCompetences(certifiedTubes); - const certifiedAreas = await _createCertifiedAreas(certifiedCompetences); + const isKnowledgeElementValidated = (knowledgeElement) => knowledgeElement.status === 'validated'; + const skillIds = knowledgeElements + .filter((knowledgeElement) => isKnowledgeElementValidated(knowledgeElement)) + .map((pixKnowledgeElement) => pixKnowledgeElement.skillId); - return new CertifiedProfile({ - id: certificationCourseId, - userId, - certifiedAreas, - certifiedCompetences, - certifiedTubes, - certifiedSkills, - }); - }, + const certifiedSkills = await _createCertifiedSkills(skillIds, askedSkillIds); + const certifiedTubes = await _createCertifiedTubes(certifiedSkills); + const certifiedCompetences = await _createCertifiedCompetences(certifiedTubes); + const certifiedAreas = await _createCertifiedAreas(certifiedCompetences); + + return new CertifiedProfile({ + id: certificationCourseId, + userId, + certifiedAreas, + certifiedCompetences, + certifiedTubes, + certifiedSkills, + }); }; +export { get }; + async function _createCertifiedSkills(skillIds, askedSkillIds) { const learningContentSkills = await skillDatasource.findByRecordIds(skillIds); return learningContentSkills.map((learningContentSkill) => { diff --git a/api/lib/infrastructure/repositories/challenge-for-pix-auto-answer-repository.js b/api/lib/infrastructure/repositories/challenge-for-pix-auto-answer-repository.js index 7e3460c3e2e..e4378cd2f97 100644 --- a/api/lib/infrastructure/repositories/challenge-for-pix-auto-answer-repository.js +++ b/api/lib/infrastructure/repositories/challenge-for-pix-auto-answer-repository.js @@ -1,14 +1,14 @@ -const ChallengeForPixAutoAnswer = require('../../domain/read-models/ChallengeForPixAutoAnswer.js'); -const { challengeDatasource } = require('../datasources/learning-content/challenge-datasource.js'); +import { ChallengeForPixAutoAnswer } from '../../domain/read-models/ChallengeForPixAutoAnswer.js'; +import { challengeDatasource } from '../datasources/learning-content/challenge-datasource.js'; -module.exports = { - async get(challengeId) { - const challenge = await challengeDatasource.get(challengeId); - return new ChallengeForPixAutoAnswer({ - id: challenge.id, - solution: challenge.solution, - type: challenge.type, - autoReply: challenge.autoReply, - }); - }, +const get = async function (challengeId) { + const challenge = await challengeDatasource.get(challengeId); + return new ChallengeForPixAutoAnswer({ + id: challenge.id, + solution: challenge.solution, + type: challenge.type, + autoReply: challenge.autoReply, + }); }; + +export { get }; diff --git a/api/lib/infrastructure/repositories/challenge-repository.js b/api/lib/infrastructure/repositories/challenge-repository.js index 57df1dbf206..f99be7c38ff 100644 --- a/api/lib/infrastructure/repositories/challenge-repository.js +++ b/api/lib/infrastructure/repositories/challenge-repository.js @@ -1,101 +1,112 @@ -const _ = require('lodash'); -const Challenge = require('../../domain/models/Challenge.js'); - -const { challengeDatasource } = require('../datasources/learning-content/challenge-datasource.js'); -const { skillDatasource } = require('../datasources/learning-content/skill-datasource.js'); -const skillAdapter = require('../adapters/skill-adapter.js'); -const solutionAdapter = require('../adapters/solution-adapter.js'); -const LearningContentResourceNotFound = require('../datasources/learning-content/LearningContentResourceNotFound.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const config = require('../../config.js'); - -module.exports = { - async get(id) { - try { - const challenge = await challengeDatasource.get(id); - const skill = await skillDatasource.get(challenge.skillId); - return _toDomain({ challengeDataObject: challenge, skillDataObject: skill }); - } catch (error) { - if (error instanceof LearningContentResourceNotFound) { - throw new NotFoundError(); - } - throw error; +import _ from 'lodash'; +import { Challenge } from '../../domain/models/Challenge.js'; +import { challengeDatasource } from '../datasources/learning-content/challenge-datasource.js'; +import { skillDatasource } from '../datasources/learning-content/skill-datasource.js'; +import * as skillAdapter from '../adapters/skill-adapter.js'; +import * as solutionAdapter from '../adapters/solution-adapter.js'; +import { LearningContentResourceNotFound } from '../datasources/learning-content/LearningContentResourceNotFound.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { config } from '../../config.js'; + +const get = async function (id) { + try { + const challenge = await challengeDatasource.get(id); + const skill = await skillDatasource.get(challenge.skillId); + return _toDomain({ challengeDataObject: challenge, skillDataObject: skill }); + } catch (error) { + if (error instanceof LearningContentResourceNotFound) { + throw new NotFoundError(); } - }, - - async getMany(ids) { - try { - const challengeDataObjects = await challengeDatasource.getMany(ids); - const skills = await skillDatasource.getMany(challengeDataObjects.map(({ skillId }) => skillId)); - return _toDomainCollection({ challengeDataObjects, skills }); - } catch (error) { - if (error instanceof LearningContentResourceNotFound) { - throw new NotFoundError(); - } - throw error; - } - }, + throw error; + } +}; - async list() { - const challengeDataObjects = await challengeDatasource.list(); - const skills = await skillDatasource.list(); +const getMany = async function (ids) { + try { + const challengeDataObjects = await challengeDatasource.getMany(ids); + const skills = await skillDatasource.getMany(challengeDataObjects.map(({ skillId }) => skillId)); return _toDomainCollection({ challengeDataObjects, skills }); - }, - - async findValidated() { - const challengeDataObjects = await challengeDatasource.findValidated(); - const activeSkills = await skillDatasource.findActive(); - return _toDomainCollection({ challengeDataObjects, skills: activeSkills }); - }, - - async findOperative() { - const challengeDataObjects = await challengeDatasource.findOperative(); - const operativeSkills = await skillDatasource.findOperative(); - return _toDomainCollection({ challengeDataObjects, skills: operativeSkills }); - }, - - async findOperativeHavingLocale(locale) { - const challengeDataObjects = await challengeDatasource.findOperativeHavingLocale(locale); - const operativeSkills = await skillDatasource.findOperative(); - return _toDomainCollection({ challengeDataObjects, skills: operativeSkills }); - }, - - async findValidatedByCompetenceId(competenceId) { - const challengeDataObjects = await challengeDatasource.findValidatedByCompetenceId(competenceId); - const activeSkills = await skillDatasource.findActive(); - return _toDomainCollection({ challengeDataObjects, skills: activeSkills }); - }, - - async findOperativeBySkills(skills) { - const skillIds = skills.map((skill) => skill.id); - const challengeDataObjects = await challengeDatasource.findOperativeBySkillIds(skillIds); - const operativeSkills = await skillDatasource.findOperative(); - return _toDomainCollection({ challengeDataObjects, skills: operativeSkills }); - }, - - async findActiveFlashCompatible({ - locale, - successProbabilityThreshold = config.features.successProbabilityThreshold, - } = {}) { - const challengeDataObjects = await challengeDatasource.findActiveFlashCompatible(locale); - const activeSkills = await skillDatasource.findActive(); - return _toDomainCollection({ challengeDataObjects, skills: activeSkills, successProbabilityThreshold }); - }, - - async findOperativeFlashCompatible({ - locale, - successProbabilityThreshold = config.features.successProbabilityThreshold, - } = {}) { - const challengeDataObjects = await challengeDatasource.findOperativeFlashCompatible(locale); - const skills = await skillDatasource.list(); - return _toDomainCollection({ challengeDataObjects, skills, successProbabilityThreshold }); - }, - - async findValidatedBySkillId(skillId) { - const challengeDataObjects = await challengeDatasource.findValidatedBySkillId(skillId); - const activeSkills = await skillDatasource.findActive(); - return _toDomainCollection({ challengeDataObjects, skills: activeSkills }); - }, + } catch (error) { + if (error instanceof LearningContentResourceNotFound) { + throw new NotFoundError(); + } + throw error; + } +}; + +const list = async function () { + const challengeDataObjects = await challengeDatasource.list(); + const skills = await skillDatasource.list(); + return _toDomainCollection({ challengeDataObjects, skills }); +}; + +const findValidated = async function () { + const challengeDataObjects = await challengeDatasource.findValidated(); + const activeSkills = await skillDatasource.findActive(); + return _toDomainCollection({ challengeDataObjects, skills: activeSkills }); +}; + +const findOperative = async function () { + const challengeDataObjects = await challengeDatasource.findOperative(); + const operativeSkills = await skillDatasource.findOperative(); + return _toDomainCollection({ challengeDataObjects, skills: operativeSkills }); +}; + +const findOperativeHavingLocale = async function (locale) { + const challengeDataObjects = await challengeDatasource.findOperativeHavingLocale(locale); + const operativeSkills = await skillDatasource.findOperative(); + return _toDomainCollection({ challengeDataObjects, skills: operativeSkills }); +}; + +const findValidatedByCompetenceId = async function (competenceId) { + const challengeDataObjects = await challengeDatasource.findValidatedByCompetenceId(competenceId); + const activeSkills = await skillDatasource.findActive(); + return _toDomainCollection({ challengeDataObjects, skills: activeSkills }); +}; + +const findOperativeBySkills = async function (skills) { + const skillIds = skills.map((skill) => skill.id); + const challengeDataObjects = await challengeDatasource.findOperativeBySkillIds(skillIds); + const operativeSkills = await skillDatasource.findOperative(); + return _toDomainCollection({ challengeDataObjects, skills: operativeSkills }); +}; + +const findActiveFlashCompatible = async function ({ + locale, + successProbabilityThreshold = config.features.successProbabilityThreshold, +} = {}) { + const challengeDataObjects = await challengeDatasource.findActiveFlashCompatible(locale); + const activeSkills = await skillDatasource.findActive(); + return _toDomainCollection({ challengeDataObjects, skills: activeSkills, successProbabilityThreshold }); +}; + +const findOperativeFlashCompatible = async function ({ + locale, + successProbabilityThreshold = config.features.successProbabilityThreshold, +} = {}) { + const challengeDataObjects = await challengeDatasource.findOperativeFlashCompatible(locale); + const skills = await skillDatasource.list(); + return _toDomainCollection({ challengeDataObjects, skills, successProbabilityThreshold }); +}; + +const findValidatedBySkillId = async function (skillId) { + const challengeDataObjects = await challengeDatasource.findValidatedBySkillId(skillId); + const activeSkills = await skillDatasource.findActive(); + return _toDomainCollection({ challengeDataObjects, skills: activeSkills }); +}; + +export { + get, + getMany, + list, + findValidated, + findOperative, + findOperativeHavingLocale, + findValidatedByCompetenceId, + findOperativeBySkills, + findActiveFlashCompatible, + findOperativeFlashCompatible, + findValidatedBySkillId, }; function _toDomainCollection({ challengeDataObjects, skills, successProbabilityThreshold }) { diff --git a/api/lib/infrastructure/repositories/clea-certified-candidate-repository.js b/api/lib/infrastructure/repositories/clea-certified-candidate-repository.js index f620b510466..c672601b0b6 100644 --- a/api/lib/infrastructure/repositories/clea-certified-candidate-repository.js +++ b/api/lib/infrastructure/repositories/clea-certified-candidate-repository.js @@ -1,49 +1,49 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const { CLEA } = require('../../domain/models/ComplementaryCertification.js'); -const CleaCertifiedCandidate = require('../../domain/read-models/CleaCertifiedCandidate.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CLEA } from '../../domain/models/ComplementaryCertification.js'; +import { CleaCertifiedCandidate } from '../../domain/read-models/CleaCertifiedCandidate.js'; -module.exports = { - async getBySessionId(sessionId) { - const results = await knex - .from('certification-courses') - .select( - 'certification-courses.firstName', - 'certification-courses.lastName', - 'certification-candidates.resultRecipientEmail', - 'certification-courses.birthdate', - 'certification-courses.birthplace', - 'certification-courses.birthPostalCode', - 'certification-courses.birthINSEECode', - 'certification-courses.birthCountry', - 'certification-courses.sex', - 'certification-courses.createdAt' - ) - .innerJoin('certification-candidates', function () { - this.on({ 'certification-candidates.sessionId': 'certification-courses.sessionId' }).andOn({ - 'certification-candidates.userId': 'certification-courses.userId', - }); - }) - .innerJoin( - 'complementary-certification-courses', - 'complementary-certification-courses.certificationCourseId', - 'certification-courses.id' - ) - .innerJoin( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-courses.complementaryCertificationId' - ) - .innerJoin( - 'complementary-certification-course-results', - 'complementary-certification-course-results.complementaryCertificationCourseId', - 'complementary-certification-courses.id' - ) - .where({ - 'certification-courses.sessionId': sessionId, - 'certification-courses.isPublished': true, - 'complementary-certifications.key': CLEA, - 'complementary-certification-course-results.acquired': true, +const getBySessionId = async function (sessionId) { + const results = await knex + .from('certification-courses') + .select( + 'certification-courses.firstName', + 'certification-courses.lastName', + 'certification-candidates.resultRecipientEmail', + 'certification-courses.birthdate', + 'certification-courses.birthplace', + 'certification-courses.birthPostalCode', + 'certification-courses.birthINSEECode', + 'certification-courses.birthCountry', + 'certification-courses.sex', + 'certification-courses.createdAt' + ) + .innerJoin('certification-candidates', function () { + this.on({ 'certification-candidates.sessionId': 'certification-courses.sessionId' }).andOn({ + 'certification-candidates.userId': 'certification-courses.userId', }); - return results.map((candidate) => new CleaCertifiedCandidate(candidate)); - }, + }) + .innerJoin( + 'complementary-certification-courses', + 'complementary-certification-courses.certificationCourseId', + 'certification-courses.id' + ) + .innerJoin( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-courses.complementaryCertificationId' + ) + .innerJoin( + 'complementary-certification-course-results', + 'complementary-certification-course-results.complementaryCertificationCourseId', + 'complementary-certification-courses.id' + ) + .where({ + 'certification-courses.sessionId': sessionId, + 'certification-courses.isPublished': true, + 'complementary-certifications.key': CLEA, + 'complementary-certification-course-results.acquired': true, + }); + return results.map((candidate) => new CleaCertifiedCandidate(candidate)); }; + +export { getBySessionId }; diff --git a/api/lib/infrastructure/repositories/competence-evaluation-repository.js b/api/lib/infrastructure/repositories/competence-evaluation-repository.js index 3d273a73665..9fff677daa2 100644 --- a/api/lib/infrastructure/repositories/competence-evaluation-repository.js +++ b/api/lib/infrastructure/repositories/competence-evaluation-repository.js @@ -1,109 +1,119 @@ -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const BookshelfCompetenceEvaluation = require('../orm-models/CompetenceEvaluation.js'); -const _ = require('lodash'); -const { NotFoundError } = require('../../domain/errors.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { BookshelfCompetenceEvaluation } from '../orm-models/CompetenceEvaluation.js'; +import _ from 'lodash'; +import { NotFoundError } from '../../domain/errors.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; -module.exports = { - async save({ competenceEvaluation, domainTransaction = DomainTransaction.emptyTransaction() }) { - let competenceEvaluationCreated = await _getByCompetenceIdAndUserId({ - competenceId: competenceEvaluation.competenceId, - userId: competenceEvaluation.userId, - domainTransaction, - }); - if (competenceEvaluationCreated) { - return competenceEvaluationCreated; - } else { - competenceEvaluationCreated = await new BookshelfCompetenceEvaluation( - _.omit(competenceEvaluation, ['assessment', 'scorecard']) - ) - .save(null, { transacting: domainTransaction.knexTransaction }) - .then((result) => bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, result)); - } +const save = async function ({ competenceEvaluation, domainTransaction = DomainTransaction.emptyTransaction() }) { + let competenceEvaluationCreated = await _getByCompetenceIdAndUserId({ + competenceId: competenceEvaluation.competenceId, + userId: competenceEvaluation.userId, + domainTransaction, + }); + if (competenceEvaluationCreated) { return competenceEvaluationCreated; - }, + } else { + competenceEvaluationCreated = await new BookshelfCompetenceEvaluation( + _.omit(competenceEvaluation, ['assessment', 'scorecard']) + ) + .save(null, { transacting: domainTransaction.knexTransaction }) + .then((result) => bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, result)); + } + return competenceEvaluationCreated; +}; - updateStatusByAssessmentId({ assessmentId, status }) { - return BookshelfCompetenceEvaluation.where({ assessmentId }) - .save({ status }, { require: true, patch: true }) - .then((updatedCompetenceEvaluation) => - bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, updatedCompetenceEvaluation) - ); - }, +const updateStatusByAssessmentId = function ({ assessmentId, status }) { + return BookshelfCompetenceEvaluation.where({ assessmentId }) + .save({ status }, { require: true, patch: true }) + .then((updatedCompetenceEvaluation) => + bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, updatedCompetenceEvaluation) + ); +}; - updateStatusByUserIdAndCompetenceId({ userId, competenceId, status }) { - return BookshelfCompetenceEvaluation.where({ userId, competenceId }) - .save({ status }, { require: true, patch: true }) - .then((updatedCompetenceEvaluation) => - bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, updatedCompetenceEvaluation) - ); - }, +const updateStatusByUserIdAndCompetenceId = function ({ userId, competenceId, status }) { + return BookshelfCompetenceEvaluation.where({ userId, competenceId }) + .save({ status }, { require: true, patch: true }) + .then((updatedCompetenceEvaluation) => + bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, updatedCompetenceEvaluation) + ); +}; - updateAssessmentId({ - currentAssessmentId, - newAssessmentId, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - return BookshelfCompetenceEvaluation.where({ assessmentId: currentAssessmentId }) - .save( - { assessmentId: newAssessmentId }, - { require: true, patch: true, transacting: domainTransaction.knexTransaction } - ) - .then((updatedCompetenceEvaluation) => - bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, updatedCompetenceEvaluation) - ); - }, +const updateAssessmentId = function ({ + currentAssessmentId, + newAssessmentId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + return BookshelfCompetenceEvaluation.where({ assessmentId: currentAssessmentId }) + .save( + { assessmentId: newAssessmentId }, + { require: true, patch: true, transacting: domainTransaction.knexTransaction } + ) + .then((updatedCompetenceEvaluation) => + bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, updatedCompetenceEvaluation) + ); +}; - getByAssessmentId(assessmentId) { - return BookshelfCompetenceEvaluation.where({ assessmentId }) - .orderBy('createdAt', 'asc') - .fetch({ withRelated: ['assessment'] }) - .then((result) => bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, result)) - .catch((bookshelfError) => { - if (bookshelfError instanceof BookshelfCompetenceEvaluation.NotFoundError) { - throw new NotFoundError(); - } - throw bookshelfError; - }); - }, +const getByAssessmentId = function (assessmentId) { + return BookshelfCompetenceEvaluation.where({ assessmentId }) + .orderBy('createdAt', 'asc') + .fetch({ withRelated: ['assessment'] }) + .then((result) => bookshelfToDomainConverter.buildDomainObject(BookshelfCompetenceEvaluation, result)) + .catch((bookshelfError) => { + if (bookshelfError instanceof BookshelfCompetenceEvaluation.NotFoundError) { + throw new NotFoundError(); + } + throw bookshelfError; + }); +}; - async getByCompetenceIdAndUserId({ +const getByCompetenceIdAndUserId = async function ({ + competenceId, + userId, + domainTransaction = DomainTransaction.emptyTransaction(), + forUpdate = false, +}) { + const competenceEvaluation = await _getByCompetenceIdAndUserId({ competenceId, userId, - domainTransaction = DomainTransaction.emptyTransaction(), - forUpdate = false, - }) { - const competenceEvaluation = await _getByCompetenceIdAndUserId({ - competenceId, - userId, - domainTransaction, - forUpdate, - }); - if (competenceEvaluation === null) { - throw new NotFoundError(); - } - return competenceEvaluation; - }, + domainTransaction, + forUpdate, + }); + if (competenceEvaluation === null) { + throw new NotFoundError(); + } + return competenceEvaluation; +}; - findByUserId(userId) { - return BookshelfCompetenceEvaluation.where({ userId }) - .orderBy('createdAt', 'asc') - .fetchAll({ withRelated: ['assessment'] }) - .then((results) => bookshelfToDomainConverter.buildDomainObjects(BookshelfCompetenceEvaluation, results)) - .then(_selectOnlyOneCompetenceEvaluationByCompetence); - }, +const findByUserId = function (userId) { + return BookshelfCompetenceEvaluation.where({ userId }) + .orderBy('createdAt', 'asc') + .fetchAll({ withRelated: ['assessment'] }) + .then((results) => bookshelfToDomainConverter.buildDomainObjects(BookshelfCompetenceEvaluation, results)) + .then(_selectOnlyOneCompetenceEvaluationByCompetence); +}; - findByAssessmentId(assessmentId) { - return BookshelfCompetenceEvaluation.where({ assessmentId }) - .orderBy('createdAt', 'asc') - .fetchAll() - .then((results) => bookshelfToDomainConverter.buildDomainObjects(BookshelfCompetenceEvaluation, results)); - }, +const findByAssessmentId = function (assessmentId) { + return BookshelfCompetenceEvaluation.where({ assessmentId }) + .orderBy('createdAt', 'asc') + .fetchAll() + .then((results) => bookshelfToDomainConverter.buildDomainObjects(BookshelfCompetenceEvaluation, results)); +}; + +const existsByCompetenceIdAndUserId = async function ({ competenceId, userId }) { + const competenceEvaluation = await _getByCompetenceIdAndUserId({ competenceId, userId }); + return competenceEvaluation ? true : false; +}; - async existsByCompetenceIdAndUserId({ competenceId, userId }) { - const competenceEvaluation = await _getByCompetenceIdAndUserId({ competenceId, userId }); - return competenceEvaluation ? true : false; - }, +export { + save, + updateStatusByAssessmentId, + updateStatusByUserIdAndCompetenceId, + updateAssessmentId, + getByAssessmentId, + getByCompetenceIdAndUserId, + findByUserId, + findByAssessmentId, + existsByCompetenceIdAndUserId, }; async function _getByCompetenceIdAndUserId({ diff --git a/api/lib/infrastructure/repositories/competence-mark-repository.js b/api/lib/infrastructure/repositories/competence-mark-repository.js index e0c84a83213..11896033863 100644 --- a/api/lib/infrastructure/repositories/competence-mark-repository.js +++ b/api/lib/infrastructure/repositories/competence-mark-repository.js @@ -1,51 +1,51 @@ -const BookshelfCompetenceMark = require('../orm-models/CompetenceMark.js'); -const CompetenceMark = require('../../domain/models/CompetenceMark.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import { BookshelfCompetenceMark } from '../orm-models/CompetenceMark.js'; +import { CompetenceMark } from '../../domain/models/CompetenceMark.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; function _toDomain(competenceMark) { return new CompetenceMark(competenceMark); } -module.exports = { - async save(competenceMark, domainTransaction = DomainTransaction.emptyTransaction()) { - await competenceMark.validate(); - const savedCompetenceMark = await new BookshelfCompetenceMark(competenceMark).save(null, { - transacting: domainTransaction.knexTransaction, - }); - return savedCompetenceMark.toDomainEntity(); - }, +const save = async function (competenceMark, domainTransaction = DomainTransaction.emptyTransaction()) { + await competenceMark.validate(); + const savedCompetenceMark = await new BookshelfCompetenceMark(competenceMark).save(null, { + transacting: domainTransaction.knexTransaction, + }); + return savedCompetenceMark.toDomainEntity(); +}; - async findByAssessmentResultId(assessmentResultId) { - const competenceMarks = await BookshelfCompetenceMark.where({ assessmentResultId }).fetchAll(); - return competenceMarks.models.map((model) => _toDomain(model.attributes)); - }, +const findByAssessmentResultId = async function (assessmentResultId) { + const competenceMarks = await BookshelfCompetenceMark.where({ assessmentResultId }).fetchAll(); + return competenceMarks.models.map((model) => _toDomain(model.attributes)); +}; - async findByCertificationCourseId(certificationCourseId) { - const competenceMarks = await knex - .select( - 'competence-marks.id', - 'competence-marks.area_code', - 'competence-marks.competence_code', - 'competence-marks.competenceId', - 'competence-marks.level', - 'competence-marks.score', - 'competence-marks.assessmentResultId' - ) - .from('assessments') - .join('assessment-results', 'assessments.id', 'assessment-results.assessmentId') - .leftJoin({ 'latest-assessment-results': 'assessment-results' }, function () { - this.on('assessments.id', 'latest-assessment-results.assessmentId').andOn( - 'assessment-results.createdAt', - '<', - 'latest-assessment-results.createdAt' - ); - }) - .join('competence-marks', 'assessment-results.id', 'competence-marks.assessmentResultId') - .whereNull('latest-assessment-results.id') - .where('assessments.certificationCourseId', certificationCourseId) - .orderBy('competence-marks.id'); +const findByCertificationCourseId = async function (certificationCourseId) { + const competenceMarks = await knex + .select( + 'competence-marks.id', + 'competence-marks.area_code', + 'competence-marks.competence_code', + 'competence-marks.competenceId', + 'competence-marks.level', + 'competence-marks.score', + 'competence-marks.assessmentResultId' + ) + .from('assessments') + .join('assessment-results', 'assessments.id', 'assessment-results.assessmentId') + .leftJoin({ 'latest-assessment-results': 'assessment-results' }, function () { + this.on('assessments.id', 'latest-assessment-results.assessmentId').andOn( + 'assessment-results.createdAt', + '<', + 'latest-assessment-results.createdAt' + ); + }) + .join('competence-marks', 'assessment-results.id', 'competence-marks.assessmentResultId') + .whereNull('latest-assessment-results.id') + .where('assessments.certificationCourseId', certificationCourseId) + .orderBy('competence-marks.id'); - return competenceMarks.map(_toDomain); - }, + return competenceMarks.map(_toDomain); }; + +export { save, findByAssessmentResultId, findByCertificationCourseId }; diff --git a/api/lib/infrastructure/repositories/competence-repository.js b/api/lib/infrastructure/repositories/competence-repository.js index 612ba7e7954..0ff1a8991d2 100644 --- a/api/lib/infrastructure/repositories/competence-repository.js +++ b/api/lib/infrastructure/repositories/competence-repository.js @@ -1,11 +1,13 @@ -const _ = require('lodash'); -const LearningContentResourceNotFound = require('../datasources/learning-content/LearningContentResourceNotFound.js'); -const Competence = require('../../domain/models/Competence.js'); -const { competenceDatasource } = require('../datasources/learning-content/competence-datasource.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const { FRENCH_FRANCE } = require('../../domain/constants.js').LOCALE; -const { PIX_ORIGIN } = require('../../domain/constants.js'); -const { getTranslatedKey } = require('../../domain/services/get-translated-text.js'); +import _ from 'lodash'; +import { LearningContentResourceNotFound } from '../datasources/learning-content/LearningContentResourceNotFound.js'; +import { Competence } from '../../domain/models/Competence.js'; +import { competenceDatasource } from '../datasources/learning-content/competence-datasource.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { LOCALE, PIX_ORIGIN } from '../../domain/constants.js'; + +const { FRENCH_FRANCE } = LOCALE; + +import { getTranslatedKey } from '../../domain/services/get-translated-text.js'; function _toDomain({ competenceData, locale }) { const translatedCompetenceName = getTranslatedKey(competenceData.name_i18n, locale); @@ -23,55 +25,55 @@ function _toDomain({ competenceData, locale }) { }); } -module.exports = { - list({ locale } = { locale: FRENCH_FRANCE }) { - return _list({ locale: locale || FRENCH_FRANCE }); - }, +const list = function ({ locale } = { locale: FRENCH_FRANCE }) { + return _list({ locale: locale || FRENCH_FRANCE }); +}; - async listPixCompetencesOnly({ locale } = { locale: FRENCH_FRANCE }) { - const allCompetences = await _list({ locale }); - return allCompetences.filter((competence) => competence.origin === PIX_ORIGIN); - }, +const listPixCompetencesOnly = async function ({ locale } = { locale: FRENCH_FRANCE }) { + const allCompetences = await _list({ locale }); + return allCompetences.filter((competence) => competence.origin === PIX_ORIGIN); +}; - async get({ id, locale }) { - try { - const competenceData = await competenceDatasource.get(id); - return _toDomain({ competenceData, locale }); - } catch (err) { - if (err instanceof LearningContentResourceNotFound) { - throw new NotFoundError('La compétence demandée n’existe pas'); - } - throw err; +const get = async function ({ id, locale }) { + try { + const competenceData = await competenceDatasource.get(id); + return _toDomain({ competenceData, locale }); + } catch (err) { + if (err instanceof LearningContentResourceNotFound) { + throw new NotFoundError('La compétence demandée n’existe pas'); } - }, + throw err; + } +}; - async getCompetenceName({ id, locale }) { - try { - const competence = await competenceDatasource.get(id); - return getTranslatedKey(competence.name_i18n, locale); - } catch (err) { - if (err instanceof LearningContentResourceNotFound) { - throw new NotFoundError('La compétence demandée n’existe pas'); - } - throw err; +const getCompetenceName = async function ({ id, locale }) { + try { + const competence = await competenceDatasource.get(id); + return getTranslatedKey(competence.name_i18n, locale); + } catch (err) { + if (err instanceof LearningContentResourceNotFound) { + throw new NotFoundError('La compétence demandée n’existe pas'); } - }, + throw err; + } +}; - async findByRecordIds({ competenceIds, locale }) { - const competenceDatas = await competenceDatasource.list(); - return competenceDatas - .filter(({ id }) => competenceIds.includes(id)) - .map((competenceData) => _toDomain({ competenceData, locale })); - }, +const findByRecordIds = async function ({ competenceIds, locale }) { + const competenceDatas = await competenceDatasource.list(); + return competenceDatas + .filter(({ id }) => competenceIds.includes(id)) + .map((competenceData) => _toDomain({ competenceData, locale })); +}; - async findByAreaId({ areaId, locale }) { - const competenceDatas = await competenceDatasource.list(); - return competenceDatas - .filter((competenceData) => competenceData.areaId === areaId) - .map((competenceData) => _toDomain({ competenceData, locale })); - }, +const findByAreaId = async function ({ areaId, locale }) { + const competenceDatas = await competenceDatasource.list(); + return competenceDatas + .filter((competenceData) => competenceData.areaId === areaId) + .map((competenceData) => _toDomain({ competenceData, locale })); }; +export { list, listPixCompetencesOnly, get, getCompetenceName, findByRecordIds, findByAreaId }; + async function _list({ locale }) { const competenceDatas = await competenceDatasource.list(); return _.sortBy( diff --git a/api/lib/infrastructure/repositories/competence-tree-repository.js b/api/lib/infrastructure/repositories/competence-tree-repository.js index 0a78996eb1b..4444e38ee90 100644 --- a/api/lib/infrastructure/repositories/competence-tree-repository.js +++ b/api/lib/infrastructure/repositories/competence-tree-repository.js @@ -1,9 +1,9 @@ -const areaRepository = require('./area-repository.js'); -const CompetenceTree = require('../../domain/models/CompetenceTree.js'); +import * as areaRepository from './area-repository.js'; +import { CompetenceTree } from '../../domain/models/CompetenceTree.js'; -module.exports = { - async get({ locale, dependencies = { areaRepository } } = {}) { - const areas = await dependencies.areaRepository.listWithPixCompetencesOnly({ locale }); - return new CompetenceTree({ areas }); - }, +const get = async function ({ locale, dependencies = { areaRepository } } = {}) { + const areas = await dependencies.areaRepository.listWithPixCompetencesOnly({ locale }); + return new CompetenceTree({ areas }); }; + +export { get }; diff --git a/api/lib/infrastructure/repositories/complementary-certification-course-repository.js b/api/lib/infrastructure/repositories/complementary-certification-course-repository.js index 249a1c2fe8c..efdaf9c85c5 100644 --- a/api/lib/infrastructure/repositories/complementary-certification-course-repository.js +++ b/api/lib/infrastructure/repositories/complementary-certification-course-repository.js @@ -1,18 +1,21 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async getComplementaryCertificationCourseId({ certificationCourseId, complementaryCertificationKey }) { - const result = await knex - .from('complementary-certification-courses') - .select('complementary-certification-courses.id') - .innerJoin( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-courses.complementaryCertificationId' - ) - .where({ certificationCourseId, key: complementaryCertificationKey }) - .first(); +const getComplementaryCertificationCourseId = async function ({ + certificationCourseId, + complementaryCertificationKey, +}) { + const result = await knex + .from('complementary-certification-courses') + .select('complementary-certification-courses.id') + .innerJoin( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-courses.complementaryCertificationId' + ) + .where({ certificationCourseId, key: complementaryCertificationKey }) + .first(); - return result?.id; - }, + return result?.id; }; + +export { getComplementaryCertificationCourseId }; diff --git a/api/lib/infrastructure/repositories/complementary-certification-course-result-repository.js b/api/lib/infrastructure/repositories/complementary-certification-course-result-repository.js index 79fb60e8e67..3f629ba108c 100644 --- a/api/lib/infrastructure/repositories/complementary-certification-course-result-repository.js +++ b/api/lib/infrastructure/repositories/complementary-certification-course-result-repository.js @@ -1,29 +1,29 @@ -const ComplementaryCertificationCourseResult = require('../../domain/models/ComplementaryCertificationCourseResult.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import { ComplementaryCertificationCourseResult } from '../../domain/models/ComplementaryCertificationCourseResult.js'; +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async getPixSourceResultByComplementaryCertificationCourseId({ complementaryCertificationCourseId }) { - const result = await knex - .select('*') - .from('complementary-certification-course-results') - .where({ complementaryCertificationCourseId, source: ComplementaryCertificationCourseResult.sources.PIX }) - .first(); +const getPixSourceResultByComplementaryCertificationCourseId = async function ({ complementaryCertificationCourseId }) { + const result = await knex + .select('*') + .from('complementary-certification-course-results') + .where({ complementaryCertificationCourseId, source: ComplementaryCertificationCourseResult.sources.PIX }) + .first(); - if (!result) return null; + if (!result) return null; - return ComplementaryCertificationCourseResult.from(result); - }, + return ComplementaryCertificationCourseResult.from(result); +}; - async getAllowedJuryLevelByBadgeKey({ key }) { - return knex('badges') - .pluck('key') - .where('targetProfileId', '=', knex('badges').select('targetProfileId').where({ key })); - }, +const getAllowedJuryLevelByBadgeKey = async function ({ key }) { + return knex('badges') + .pluck('key') + .where('targetProfileId', '=', knex('badges').select('targetProfileId').where({ key })); +}; - async save({ complementaryCertificationCourseId, partnerKey, acquired, source }) { - return knex('complementary-certification-course-results') - .insert({ partnerKey, acquired, complementaryCertificationCourseId, source }) - .onConflict(['complementaryCertificationCourseId', 'source']) - .merge(); - }, +const save = async function ({ complementaryCertificationCourseId, partnerKey, acquired, source }) { + return knex('complementary-certification-course-results') + .insert({ partnerKey, acquired, complementaryCertificationCourseId, source }) + .onConflict(['complementaryCertificationCourseId', 'source']) + .merge(); }; + +export { getPixSourceResultByComplementaryCertificationCourseId, getAllowedJuryLevelByBadgeKey, save }; diff --git a/api/lib/infrastructure/repositories/complementary-certification-habilitation-repository.js b/api/lib/infrastructure/repositories/complementary-certification-habilitation-repository.js index 03f4ad0b8ed..ff0c3ab69b1 100644 --- a/api/lib/infrastructure/repositories/complementary-certification-habilitation-repository.js +++ b/api/lib/infrastructure/repositories/complementary-certification-habilitation-repository.js @@ -1,32 +1,32 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; const COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME = 'complementary-certification-habilitations'; -module.exports = { - async save(complementaryCertification) { - const columnsToSave = { - complementaryCertificationId: complementaryCertification.complementaryCertificationId, - certificationCenterId: complementaryCertification.certificationCenterId, - }; - return knex(COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME).insert(columnsToSave); - }, +const save = async function (complementaryCertification) { + const columnsToSave = { + complementaryCertificationId: complementaryCertification.complementaryCertificationId, + certificationCenterId: complementaryCertification.certificationCenterId, + }; + return knex(COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME).insert(columnsToSave); +}; - async deleteByCertificationCenterId(certificationCenterId) { - return knex(COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME).delete().where({ certificationCenterId }); - }, +const deleteByCertificationCenterId = async function (certificationCenterId) { + return knex(COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME).delete().where({ certificationCenterId }); +}; - async findByCertificationCenterId(certificationCenterId) { - return knex(COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME) - .select([ - 'complementary-certifications.id', - 'complementary-certifications.key', - 'complementary-certifications.label', - ]) - .join( - 'complementary-certifications', - 'complementary-certifications.id', - `${COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME}.complementaryCertificationId` - ) - .where(`${COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME}.certificationCenterId`, certificationCenterId); - }, +const findByCertificationCenterId = async function (certificationCenterId) { + return knex(COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME) + .select([ + 'complementary-certifications.id', + 'complementary-certifications.key', + 'complementary-certifications.label', + ]) + .join( + 'complementary-certifications', + 'complementary-certifications.id', + `${COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME}.complementaryCertificationId` + ) + .where(`${COMPLEMENTARY_CERTIFICATION_HABILITATIONS_TABLE_NAME}.certificationCenterId`, certificationCenterId); }; + +export { save, deleteByCertificationCenterId, findByCertificationCenterId }; diff --git a/api/lib/infrastructure/repositories/complementary-certification-repository.js b/api/lib/infrastructure/repositories/complementary-certification-repository.js index b708d30367a..01a9b5f3df5 100644 --- a/api/lib/infrastructure/repositories/complementary-certification-repository.js +++ b/api/lib/infrastructure/repositories/complementary-certification-repository.js @@ -1,5 +1,5 @@ -const ComplementaryCertification = require('../../domain/models/ComplementaryCertification.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import { ComplementaryCertification } from '../../domain/models/ComplementaryCertification.js'; +import { knex } from '../../../db/knex-database-connection.js'; function _toDomain(row) { return new ComplementaryCertification({ @@ -7,16 +7,16 @@ function _toDomain(row) { }); } -module.exports = { - async findAll() { - const result = await knex.from('complementary-certifications').select('id', 'label', 'key').orderBy('id', 'asc'); +const findAll = async function () { + const result = await knex.from('complementary-certifications').select('id', 'label', 'key').orderBy('id', 'asc'); - return result.map(_toDomain); - }, + return result.map(_toDomain); +}; - async getByLabel({ label }) { - const result = await knex.from('complementary-certifications').where({ label }).first(); +const getByLabel = async function ({ label }) { + const result = await knex.from('complementary-certifications').where({ label }).first(); - return _toDomain(result); - }, + return _toDomain(result); }; + +export { findAll, getByLabel }; diff --git a/api/lib/infrastructure/repositories/complementary-certification-scoring-criteria-repository.js b/api/lib/infrastructure/repositories/complementary-certification-scoring-criteria-repository.js index b7fcd0f7d87..354a49e5863 100644 --- a/api/lib/infrastructure/repositories/complementary-certification-scoring-criteria-repository.js +++ b/api/lib/infrastructure/repositories/complementary-certification-scoring-criteria-repository.js @@ -1,44 +1,44 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const ComplementaryCertificationScoringCriteria = require('../../domain/models/ComplementaryCertificationScoringCriteria.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { ComplementaryCertificationScoringCriteria } from '../../domain/models/ComplementaryCertificationScoringCriteria.js'; -module.exports = { - async findByCertificationCourseId({ certificationCourseId }) { - const results = await knex('complementary-certification-courses') - .select({ - complementaryCertificationCourseId: 'complementary-certification-courses.id', - minimumReproducibilityRate: 'complementary-certifications.minimumReproducibilityRate', - complementaryCertificationBadgeKey: 'badges.key', - hasComplementaryReferential: 'complementary-certifications.hasComplementaryReferential', - minimumEarnedPix: 'complementary-certifications.minimumEarnedPix', - }) - .join( - 'complementary-certification-badges', - 'complementary-certification-badges.id', - 'complementary-certification-courses.complementaryCertificationBadgeId' - ) - .join( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-badges.complementaryCertificationId' - ) - .join('badges', 'badges.id', 'complementary-certification-badges.badgeId') - .where({ certificationCourseId }); +const findByCertificationCourseId = async function ({ certificationCourseId }) { + const results = await knex('complementary-certification-courses') + .select({ + complementaryCertificationCourseId: 'complementary-certification-courses.id', + minimumReproducibilityRate: 'complementary-certifications.minimumReproducibilityRate', + complementaryCertificationBadgeKey: 'badges.key', + hasComplementaryReferential: 'complementary-certifications.hasComplementaryReferential', + minimumEarnedPix: 'complementary-certifications.minimumEarnedPix', + }) + .join( + 'complementary-certification-badges', + 'complementary-certification-badges.id', + 'complementary-certification-courses.complementaryCertificationBadgeId' + ) + .join( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-badges.complementaryCertificationId' + ) + .join('badges', 'badges.id', 'complementary-certification-badges.badgeId') + .where({ certificationCourseId }); - return results.map( - ({ + return results.map( + ({ + complementaryCertificationCourseId, + minimumReproducibilityRate, + complementaryCertificationBadgeKey, + hasComplementaryReferential, + minimumEarnedPix, + }) => + new ComplementaryCertificationScoringCriteria({ complementaryCertificationCourseId, - minimumReproducibilityRate, + minimumReproducibilityRate: Number(minimumReproducibilityRate), complementaryCertificationBadgeKey, hasComplementaryReferential, minimumEarnedPix, - }) => - new ComplementaryCertificationScoringCriteria({ - complementaryCertificationCourseId, - minimumReproducibilityRate: Number(minimumReproducibilityRate), - complementaryCertificationBadgeKey, - hasComplementaryReferential, - minimumEarnedPix, - }) - ); - }, + }) + ); }; + +export { findByCertificationCourseId }; diff --git a/api/lib/infrastructure/repositories/complementary-certification-subscription-repository.js b/api/lib/infrastructure/repositories/complementary-certification-subscription-repository.js index 22566f68c55..7984b1a76e6 100644 --- a/api/lib/infrastructure/repositories/complementary-certification-subscription-repository.js +++ b/api/lib/infrastructure/repositories/complementary-certification-subscription-repository.js @@ -1,7 +1,7 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async save(complementaryCertificationSubscription) { - return knex('complementary-certification-subscriptions').insert(complementaryCertificationSubscription); - }, +const save = async function (complementaryCertificationSubscription) { + return knex('complementary-certification-subscriptions').insert(complementaryCertificationSubscription); }; + +export { save }; diff --git a/api/lib/infrastructure/repositories/correction-repository.js b/api/lib/infrastructure/repositories/correction-repository.js index e93b21e6790..89caa8cb2b2 100644 --- a/api/lib/infrastructure/repositories/correction-repository.js +++ b/api/lib/infrastructure/repositories/correction-repository.js @@ -1,45 +1,45 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const Correction = require('../../domain/models/Correction.js'); -const Hint = require('../../domain/models/Hint.js'); -const { challengeDatasource } = require('../datasources/learning-content/challenge-datasource.js'); -const { skillDatasource } = require('../datasources/learning-content/skill-datasource.js'); -const tutorialRepository = require('./tutorial-repository.js'); +import { Correction } from '../../domain/models/Correction.js'; +import { Hint } from '../../domain/models/Hint.js'; +import { challengeDatasource } from '../datasources/learning-content/challenge-datasource.js'; +import { skillDatasource } from '../datasources/learning-content/skill-datasource.js'; +import * as tutorialRepository from './tutorial-repository.js'; const VALIDATED_HINT_STATUSES = ['Validé', 'pré-validé']; -const { getTranslatedKey } = require('../../domain/services/get-translated-text.js'); +import { getTranslatedKey } from '../../domain/services/get-translated-text.js'; -module.exports = { - async getByChallengeId({ challengeId, userId, locale, dependencies = { tutorialRepository } } = {}) { - const challenge = await challengeDatasource.get(challengeId); - const skill = await _getSkill(challenge); - const hint = await _getHint({ skill, locale }); +const getByChallengeId = async function ({ challengeId, userId, locale, dependencies = { tutorialRepository } } = {}) { + const challenge = await challengeDatasource.get(challengeId); + const skill = await _getSkill(challenge); + const hint = await _getHint({ skill, locale }); - const tutorials = await _getTutorials({ - userId, - skill, - tutorialIdsProperty: 'tutorialIds', - locale, - tutorialRepository: dependencies.tutorialRepository, - }); - const learningMoreTutorials = await _getTutorials({ - userId, - skill, - tutorialIdsProperty: 'learningMoreTutorialIds', - locale, - tutorialRepository: dependencies.tutorialRepository, - }); + const tutorials = await _getTutorials({ + userId, + skill, + tutorialIdsProperty: 'tutorialIds', + locale, + tutorialRepository: dependencies.tutorialRepository, + }); + const learningMoreTutorials = await _getTutorials({ + userId, + skill, + tutorialIdsProperty: 'learningMoreTutorialIds', + locale, + tutorialRepository: dependencies.tutorialRepository, + }); - return new Correction({ - id: challenge.id, - solution: challenge.solution, - solutionToDisplay: challenge.solutionToDisplay, - hint, - tutorials, - learningMoreTutorials: learningMoreTutorials, - }); - }, + return new Correction({ + id: challenge.id, + solution: challenge.solution, + solutionToDisplay: challenge.solutionToDisplay, + hint, + tutorials, + learningMoreTutorials: learningMoreTutorials, + }); }; +export { getByChallengeId }; + async function _getHint({ skill, locale }) { if (_hasValidatedHint(skill)) { return _convertSkillToHint({ skill, locale }); diff --git a/api/lib/infrastructure/repositories/country-repository.js b/api/lib/infrastructure/repositories/country-repository.js index c4c8979b60f..4e141e53d92 100644 --- a/api/lib/infrastructure/repositories/country-repository.js +++ b/api/lib/infrastructure/repositories/country-repository.js @@ -1,18 +1,18 @@ -const { Country } = require('../../domain/read-models/Country.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import { Country } from '../../domain/read-models/Country.js'; +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async findAll() { - const result = await knex - .from('certification-cpf-countries') - .select('commonName', 'code', 'matcher') - .where('commonName', '=', knex.ref('originalName')) - .orderBy('commonName', 'asc'); +const findAll = async function () { + const result = await knex + .from('certification-cpf-countries') + .select('commonName', 'code', 'matcher') + .where('commonName', '=', knex.ref('originalName')) + .orderBy('commonName', 'asc'); - return result.map(_toDomain); - }, + return result.map(_toDomain); }; +export { findAll }; + function _toDomain(row) { return new Country({ ...row, diff --git a/api/lib/infrastructure/repositories/course-repository.js b/api/lib/infrastructure/repositories/course-repository.js index 04569c52cea..a00d82bd820 100644 --- a/api/lib/infrastructure/repositories/course-repository.js +++ b/api/lib/infrastructure/repositories/course-repository.js @@ -1,7 +1,7 @@ -const Course = require('../../domain/models/Course.js'); -const { courseDatasource } = require('../datasources/learning-content/course-datasource.js'); -const LearningContentResourceNotFound = require('../datasources/learning-content/LearningContentResourceNotFound.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import { Course } from '../../domain/models/Course.js'; +import { courseDatasource } from '../datasources/learning-content/course-datasource.js'; +import { LearningContentResourceNotFound } from '../datasources/learning-content/LearningContentResourceNotFound.js'; +import { NotFoundError } from '../../domain/errors.js'; function _toDomain(courseDataObject) { return new Course({ @@ -26,17 +26,17 @@ async function _get(id) { } } -module.exports = { - async get(id) { - return _get(id); - }, +const get = async function (id) { + return _get(id); +}; - async getCourseName(id) { - try { - const course = await _get(id); - return course.name; - } catch (err) { - throw new NotFoundError("Le test demandé n'existe pas"); - } - }, +const getCourseName = async function (id) { + try { + const course = await _get(id); + return course.name; + } catch (err) { + throw new NotFoundError("Le test demandé n'existe pas"); + } }; + +export { get, getCourseName }; diff --git a/api/lib/infrastructure/repositories/cpf-certification-result-repository.js b/api/lib/infrastructure/repositories/cpf-certification-result-repository.js index cc3385aa8d4..664776f88ab 100644 --- a/api/lib/infrastructure/repositories/cpf-certification-result-repository.js +++ b/api/lib/infrastructure/repositories/cpf-certification-result-repository.js @@ -1,72 +1,78 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CpfCertificationResult = require('../../domain/read-models/CpfCertificationResult.js'); -const AssessmentResult = require('../../domain/models/AssessmentResult.js'); -const { cpfImportStatus } = require('../../domain/models/CertificationCourse.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CpfCertificationResult } from '../../domain/read-models/CpfCertificationResult.js'; +import { AssessmentResult } from '../../domain/models/AssessmentResult.js'; +import { cpfImportStatus } from '../../domain/models/CertificationCourse.js'; -module.exports = { - async countByTimeRange({ startDate, endDate }) { - const query = _selectCpfCertificationResults(); - const { count } = await _filterQuery(query, startDate, endDate) - .count('certification-courses.id') - .whereNull('certification-courses.cpfImportStatus') - .first(); - return count; - }, +const countByTimeRange = async function ({ startDate, endDate }) { + const query = _selectCpfCertificationResults(); + const { count } = await _filterQuery(query, startDate, endDate) + .count('certification-courses.id') + .whereNull('certification-courses.cpfImportStatus') + .first(); + return count; +}; + +const findByBatchId = async function (batchId) { + const cpfCertificationResults = await _selectCpfCertificationResults() + .select('certification-courses.*', 'assessment-results.pixScore', 'sessions.publishedAt') + .select( + knex.raw(` + json_agg(json_build_object( + 'competenceCode', "competence-marks"."competence_code", + 'areaCode', "competence-marks"."area_code", + 'level', "competence-marks"."level" + ) ORDER BY "competence-marks"."competence_code" asc) as "competenceMarks"`) + ) + .innerJoin('competence-marks', 'competence-marks.assessmentResultId', 'assessment-results.id') + .where('certification-courses.cpfFilename', batchId) + .groupBy('certification-courses.id', 'assessment-results.pixScore', 'sessions.publishedAt'); + return cpfCertificationResults.map((certificationCourse) => new CpfCertificationResult(certificationCourse)); +}; - async findByBatchId(batchId) { - const cpfCertificationResults = await _selectCpfCertificationResults() - .select('certification-courses.*', 'assessment-results.pixScore', 'sessions.publishedAt') - .select( - knex.raw(` - json_agg(json_build_object( - 'competenceCode', "competence-marks"."competence_code", - 'areaCode', "competence-marks"."area_code", - 'level', "competence-marks"."level" - ) ORDER BY "competence-marks"."competence_code" asc) as "competenceMarks"`) - ) - .innerJoin('competence-marks', 'competence-marks.assessmentResultId', 'assessment-results.id') - .where('certification-courses.cpfFilename', batchId) - .groupBy('certification-courses.id', 'assessment-results.pixScore', 'sessions.publishedAt'); - return cpfCertificationResults.map((certificationCourse) => new CpfCertificationResult(certificationCourse)); - }, +const markCertificationCoursesAsExported = async function ({ certificationCourseIds, filename }) { + const now = new Date(); - async markCertificationCoursesAsExported({ certificationCourseIds, filename }) { - const now = new Date(); + return knex('certification-courses') + .update({ cpfFilename: filename, cpfImportStatus: cpfImportStatus.READY_TO_SEND, updatedAt: now }) + .whereIn('id', certificationCourseIds); +}; - return knex('certification-courses') - .update({ cpfFilename: filename, cpfImportStatus: cpfImportStatus.READY_TO_SEND, updatedAt: now }) - .whereIn('id', certificationCourseIds); - }, +const markCertificationToExport = async function ({ startDate, endDate, limit = 'ALL', offset = 0, batchId }) { + const now = new Date(); - async markCertificationToExport({ startDate, endDate, limit = 'ALL', offset = 0, batchId }) { - const now = new Date(); + return knex + .with('certification-courses-to-mark', (qb) => { + const query = _selectCpfCertificationResults(qb); + return _filterQuery(query, startDate, endDate) + .select('certification-courses.id') + .where((qb) => { + qb.orWhereNull('certification-courses.cpfImportStatus'); + qb.orWhere('certification-courses.cpfImportStatus', cpfImportStatus.PENDING); + }) + .orderBy('certification-courses.id') + .offset(offset) + .limit(limit); + }) + .update({ cpfFilename: batchId, cpfImportStatus: cpfImportStatus.PENDING, updatedAt: now }) + .from('certification-courses') + .whereIn('id', knex.select('id').from('certification-courses-to-mark')) + .whereNull('certification-courses.cpfImportStatus'); +}; - return knex - .with('certification-courses-to-mark', (qb) => { - const query = _selectCpfCertificationResults(qb); - return _filterQuery(query, startDate, endDate) - .select('certification-courses.id') - .where((qb) => { - qb.orWhereNull('certification-courses.cpfImportStatus'); - qb.orWhere('certification-courses.cpfImportStatus', cpfImportStatus.PENDING); - }) - .orderBy('certification-courses.id') - .offset(offset) - .limit(limit); - }) - .update({ cpfFilename: batchId, cpfImportStatus: cpfImportStatus.PENDING, updatedAt: now }) - .from('certification-courses') - .whereIn('id', knex.select('id').from('certification-courses-to-mark')) - .whereNull('certification-courses.cpfImportStatus'); - }, +const updateCertificationImportStatus = async function ({ certificationCourseIds, cpfImportStatus }) { + const now = new Date(); - async updateCertificationImportStatus({ certificationCourseIds, cpfImportStatus }) { - const now = new Date(); + return knex('certification-courses') + .update({ cpfImportStatus, updatedAt: now }) + .whereIn('id', certificationCourseIds); +}; - return knex('certification-courses') - .update({ cpfImportStatus, updatedAt: now }) - .whereIn('id', certificationCourseIds); - }, +export { + countByTimeRange, + findByBatchId, + markCertificationCoursesAsExported, + markCertificationToExport, + updateCertificationImportStatus, }; function _selectCpfCertificationResults(qb = knex) { diff --git a/api/lib/infrastructure/repositories/data-protection-officer-repository.js b/api/lib/infrastructure/repositories/data-protection-officer-repository.js index 8a8c3330949..f5efae2355b 100644 --- a/api/lib/infrastructure/repositories/data-protection-officer-repository.js +++ b/api/lib/infrastructure/repositories/data-protection-officer-repository.js @@ -1,6 +1,6 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const DataProtectionOfficer = require('../../domain/models/DataProtectionOfficer.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { DataProtectionOfficer } from '../../domain/models/DataProtectionOfficer.js'; +import { DomainTransaction } from '../DomainTransaction.js'; const DATA_PROTECTION_OFFICERS_TABLE_NAME = 'data-protection-officers'; @@ -59,9 +59,4 @@ async function update(dataProtectionOfficer) { return new DataProtectionOfficer(dataProtectionOfficerRow); } -module.exports = { - batchAddDataProtectionOfficerToOrganization, - create, - get, - update, -}; +export { batchAddDataProtectionOfficerToOrganization, create, get, update }; diff --git a/api/lib/infrastructure/repositories/division-repository.js b/api/lib/infrastructure/repositories/division-repository.js index 09e602e8ecf..0f57ce122ea 100644 --- a/api/lib/infrastructure/repositories/division-repository.js +++ b/api/lib/infrastructure/repositories/division-repository.js @@ -1,5 +1,5 @@ -const Division = require('../../domain/models/Division.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import { Division } from '../../domain/models/Division.js'; +import { knex } from '../../../db/knex-database-connection.js'; async function findByCampaignId(campaignId) { const divisions = await knex('view-active-organization-learners') @@ -31,7 +31,4 @@ function _toDomain(division) { return new Division({ name: division }); } -module.exports = { - findByCampaignId, - findByOrganizationIdForCurrentSchoolYear, -}; +export { findByCampaignId, findByOrganizationIdForCurrentSchoolYear }; diff --git a/api/lib/infrastructure/repositories/flash-assessment-result-repository.js b/api/lib/infrastructure/repositories/flash-assessment-result-repository.js index 8e1f79144fa..f495e38b1c4 100644 --- a/api/lib/infrastructure/repositories/flash-assessment-result-repository.js +++ b/api/lib/infrastructure/repositories/flash-assessment-result-repository.js @@ -1,27 +1,27 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; const TABLE_NAME = 'flash-assessment-results'; -module.exports = { - async save({ +const save = async function ({ + answerId, + estimatedLevel, + errorRate, + assessmentId, + domainTransaction: { knexTransaction } = DomainTransaction.emptyTransaction(), +}) { + const query = knex(TABLE_NAME).insert({ answerId, estimatedLevel, errorRate, assessmentId, - domainTransaction: { knexTransaction } = DomainTransaction.emptyTransaction(), - }) { - const query = knex(TABLE_NAME).insert({ - answerId, - estimatedLevel, - errorRate, - assessmentId, - }); - if (knexTransaction) query.transacting(knexTransaction); - return query; - }, + }); + if (knexTransaction) query.transacting(knexTransaction); + return query; +}; - async getLatestByAssessmentId(assessmentId) { - return knex(TABLE_NAME).where({ assessmentId }).orderBy('id', 'desc').limit(1).first(); - }, +const getLatestByAssessmentId = async function (assessmentId) { + return knex(TABLE_NAME).where({ assessmentId }).orderBy('id', 'desc').limit(1).first(); }; + +export { save, getLatestByAssessmentId }; diff --git a/api/lib/infrastructure/repositories/framework-repository.js b/api/lib/infrastructure/repositories/framework-repository.js index 14316f2f61b..b148550d39f 100644 --- a/api/lib/infrastructure/repositories/framework-repository.js +++ b/api/lib/infrastructure/repositories/framework-repository.js @@ -1,7 +1,7 @@ -const Framework = require('../../domain/models/Framework.js'); -const { frameworkDatasource } = require('../datasources/learning-content/framework-datasource.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const _ = require('lodash'); +import { Framework } from '../../domain/models/Framework.js'; +import { frameworkDatasource } from '../datasources/learning-content/framework-datasource.js'; +import { NotFoundError } from '../../domain/errors.js'; +import _ from 'lodash'; async function list() { const frameworkDataObjects = await frameworkDatasource.list(); @@ -31,8 +31,4 @@ async function findByRecordIds(frameworkIds) { return _.orderBy(frameworks, (framework) => framework.name.toLowerCase()); } -module.exports = { - list, - getByName, - findByRecordIds, -}; +export { list, getByName, findByRecordIds }; diff --git a/api/lib/infrastructure/repositories/group-repository.js b/api/lib/infrastructure/repositories/group-repository.js index 0ea7fd985e8..c0e877ee43c 100644 --- a/api/lib/infrastructure/repositories/group-repository.js +++ b/api/lib/infrastructure/repositories/group-repository.js @@ -1,5 +1,5 @@ -const Group = require('../../domain/models/Group.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import { Group } from '../../domain/models/Group.js'; +import { knex } from '../../../db/knex-database-connection.js'; async function findByCampaignId(campaignId) { const groups = await knex('view-active-organization-learners') @@ -31,7 +31,4 @@ function _toDomain(group) { return new Group({ name: group }); } -module.exports = { - findByCampaignId, - findByOrganizationId, -}; +export { findByCampaignId, findByOrganizationId }; diff --git a/api/lib/infrastructure/repositories/issue-report-category-repository.js b/api/lib/infrastructure/repositories/issue-report-category-repository.js index 1b9f1064d66..9ce8d789c04 100644 --- a/api/lib/infrastructure/repositories/issue-report-category-repository.js +++ b/api/lib/infrastructure/repositories/issue-report-category-repository.js @@ -1,7 +1,7 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async get({ name }) { - return knex('issue-report-categories').where({ name }).first(); - }, +const get = async function ({ name }) { + return knex('issue-report-categories').where({ name }).first(); }; + +export { get }; diff --git a/api/lib/infrastructure/repositories/jury-certification-repository.js b/api/lib/infrastructure/repositories/jury-certification-repository.js index 1bdb1f68f72..565119019d6 100644 --- a/api/lib/infrastructure/repositories/jury-certification-repository.js +++ b/api/lib/infrastructure/repositories/jury-certification-repository.js @@ -1,67 +1,67 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const _ = require('lodash'); -const JuryCertification = require('../../domain/models/JuryCertification.js'); -const CertificationIssueReport = require('../../domain/models/CertificationIssueReport.js'); -const ComplementaryCertificationCourseResultsForJuryCertification = require('../../domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification.js'); -const ComplementaryCertificationCourseResultsForJuryCertificationWithExternal = require('../../domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal.js'); - -module.exports = { - async get(certificationCourseId) { - const juryCertificationDTO = await _selectJuryCertifications() - .where('certification-courses.id', certificationCourseId) - .first(); - - if (!juryCertificationDTO) { - throw new NotFoundError(`Certification course of id ${certificationCourseId} does not exist.`); - } - - const competenceMarkDTOs = await knex('competence-marks') - .where({ - assessmentResultId: juryCertificationDTO.assessmentResultId, - }) - .orderBy('competence_code', 'asc'); - - const complementaryCertificationCourseResultDTOs = await knex('complementary-certification-course-results') - .select( - 'complementary-certification-course-results.*', - 'complementary-certification-courses.id', - 'complementary-certification-badges.label', - 'complementary-certification-badges.level', - 'complementary-certifications.hasExternalJury' - ) - .leftJoin( - 'complementary-certification-courses', - 'complementary-certification-course-results.complementaryCertificationCourseId', - 'complementary-certification-courses.id' - ) - .leftJoin('badges', 'badges.key', 'complementary-certification-course-results.partnerKey') - .leftJoin('complementary-certification-badges', 'complementary-certification-badges.badgeId', 'badges.id') - .leftJoin( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-badges.complementaryCertificationId' - ) - .where({ - certificationCourseId: juryCertificationDTO.certificationCourseId, - }); - - const badgeKeyAndLabelsGroupedByTargetProfile = await _getBadgeKeyAndLabelsGroupedByTargetProfile(); - - const certificationIssueReportDTOs = await knex('certification-issue-reports') - .where({ certificationCourseId }) - .orderBy('id', 'ASC'); - - return _toDomainWithComplementaryCertifications({ - juryCertificationDTO, - certificationIssueReportDTOs, - competenceMarkDTOs, - complementaryCertificationCourseResultDTOs, - badgeKeyAndLabelsGroupedByTargetProfile, +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../domain/errors.js'; +import _ from 'lodash'; +import { JuryCertification } from '../../domain/models/JuryCertification.js'; +import { CertificationIssueReport } from '../../domain/models/CertificationIssueReport.js'; +import { ComplementaryCertificationCourseResultsForJuryCertification } from '../../domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification.js'; +import { ComplementaryCertificationCourseResultsForJuryCertificationWithExternal } from '../../domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal.js'; + +const get = async function (certificationCourseId) { + const juryCertificationDTO = await _selectJuryCertifications() + .where('certification-courses.id', certificationCourseId) + .first(); + + if (!juryCertificationDTO) { + throw new NotFoundError(`Certification course of id ${certificationCourseId} does not exist.`); + } + + const competenceMarkDTOs = await knex('competence-marks') + .where({ + assessmentResultId: juryCertificationDTO.assessmentResultId, + }) + .orderBy('competence_code', 'asc'); + + const complementaryCertificationCourseResultDTOs = await knex('complementary-certification-course-results') + .select( + 'complementary-certification-course-results.*', + 'complementary-certification-courses.id', + 'complementary-certification-badges.label', + 'complementary-certification-badges.level', + 'complementary-certifications.hasExternalJury' + ) + .leftJoin( + 'complementary-certification-courses', + 'complementary-certification-course-results.complementaryCertificationCourseId', + 'complementary-certification-courses.id' + ) + .leftJoin('badges', 'badges.key', 'complementary-certification-course-results.partnerKey') + .leftJoin('complementary-certification-badges', 'complementary-certification-badges.badgeId', 'badges.id') + .leftJoin( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-badges.complementaryCertificationId' + ) + .where({ + certificationCourseId: juryCertificationDTO.certificationCourseId, }); - }, + + const badgeKeyAndLabelsGroupedByTargetProfile = await _getBadgeKeyAndLabelsGroupedByTargetProfile(); + + const certificationIssueReportDTOs = await knex('certification-issue-reports') + .where({ certificationCourseId }) + .orderBy('id', 'ASC'); + + return _toDomainWithComplementaryCertifications({ + juryCertificationDTO, + certificationIssueReportDTOs, + competenceMarkDTOs, + complementaryCertificationCourseResultDTOs, + badgeKeyAndLabelsGroupedByTargetProfile, + }); }; +export { get }; + function _selectJuryCertifications() { return knex .select({ diff --git a/api/lib/infrastructure/repositories/jury-certification-summary-repository.js b/api/lib/infrastructure/repositories/jury-certification-summary-repository.js index 819e1663310..d5a901417fb 100644 --- a/api/lib/infrastructure/repositories/jury-certification-summary-repository.js +++ b/api/lib/infrastructure/repositories/jury-certification-summary-repository.js @@ -1,45 +1,45 @@ -const _ = require('lodash'); -const { fetchPage } = require('../utils/knex-utils.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const JuryCertificationSummary = require('../../domain/read-models/JuryCertificationSummary.js'); -const CertificationIssueReport = require('../../domain/models/CertificationIssueReport.js'); -const Assessment = require('../../domain/models/Assessment.js'); -const ComplementaryCertificationCourseResult = require('../../domain/models/ComplementaryCertificationCourseResult.js'); +import _ from 'lodash'; +import { fetchPage } from '../utils/knex-utils.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { JuryCertificationSummary } from '../../domain/read-models/JuryCertificationSummary.js'; +import { CertificationIssueReport } from '../../domain/models/CertificationIssueReport.js'; +import { Assessment } from '../../domain/models/Assessment.js'; +import { ComplementaryCertificationCourseResult } from '../../domain/models/ComplementaryCertificationCourseResult.js'; -module.exports = { - async findBySessionId(sessionId) { - const result = await _getCertificationCoursesIdBySessionIdQuery(sessionId); +const findBySessionId = async function (sessionId) { + const result = await _getCertificationCoursesIdBySessionIdQuery(sessionId); - const certificationCourseIds = result.map((obj) => obj.id); + const certificationCourseIds = result.map((obj) => obj.id); - const results = await _getByCertificationCourseIds(certificationCourseIds); + const results = await _getByCertificationCourseIds(certificationCourseIds); - const juryCertificationSummaryDTOs = await _getJuryCertificationSummaries(results); + const juryCertificationSummaryDTOs = await _getJuryCertificationSummaries(results); - const juryCertificationSummaries = _.map(juryCertificationSummaryDTOs, _toDomain); - return juryCertificationSummaries; - }, + const juryCertificationSummaries = _.map(juryCertificationSummaryDTOs, _toDomain); + return juryCertificationSummaries; +}; - async findBySessionIdPaginated({ page, sessionId }) { - const query = _getCertificationCoursesIdBySessionIdQuery(sessionId); +const findBySessionIdPaginated = async function ({ page, sessionId }) { + const query = _getCertificationCoursesIdBySessionIdQuery(sessionId); - const { results: orderedCertificationCourseIdsInObjects, pagination } = await fetchPage(query, page); + const { results: orderedCertificationCourseIdsInObjects, pagination } = await fetchPage(query, page); - const orderedCertificationCourseIds = orderedCertificationCourseIdsInObjects.map((obj) => obj.id); + const orderedCertificationCourseIds = orderedCertificationCourseIdsInObjects.map((obj) => obj.id); - const results = await _getByCertificationCourseIds(orderedCertificationCourseIds); + const results = await _getByCertificationCourseIds(orderedCertificationCourseIds); - const orderedResults = orderedCertificationCourseIds.map((id) => results.find((result) => result.id === id)); + const orderedResults = orderedCertificationCourseIds.map((id) => results.find((result) => result.id === id)); - const juryCertificationSummaryDTOs = await _getJuryCertificationSummaries(orderedResults); - const juryCertificationSummaries = _.map(juryCertificationSummaryDTOs, _toDomain); - return { - pagination, - juryCertificationSummaries, - }; - }, + const juryCertificationSummaryDTOs = await _getJuryCertificationSummaries(orderedResults); + const juryCertificationSummaries = _.map(juryCertificationSummaryDTOs, _toDomain); + return { + pagination, + juryCertificationSummaries, + }; }; +export { findBySessionId, findBySessionIdPaginated }; + async function _getJuryCertificationSummaries(results) { const certificationCourseIds = results.map((row) => row.id); const certificationIssueReportRows = await knex('certification-issue-reports').whereIn( diff --git a/api/lib/infrastructure/repositories/knowledge-element-repository.js b/api/lib/infrastructure/repositories/knowledge-element-repository.js index dbdb0ab64fa..384ee8c8461 100644 --- a/api/lib/infrastructure/repositories/knowledge-element-repository.js +++ b/api/lib/infrastructure/repositories/knowledge-element-repository.js @@ -1,12 +1,12 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { constants } = require('../constants.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const KnowledgeElement = require('../../domain/models/KnowledgeElement.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); -const knowledgeElementSnapshotRepository = require('./knowledge-element-snapshot-repository.js'); -const campaignRepository = require('./campaign-repository.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import { constants } from '../constants.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { KnowledgeElement } from '../../domain/models/KnowledgeElement.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; +import * as knowledgeElementSnapshotRepository from './knowledge-element-snapshot-repository.js'; +import * as campaignRepository from './campaign-repository.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; const { SHARED } = CampaignParticipationStatuses; @@ -86,132 +86,152 @@ async function _countValidatedByCompetencesForUsersWithinCampaign(userIdsAndDate ); } -module.exports = { - async save(knowledgeElement) { - const knowledgeElementToSave = _.omit(knowledgeElement, ['id', 'createdAt']); - const [savedKnowledgeElement] = await knex(tableName).insert(knowledgeElementToSave).returning('*'); - return new KnowledgeElement(savedKnowledgeElement); - }, - - findUniqByUserId({ userId, limitDate, domainTransaction }) { - return _findAssessedByUserIdAndLimitDateQuery({ userId, limitDate, domainTransaction }); - }, - - async findUniqByUserIdAndAssessmentId({ userId, assessmentId }) { - const query = _findByUserIdAndLimitDateQuery({ userId }); - const knowledgeElementRows = await query.where({ assessmentId }); - - const knowledgeElements = _.map( - knowledgeElementRows, - (knowledgeElementRow) => new KnowledgeElement(knowledgeElementRow) - ); - return _applyFilters(knowledgeElements); - }, - - async findUniqByUserIdAndCompetenceId({ - userId, - competenceId, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knowledgeElements = await _findAssessedByUserIdAndLimitDateQuery({ userId, domainTransaction }); - return knowledgeElements.filter((knowledgeElement) => knowledgeElement.competenceId === competenceId); - }, - - async findUniqByUserIdGroupedByCompetenceId({ userId, limitDate }) { - const knowledgeElements = await this.findUniqByUserId({ userId, limitDate }); - return _.groupBy(knowledgeElements, 'competenceId'); - }, - - async findByCampaignIdAndUserIdForSharedCampaignParticipation({ campaignId, userId }) { - const [sharedCampaignParticipation] = await knex('campaign-participations') - .select('sharedAt') - .where({ campaignId, status: SHARED, userId }) - .limit(1); - - if (!sharedCampaignParticipation) { - return []; - } +const save = async function (knowledgeElement) { + const knowledgeElementToSave = _.omit(knowledgeElement, ['id', 'createdAt']); + const [savedKnowledgeElement] = await knex(tableName).insert(knowledgeElementToSave).returning('*'); + return new KnowledgeElement(savedKnowledgeElement); +}; - const { sharedAt } = sharedCampaignParticipation; - const knowledgeElements = await _findAssessedByUserIdAndLimitDateQuery({ userId, limitDate: sharedAt }); +const findUniqByUserId = function ({ userId, limitDate, domainTransaction }) { + return _findAssessedByUserIdAndLimitDateQuery({ userId, limitDate, domainTransaction }); +}; - return _filterValidatedKnowledgeElementsByCampaignId(knowledgeElements, campaignId); - }, +const findUniqByUserIdAndAssessmentId = async function ({ userId, assessmentId }) { + const query = _findByUserIdAndLimitDateQuery({ userId }); + const knowledgeElementRows = await query.where({ assessmentId }); - async findByCampaignIdForSharedCampaignParticipation(campaignId) { - const sharedCampaignParticipations = await knex('campaign-participations') - .select('userId', 'sharedAt') - .where({ campaignId, status: SHARED }); + const knowledgeElements = _.map( + knowledgeElementRows, + (knowledgeElementRow) => new KnowledgeElement(knowledgeElementRow) + ); + return _applyFilters(knowledgeElements); +}; - const knowledgeElements = _.flatMap( - await bluebird.map( - sharedCampaignParticipations, - async ({ userId, sharedAt }) => { - return _findAssessedByUserIdAndLimitDateQuery({ userId, limitDate: sharedAt }); - }, - { concurrency: constants.CONCURRENCY_HEAVY_OPERATIONS } - ) - ); +const findUniqByUserIdAndCompetenceId = async function ({ + userId, + competenceId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knowledgeElements = await _findAssessedByUserIdAndLimitDateQuery({ userId, domainTransaction }); + return knowledgeElements.filter((knowledgeElement) => knowledgeElement.competenceId === competenceId); +}; - return _filterValidatedKnowledgeElementsByCampaignId(knowledgeElements, campaignId); - }, +const findUniqByUserIdGroupedByCompetenceId = async function ({ userId, limitDate }) { + const knowledgeElements = await this.findUniqByUserId({ userId, limitDate }); + return _.groupBy(knowledgeElements, 'competenceId'); +}; - async findSnapshotGroupedByCompetencesForUsers(userIdsAndDates) { - const knowledgeElementsGroupedByUser = await _findSnapshotsForUsers(userIdsAndDates); +const findByCampaignIdAndUserIdForSharedCampaignParticipation = async function ({ campaignId, userId }) { + const [sharedCampaignParticipation] = await knex('campaign-participations') + .select('sharedAt') + .where({ campaignId, status: SHARED, userId }) + .limit(1); - for (const [userId, knowledgeElements] of Object.entries(knowledgeElementsGroupedByUser)) { - knowledgeElementsGroupedByUser[userId] = _.groupBy(knowledgeElements, 'competenceId'); - } - return knowledgeElementsGroupedByUser; - }, + if (!sharedCampaignParticipation) { + return []; + } - async countValidatedByCompetencesForUsersWithinCampaign(userIdsAndDates, campaignLearningContent) { - return _countValidatedByCompetencesForUsersWithinCampaign(userIdsAndDates, campaignLearningContent); - }, + const { sharedAt } = sharedCampaignParticipation; + const knowledgeElements = await _findAssessedByUserIdAndLimitDateQuery({ userId, limitDate: sharedAt }); - async countValidatedByCompetencesForOneUserWithinCampaign(userId, limitDate, campaignLearningContent) { - return _countValidatedByCompetencesForUsersWithinCampaign({ [userId]: limitDate }, campaignLearningContent); - }, + return _filterValidatedKnowledgeElementsByCampaignId(knowledgeElements, campaignId); +}; - async findGroupedByCompetencesForUsersWithinLearningContent(userIdsAndDates, campaignLearningContent) { - const knowledgeElementsGroupedByUser = await _findSnapshotsForUsers(userIdsAndDates); - const knowledgeElementsGroupedByUserAndCompetence = {}; +const findByCampaignIdForSharedCampaignParticipation = async function (campaignId) { + const sharedCampaignParticipations = await knex('campaign-participations') + .select('userId', 'sharedAt') + .where({ campaignId, status: SHARED }); + + const knowledgeElements = _.flatMap( + await bluebird.map( + sharedCampaignParticipations, + async ({ userId, sharedAt }) => { + return _findAssessedByUserIdAndLimitDateQuery({ userId, limitDate: sharedAt }); + }, + { concurrency: constants.CONCURRENCY_HEAVY_OPERATIONS } + ) + ); - for (const [userId, knowledgeElements] of Object.entries(knowledgeElementsGroupedByUser)) { - knowledgeElementsGroupedByUserAndCompetence[userId] = - campaignLearningContent.getKnowledgeElementsGroupedByCompetence(knowledgeElements); - } + return _filterValidatedKnowledgeElementsByCampaignId(knowledgeElements, campaignId); +}; - return knowledgeElementsGroupedByUserAndCompetence; - }, +const findSnapshotGroupedByCompetencesForUsers = async function (userIdsAndDates) { + const knowledgeElementsGroupedByUser = await _findSnapshotsForUsers(userIdsAndDates); - async findValidatedGroupedByTubesWithinCampaign(userIdsAndDates, campaignLearningContent) { - const knowledgeElementsGroupedByUser = await _findSnapshotsForUsers(userIdsAndDates); + for (const [userId, knowledgeElements] of Object.entries(knowledgeElementsGroupedByUser)) { + knowledgeElementsGroupedByUser[userId] = _.groupBy(knowledgeElements, 'competenceId'); + } + return knowledgeElementsGroupedByUser; +}; - return campaignLearningContent.getValidatedKnowledgeElementsGroupedByTube( - _.flatMap(knowledgeElementsGroupedByUser) - ); - }, +const countValidatedByCompetencesForUsersWithinCampaign = async function (userIdsAndDates, campaignLearningContent) { + return _countValidatedByCompetencesForUsersWithinCampaign(userIdsAndDates, campaignLearningContent); +}; - async findSnapshotForUsers(userIdsAndDates) { - return _findSnapshotsForUsers(userIdsAndDates); - }, +const countValidatedByCompetencesForOneUserWithinCampaign = async function ( + userId, + limitDate, + campaignLearningContent +) { + return _countValidatedByCompetencesForUsersWithinCampaign({ [userId]: limitDate }, campaignLearningContent); +}; - async findInvalidatedAndDirectByUserId(userId) { - const invalidatedKnowledgeElements = await knex(tableName) - .where({ - userId, - status: KnowledgeElement.StatusType.INVALIDATED, - source: KnowledgeElement.SourceType.DIRECT, - }) - .orderBy('createdAt', 'desc'); +const findGroupedByCompetencesForUsersWithinLearningContent = async function ( + userIdsAndDates, + campaignLearningContent +) { + const knowledgeElementsGroupedByUser = await _findSnapshotsForUsers(userIdsAndDates); + const knowledgeElementsGroupedByUserAndCompetence = {}; - if (!invalidatedKnowledgeElements.length) { - return []; - } + for (const [userId, knowledgeElements] of Object.entries(knowledgeElementsGroupedByUser)) { + knowledgeElementsGroupedByUserAndCompetence[userId] = + campaignLearningContent.getKnowledgeElementsGroupedByCompetence(knowledgeElements); + } + + return knowledgeElementsGroupedByUserAndCompetence; +}; + +const findValidatedGroupedByTubesWithinCampaign = async function (userIdsAndDates, campaignLearningContent) { + const knowledgeElementsGroupedByUser = await _findSnapshotsForUsers(userIdsAndDates); + + return campaignLearningContent.getValidatedKnowledgeElementsGroupedByTube(_.flatMap(knowledgeElementsGroupedByUser)); +}; + +const findSnapshotForUsers = async function (userIdsAndDates) { + return _findSnapshotsForUsers(userIdsAndDates); +}; + +const findInvalidatedAndDirectByUserId = async function (userId) { + const invalidatedKnowledgeElements = await knex(tableName) + .where({ + userId, + status: KnowledgeElement.StatusType.INVALIDATED, + source: KnowledgeElement.SourceType.DIRECT, + }) + .orderBy('createdAt', 'desc'); + + if (!invalidatedKnowledgeElements.length) { + return []; + } + + return invalidatedKnowledgeElements.map( + (invalidatedKnowledgeElement) => new KnowledgeElement(invalidatedKnowledgeElement) + ); +}; - return invalidatedKnowledgeElements.map( - (invalidatedKnowledgeElement) => new KnowledgeElement(invalidatedKnowledgeElement) - ); - }, +export { + save, + findUniqByUserId, + findUniqByUserIdAndAssessmentId, + findUniqByUserIdAndCompetenceId, + findUniqByUserIdGroupedByCompetenceId, + findByCampaignIdAndUserIdForSharedCampaignParticipation, + findByCampaignIdForSharedCampaignParticipation, + findSnapshotGroupedByCompetencesForUsers, + countValidatedByCompetencesForUsersWithinCampaign, + countValidatedByCompetencesForOneUserWithinCampaign, + findGroupedByCompetencesForUsersWithinLearningContent, + findValidatedGroupedByTubesWithinCampaign, + findSnapshotForUsers, + findInvalidatedAndDirectByUserId, }; diff --git a/api/lib/infrastructure/repositories/knowledge-element-snapshot-repository.js b/api/lib/infrastructure/repositories/knowledge-element-snapshot-repository.js index 9a0b0045269..aab07b0153f 100644 --- a/api/lib/infrastructure/repositories/knowledge-element-snapshot-repository.js +++ b/api/lib/infrastructure/repositories/knowledge-element-snapshot-repository.js @@ -1,10 +1,10 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const BookshelfKnowledgeElementSnapshot = require('../orm-models/KnowledgeElementSnapshot.js'); -const KnowledgeElement = require('../../domain/models/KnowledgeElement.js'); -const { AlreadyExistingEntityError } = require('../../domain/errors.js'); -const bookshelfUtils = require('../utils/knex-utils.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { BookshelfKnowledgeElementSnapshot } from '../orm-models/KnowledgeElementSnapshot.js'; +import { KnowledgeElement } from '../../domain/models/KnowledgeElement.js'; +import { AlreadyExistingEntityError } from '../../domain/errors.js'; +import * as knexUtils from '../utils/knex-utils.js'; +import { DomainTransaction } from '../DomainTransaction.js'; function _toKnowledgeElementCollection({ snapshot } = {}) { if (!snapshot) return null; @@ -17,43 +17,48 @@ function _toKnowledgeElementCollection({ snapshot } = {}) { ); } -module.exports = { - async save({ userId, snappedAt, knowledgeElements, domainTransaction = DomainTransaction.emptyTransaction() }) { - try { - await new BookshelfKnowledgeElementSnapshot({ - userId, - snappedAt, - snapshot: JSON.stringify(knowledgeElements), - }).save(null, { transacting: domainTransaction.knexTransaction }); - } catch (error) { - if (bookshelfUtils.isUniqConstraintViolated(error)) { - throw new AlreadyExistingEntityError( - `A snapshot already exists for the user ${userId} at the datetime ${snappedAt}.` - ); - } +const save = async function ({ + userId, + snappedAt, + knowledgeElements, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + try { + await new BookshelfKnowledgeElementSnapshot({ + userId, + snappedAt, + snapshot: JSON.stringify(knowledgeElements), + }).save(null, { transacting: domainTransaction.knexTransaction }); + } catch (error) { + if (knexUtils.isUniqConstraintViolated(error)) { + throw new AlreadyExistingEntityError( + `A snapshot already exists for the user ${userId} at the datetime ${snappedAt}.` + ); } - }, + } +}; - async findByUserIdsAndSnappedAtDates(userIdsAndSnappedAtDates = {}) { - const params = Object.entries(userIdsAndSnappedAtDates); - const results = await knex - .select('userId', 'snapshot') - .from('knowledge-element-snapshots') - .whereIn(['userId', 'snappedAt'], params); +const findByUserIdsAndSnappedAtDates = async function (userIdsAndSnappedAtDates = {}) { + const params = Object.entries(userIdsAndSnappedAtDates); + const results = await knex + .select('userId', 'snapshot') + .from('knowledge-element-snapshots') + .whereIn(['userId', 'snappedAt'], params); - const knowledgeElementsByUserId = {}; - for (const result of results) { - knowledgeElementsByUserId[result.userId] = _toKnowledgeElementCollection(result); - } + const knowledgeElementsByUserId = {}; + for (const result of results) { + knowledgeElementsByUserId[result.userId] = _toKnowledgeElementCollection(result); + } - const userIdsWithoutSnapshot = _.difference( - Object.keys(userIdsAndSnappedAtDates), - Object.keys(knowledgeElementsByUserId) - ); - for (const userId of userIdsWithoutSnapshot) { - knowledgeElementsByUserId[userId] = null; - } + const userIdsWithoutSnapshot = _.difference( + Object.keys(userIdsAndSnappedAtDates), + Object.keys(knowledgeElementsByUserId) + ); + for (const userId of userIdsWithoutSnapshot) { + knowledgeElementsByUserId[userId] = null; + } - return knowledgeElementsByUserId; - }, + return knowledgeElementsByUserId; }; + +export { save, findByUserIdsAndSnappedAtDates }; diff --git a/api/lib/infrastructure/repositories/learning-content-repository.js b/api/lib/infrastructure/repositories/learning-content-repository.js index 9ebaeff783e..b1165376581 100644 --- a/api/lib/infrastructure/repositories/learning-content-repository.js +++ b/api/lib/infrastructure/repositories/learning-content-repository.js @@ -1,16 +1,15 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { NoSkillsInCampaignError, NotFoundError } = require('../../domain/errors.js'); -const tubeRepository = require('./tube-repository.js'); -const thematicRepository = require('./thematic-repository.js'); -const campaignRepository = require('./campaign-repository.js'); -const competenceRepository = require('./competence-repository.js'); -const areaRepository = require('./area-repository.js'); -const frameworkRepository = require('./framework-repository.js'); -const skillRepository = require('./skill-repository.js'); -const LearningContent = require('../../domain/models/LearningContent.js'); -// TODO pas satisfaisant comme dépendance -const learningContentConversionService = require('../../domain/services/learning-content/learning-content-conversion-service.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { NoSkillsInCampaignError, NotFoundError } from '../../domain/errors.js'; +import * as tubeRepository from './tube-repository.js'; +import * as thematicRepository from './thematic-repository.js'; +import * as campaignRepository from './campaign-repository.js'; +import * as competenceRepository from './competence-repository.js'; +import * as areaRepository from './area-repository.js'; +import * as frameworkRepository from './framework-repository.js'; +import * as skillRepository from './skill-repository.js'; +import { LearningContent } from '../../domain/models/LearningContent.js'; +import * as learningContentConversionService from '../../domain/services/learning-content/learning-content-conversion-service.js'; async function findByCampaignId(campaignId, locale) { const skills = await campaignRepository.findSkills({ campaignId }); @@ -149,9 +148,4 @@ async function _getLearningContentByFrameworks(frameworks, locale) { return frameworks; } -module.exports = { - findByCampaignId, - findByTargetProfileId, - findByCampaignParticipationId, - findByFrameworkNames, -}; +export { findByCampaignId, findByTargetProfileId, findByCampaignParticipationId, findByFrameworkNames }; diff --git a/api/lib/infrastructure/repositories/membership-repository.js b/api/lib/infrastructure/repositories/membership-repository.js index 1cc28185434..187d8399e8c 100644 --- a/api/lib/infrastructure/repositories/membership-repository.js +++ b/api/lib/infrastructure/repositories/membership-repository.js @@ -1,12 +1,12 @@ -const BookshelfMembership = require('../orm-models/Membership.js'); -const { MembershipCreationError, MembershipUpdateError, NotFoundError } = require('../../domain/errors.js'); -const Membership = require('../../domain/models/Membership.js'); -const User = require('../../domain/models/User.js'); -const Organization = require('../../domain/models/Organization.js'); -const bookshelfUtils = require('../utils/knex-utils.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import { BookshelfMembership } from '../orm-models/Membership.js'; +import { MembershipCreationError, MembershipUpdateError, NotFoundError } from '../../domain/errors.js'; +import { Membership } from '../../domain/models/Membership.js'; +import { User } from '../../domain/models/User.js'; +import { Organization } from '../../domain/models/Organization.js'; +import * as knexUtils from '../utils/knex-utils.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; const DEFAULT_PAGE_SIZE = 10; const DEFAULT_PAGE_NUMBER = 1; @@ -41,101 +41,110 @@ function _setSearchFiltersForQueryBuilder(filter, qb) { } } -module.exports = { - create(userId, organizationId, organizationRole) { - return new BookshelfMembership({ userId, organizationId, organizationRole }) - .save() - .then((bookshelfMembership) => bookshelfMembership.load(['user'])) - .then(_toDomain) - .catch((err) => { - if (bookshelfUtils.isUniqConstraintViolated(err)) { - throw new MembershipCreationError(err.message); - } - throw err; - }); - }, - - async get(membershipId) { - let bookshelfMembership; - try { - bookshelfMembership = await BookshelfMembership.where('id', membershipId).fetch({ - withRelated: ['user', 'organization'], - }); - } catch (error) { - if (error instanceof BookshelfMembership.NotFoundError) { - throw new NotFoundError(`Membership ${membershipId} not found`); +const create = function (userId, organizationId, organizationRole) { + return new BookshelfMembership({ userId, organizationId, organizationRole }) + .save() + .then((bookshelfMembership) => bookshelfMembership.load(['user'])) + .then(_toDomain) + .catch((err) => { + if (knexUtils.isUniqConstraintViolated(err)) { + throw new MembershipCreationError(err.message); } - throw error; - } + throw err; + }); +}; - return _toDomain(bookshelfMembership); - }, - - async findByOrganizationId({ organizationId }) { - const memberships = await BookshelfMembership.where({ organizationId, disabledAt: null }) - .orderBy('id', 'ASC') - .fetchAll({ withRelated: ['user'] }); - return bookshelfToDomainConverter.buildDomainObjects(BookshelfMembership, memberships); - }, - - async findPaginatedFiltered({ organizationId, filter, page }) { - const pageSize = page.size ? page.size : DEFAULT_PAGE_SIZE; - const pageNumber = page.number ? page.number : DEFAULT_PAGE_NUMBER; - const { models, pagination } = await BookshelfMembership.query((qb) => { - qb.where({ 'memberships.organizationId': organizationId, 'memberships.disabledAt': null }); - _setSearchFiltersForQueryBuilder(filter, qb); - qb.innerJoin('users', 'memberships.userId', 'users.id'); - qb.orderByRaw('"organizationRole" ASC, LOWER(users."lastName") ASC, LOWER(users."firstName") ASC'); - }).fetchPage({ - withRelated: ['user'], - page: pageNumber, - pageSize, +const get = async function (membershipId) { + let bookshelfMembership; + try { + bookshelfMembership = await BookshelfMembership.where('id', membershipId).fetch({ + withRelated: ['user', 'organization'], }); - const memberships = bookshelfToDomainConverter.buildDomainObjects(BookshelfMembership, models); - return { models: memberships, pagination }; - }, - - findByUserIdAndOrganizationId({ userId, organizationId, includeOrganization = false }) { - return BookshelfMembership.where({ userId, organizationId, disabledAt: null }) - .fetchAll({ withRelated: includeOrganization ? ['organization', 'organization.tags'] : [] }) - .then((memberships) => bookshelfToDomainConverter.buildDomainObjects(BookshelfMembership, memberships)); - }, - - findByUserId({ userId }) { - return BookshelfMembership.where({ userId, disabledAt: null }) - .fetchAll({ withRelated: ['organization'] }) - .then((memberships) => bookshelfToDomainConverter.buildDomainObjects(BookshelfMembership, memberships)); - }, - - async updateById({ id, membership }) { - let updatedMembership; - - if (!membership) { - throw new MembershipUpdateError("Le membership n'est pas renseigné"); + } catch (error) { + if (error instanceof BookshelfMembership.NotFoundError) { + throw new NotFoundError(`Membership ${membershipId} not found`); } + throw error; + } - try { - updatedMembership = await new BookshelfMembership({ id }).save(membership, { - patch: true, - method: 'update', - require: true, - }); - } catch (err) { - throw new MembershipUpdateError(err.message); - } + return _toDomain(bookshelfMembership); +}; - const updatedMembershipWithUserAndOrganization = await updatedMembership.refresh({ - withRelated: ['user', 'organization'], +const findByOrganizationId = async function ({ organizationId }) { + const memberships = await BookshelfMembership.where({ organizationId, disabledAt: null }) + .orderBy('id', 'ASC') + .fetchAll({ withRelated: ['user'] }); + return bookshelfToDomainConverter.buildDomainObjects(BookshelfMembership, memberships); +}; + +const findPaginatedFiltered = async function ({ organizationId, filter, page }) { + const pageSize = page.size ? page.size : DEFAULT_PAGE_SIZE; + const pageNumber = page.number ? page.number : DEFAULT_PAGE_NUMBER; + const { models, pagination } = await BookshelfMembership.query((qb) => { + qb.where({ 'memberships.organizationId': organizationId, 'memberships.disabledAt': null }); + _setSearchFiltersForQueryBuilder(filter, qb); + qb.innerJoin('users', 'memberships.userId', 'users.id'); + qb.orderByRaw('"organizationRole" ASC, LOWER(users."lastName") ASC, LOWER(users."firstName") ASC'); + }).fetchPage({ + withRelated: ['user'], + page: pageNumber, + pageSize, + }); + const memberships = bookshelfToDomainConverter.buildDomainObjects(BookshelfMembership, models); + return { models: memberships, pagination }; +}; + +const findByUserIdAndOrganizationId = function ({ userId, organizationId, includeOrganization = false }) { + return BookshelfMembership.where({ userId, organizationId, disabledAt: null }) + .fetchAll({ withRelated: includeOrganization ? ['organization', 'organization.tags'] : [] }) + .then((memberships) => bookshelfToDomainConverter.buildDomainObjects(BookshelfMembership, memberships)); +}; + +const findByUserId = function ({ userId }) { + return BookshelfMembership.where({ userId, disabledAt: null }) + .fetchAll({ withRelated: ['organization'] }) + .then((memberships) => bookshelfToDomainConverter.buildDomainObjects(BookshelfMembership, memberships)); +}; + +const updateById = async function ({ id, membership }) { + let updatedMembership; + + if (!membership) { + throw new MembershipUpdateError("Le membership n'est pas renseigné"); + } + + try { + updatedMembership = await new BookshelfMembership({ id }).save(membership, { + patch: true, + method: 'update', + require: true, }); - return bookshelfToDomainConverter.buildDomainObject(BookshelfMembership, updatedMembershipWithUserAndOrganization); - }, - - async disableMembershipsByUserId({ - userId, - updatedByUserId, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knexConn = domainTransaction.knexTransaction ?? knex; - await knexConn('memberships').where({ userId }).update({ disabledAt: new Date(), updatedByUserId }); - }, + } catch (err) { + throw new MembershipUpdateError(err.message); + } + + const updatedMembershipWithUserAndOrganization = await updatedMembership.refresh({ + withRelated: ['user', 'organization'], + }); + return bookshelfToDomainConverter.buildDomainObject(BookshelfMembership, updatedMembershipWithUserAndOrganization); +}; + +const disableMembershipsByUserId = async function ({ + userId, + updatedByUserId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction ?? knex; + await knexConn('memberships').where({ userId }).update({ disabledAt: new Date(), updatedByUserId }); +}; + +export { + create, + get, + findByOrganizationId, + findPaginatedFiltered, + findByUserIdAndOrganizationId, + findByUserId, + updateById, + disableMembershipsByUserId, }; diff --git a/api/lib/infrastructure/repositories/organization-for-admin-repository.js b/api/lib/infrastructure/repositories/organization-for-admin-repository.js index ab15c707e07..83969e0475a 100644 --- a/api/lib/infrastructure/repositories/organization-for-admin-repository.js +++ b/api/lib/infrastructure/repositories/organization-for-admin-repository.js @@ -1,10 +1,10 @@ -const { NotFoundError, MissingAttributesError } = require('../../domain/errors.js'); -const OrganizationForAdmin = require('../../domain/models/organizations-administration/Organization.js'); -const Tag = require('../../domain/models/Tag.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const OrganizationInvitation = require('../../domain/models/OrganizationInvitation.js'); -const _ = require('lodash'); -const apps = require('../../domain/constants.js'); +import { NotFoundError, MissingAttributesError } from '../../domain/errors.js'; +import { OrganizationForAdmin } from '../../domain/models/organizations-administration/Organization.js'; +import { Tag } from '../../domain/models/Tag.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { OrganizationInvitation } from '../../domain/models/OrganizationInvitation.js'; +import _ from 'lodash'; +import * as apps from '../../domain/constants.js'; const ORGANIZATIONS_TABLE_NAME = 'organizations'; @@ -42,138 +42,138 @@ function _toDomain(rawOrganization) { return organization; } -module.exports = { - async get(id) { - const organization = await knex(ORGANIZATIONS_TABLE_NAME) - .select({ - id: 'organizations.id', - name: 'organizations.name', - type: 'organizations.type', - logoUrl: 'organizations.logoUrl', - externalId: 'organizations.externalId', - provinceCode: 'organizations.provinceCode', - isManagingStudents: 'organizations.isManagingStudents', - credit: 'organizations.credit', - email: 'organizations.email', - documentationUrl: 'organizations.documentationUrl', - createdBy: 'organizations.createdBy', - createdAt: 'organizations.createdAt', - showNPS: 'organizations.showNPS', - formNPSUrl: 'organizations.formNPSUrl', - showSkills: 'organizations.showSkills', - archivedAt: 'organizations.archivedAt', - archivistFirstName: 'archivists.firstName', - archivistLastName: 'archivists.lastName', - dataProtectionOfficerFirstName: 'dataProtectionOfficers.firstName', - dataProtectionOfficerLastName: 'dataProtectionOfficers.lastName', - dataProtectionOfficerEmail: 'dataProtectionOfficers.email', - creatorFirstName: 'creators.firstName', - creatorLastName: 'creators.lastName', - identityProviderForCampaigns: 'organizations.identityProviderForCampaigns', - }) - .leftJoin('users AS archivists', 'archivists.id', 'organizations.archivedBy') - .leftJoin('users AS creators', 'creators.id', 'organizations.createdBy') - .leftJoin( - 'data-protection-officers AS dataProtectionOfficers', - 'dataProtectionOfficers.organizationId', - 'organizations.id' - ) - .where('organizations.id', id) - .first(); - - if (!organization) { - throw new NotFoundError(`Not found organization for ID ${id}`); - } - - const tags = await knex('tags') - .select('tags.*') - .join('organization-tags', 'organization-tags.tagId', 'tags.id') - .where('organization-tags.organizationId', organization.id); - - const availableFeatures = await knex('features') - .select('key') - .join('organization-features', function () { - this.on('features.id', 'organization-features.featureId').andOn( - 'organization-features.organizationId', - organization.id - ); - }) - .pluck('key'); - - organization.enableMultipleSendingAssessment = availableFeatures.includes( - apps.ORGANIZATION_FEATURE.MULTIPLE_SENDING_ASSESSMENT - ); - - organization.tags = tags.map((tag) => { - return new Tag(tag); - }); - - return _toDomain(organization); - }, - - async update(organization) { - const organizationRawData = _.pick(organization, [ - 'name', - 'type', - 'logoUrl', - 'externalId', - 'provinceCode', - 'isManagingStudents', - 'email', - 'credit', - 'documentationUrl', - 'showSkills', - 'identityProviderForCampaigns', - ]); - - const [organizationDB] = await knex(ORGANIZATIONS_TABLE_NAME) - .update(organizationRawData) - .where({ id: organization.id }) - .returning('*'); - - const tagsDB = await knex('tags') - .select(['tags.id', 'tags.name']) - .join('organization-tags', 'organization-tags.tagId', 'tags.id') - .where('organization-tags.organizationId', organizationDB.id); - const archivist = await knex('users') - .select(['users.firstName', 'users.lastName']) - .join('organizations', 'organizations.archivedBy', 'users.id') - .where('organizations.id', organizationDB.id) - .first(); - - const tags = tagsDB.map((tagDB) => new Tag(tagDB)); - - if (archivist) { - organizationDB.archivistFirstName = archivist.firstName; - organizationDB.archivistLastName = archivist.lastName; - } - - return _toDomain({ ...organizationDB, tags }); - }, - - async archive({ id, archivedBy }) { - if (!archivedBy) { - throw new MissingAttributesError(); - } - - const archiveDate = new Date(); - - await knex('organization-invitations') - .where({ organizationId: id, status: OrganizationInvitation.StatusType.PENDING }) - .update({ status: OrganizationInvitation.StatusType.CANCELLED, updatedAt: archiveDate }); - - await knex('campaigns').where({ organizationId: id, archivedAt: null }).update({ archivedAt: archiveDate }); - - await knex('memberships').where({ organizationId: id, disabledAt: null }).update({ disabledAt: archiveDate }); - - await knex(ORGANIZATIONS_TABLE_NAME) - .where({ id: id, archivedBy: null }) - .update({ archivedBy: archivedBy, archivedAt: archiveDate }); - }, - - async save(organization) { - const data = _.pick(organization, ['name', 'type', 'documentationUrl', 'credit', 'createdBy']); - const [organizationCreated] = await knex(ORGANIZATIONS_TABLE_NAME).returning('*').insert(data); - return _toDomain(organizationCreated); - }, +const get = async function (id) { + const organization = await knex(ORGANIZATIONS_TABLE_NAME) + .select({ + id: 'organizations.id', + name: 'organizations.name', + type: 'organizations.type', + logoUrl: 'organizations.logoUrl', + externalId: 'organizations.externalId', + provinceCode: 'organizations.provinceCode', + isManagingStudents: 'organizations.isManagingStudents', + credit: 'organizations.credit', + email: 'organizations.email', + documentationUrl: 'organizations.documentationUrl', + createdBy: 'organizations.createdBy', + createdAt: 'organizations.createdAt', + showNPS: 'organizations.showNPS', + formNPSUrl: 'organizations.formNPSUrl', + showSkills: 'organizations.showSkills', + archivedAt: 'organizations.archivedAt', + archivistFirstName: 'archivists.firstName', + archivistLastName: 'archivists.lastName', + dataProtectionOfficerFirstName: 'dataProtectionOfficers.firstName', + dataProtectionOfficerLastName: 'dataProtectionOfficers.lastName', + dataProtectionOfficerEmail: 'dataProtectionOfficers.email', + creatorFirstName: 'creators.firstName', + creatorLastName: 'creators.lastName', + identityProviderForCampaigns: 'organizations.identityProviderForCampaigns', + }) + .leftJoin('users AS archivists', 'archivists.id', 'organizations.archivedBy') + .leftJoin('users AS creators', 'creators.id', 'organizations.createdBy') + .leftJoin( + 'data-protection-officers AS dataProtectionOfficers', + 'dataProtectionOfficers.organizationId', + 'organizations.id' + ) + .where('organizations.id', id) + .first(); + + if (!organization) { + throw new NotFoundError(`Not found organization for ID ${id}`); + } + + const tags = await knex('tags') + .select('tags.*') + .join('organization-tags', 'organization-tags.tagId', 'tags.id') + .where('organization-tags.organizationId', organization.id); + + const availableFeatures = await knex('features') + .select('key') + .join('organization-features', function () { + this.on('features.id', 'organization-features.featureId').andOn( + 'organization-features.organizationId', + organization.id + ); + }) + .pluck('key'); + + organization.enableMultipleSendingAssessment = availableFeatures.includes( + apps.ORGANIZATION_FEATURE.MULTIPLE_SENDING_ASSESSMENT + ); + + organization.tags = tags.map((tag) => { + return new Tag(tag); + }); + + return _toDomain(organization); +}; + +const update = async function (organization) { + const organizationRawData = _.pick(organization, [ + 'name', + 'type', + 'logoUrl', + 'externalId', + 'provinceCode', + 'isManagingStudents', + 'email', + 'credit', + 'documentationUrl', + 'showSkills', + 'identityProviderForCampaigns', + ]); + + const [organizationDB] = await knex(ORGANIZATIONS_TABLE_NAME) + .update(organizationRawData) + .where({ id: organization.id }) + .returning('*'); + + const tagsDB = await knex('tags') + .select(['tags.id', 'tags.name']) + .join('organization-tags', 'organization-tags.tagId', 'tags.id') + .where('organization-tags.organizationId', organizationDB.id); + const archivist = await knex('users') + .select(['users.firstName', 'users.lastName']) + .join('organizations', 'organizations.archivedBy', 'users.id') + .where('organizations.id', organizationDB.id) + .first(); + + const tags = tagsDB.map((tagDB) => new Tag(tagDB)); + + if (archivist) { + organizationDB.archivistFirstName = archivist.firstName; + organizationDB.archivistLastName = archivist.lastName; + } + + return _toDomain({ ...organizationDB, tags }); +}; + +const archive = async function ({ id, archivedBy }) { + if (!archivedBy) { + throw new MissingAttributesError(); + } + + const archiveDate = new Date(); + + await knex('organization-invitations') + .where({ organizationId: id, status: OrganizationInvitation.StatusType.PENDING }) + .update({ status: OrganizationInvitation.StatusType.CANCELLED, updatedAt: archiveDate }); + + await knex('campaigns').where({ organizationId: id, archivedAt: null }).update({ archivedAt: archiveDate }); + + await knex('memberships').where({ organizationId: id, disabledAt: null }).update({ disabledAt: archiveDate }); + + await knex(ORGANIZATIONS_TABLE_NAME) + .where({ id: id, archivedBy: null }) + .update({ archivedBy: archivedBy, archivedAt: archiveDate }); }; + +const save = async function (organization) { + const data = _.pick(organization, ['name', 'type', 'documentationUrl', 'credit', 'createdBy']); + const [organizationCreated] = await knex(ORGANIZATIONS_TABLE_NAME).returning('*').insert(data); + return _toDomain(organizationCreated); +}; + +export { get, update, archive, save }; diff --git a/api/lib/infrastructure/repositories/organization-invitation-repository.js b/api/lib/infrastructure/repositories/organization-invitation-repository.js index a1e9fdac05b..f19b7ea086c 100644 --- a/api/lib/infrastructure/repositories/organization-invitation-repository.js +++ b/api/lib/infrastructure/repositories/organization-invitation-repository.js @@ -1,9 +1,9 @@ -const BookshelfOrganizationInvitation = require('../orm-models/OrganizationInvitation.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const OrganizationInvitation = require('../../domain/models/OrganizationInvitation.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const _ = require('lodash'); +import { BookshelfOrganizationInvitation } from '../orm-models/OrganizationInvitation.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { OrganizationInvitation } from '../../domain/models/OrganizationInvitation.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import _ from 'lodash'; function _toDomain(bookshelfInvitation) { if (bookshelfInvitation) { @@ -26,78 +26,87 @@ function _checkNotFoundErrorWithCode({ error, id, code }) { throw error; } -module.exports = { - create({ organizationId, email, code, role }) { - const status = OrganizationInvitation.StatusType.PENDING; - return new BookshelfOrganizationInvitation({ organizationId, email, status, code, role }).save().then(_toDomain); - }, +const create = function ({ organizationId, email, code, role }) { + const status = OrganizationInvitation.StatusType.PENDING; + return new BookshelfOrganizationInvitation({ organizationId, email, status, code, role }).save().then(_toDomain); +}; - get(id) { - return BookshelfOrganizationInvitation.where({ id }) - .fetch() - .then(_toDomain) - .catch((err) => _checkNotFoundError(err, id)); - }, +const get = function (id) { + return BookshelfOrganizationInvitation.where({ id }) + .fetch() + .then(_toDomain) + .catch((err) => _checkNotFoundError(err, id)); +}; - getByIdAndCode({ id, code }) { - return BookshelfOrganizationInvitation.where({ id, code }) - .fetch() - .then(_toDomain) - .catch((error) => _checkNotFoundErrorWithCode({ error, id, code })); - }, +const getByIdAndCode = function ({ id, code }) { + return BookshelfOrganizationInvitation.where({ id, code }) + .fetch() + .then(_toDomain) + .catch((error) => _checkNotFoundErrorWithCode({ error, id, code })); +}; - markAsAccepted(id) { - const status = OrganizationInvitation.StatusType.ACCEPTED; +const markAsAccepted = function (id) { + const status = OrganizationInvitation.StatusType.ACCEPTED; - return new BookshelfOrganizationInvitation({ id }) - .save({ status }, { patch: true, require: true }) - .then((model) => model.refresh()) - .then(_toDomain) - .catch((err) => _checkNotFoundError(err, id)); - }, + return new BookshelfOrganizationInvitation({ id }) + .save({ status }, { patch: true, require: true }) + .then((model) => model.refresh()) + .then(_toDomain) + .catch((err) => _checkNotFoundError(err, id)); +}; - async markAsCancelled({ id }) { - const [organizationInvitation] = await knex('organization-invitations') - .where({ id }) - .update({ - status: OrganizationInvitation.StatusType.CANCELLED, - updatedAt: new Date(), - }) - .returning('*'); +const markAsCancelled = async function ({ id }) { + const [organizationInvitation] = await knex('organization-invitations') + .where({ id }) + .update({ + status: OrganizationInvitation.StatusType.CANCELLED, + updatedAt: new Date(), + }) + .returning('*'); - if (!organizationInvitation) { - throw new NotFoundError(`Organization invitation of id ${id} is not found.`); - } - return new OrganizationInvitation(organizationInvitation); - }, + if (!organizationInvitation) { + throw new NotFoundError(`Organization invitation of id ${id} is not found.`); + } + return new OrganizationInvitation(organizationInvitation); +}; - findPendingByOrganizationId({ organizationId }) { - return BookshelfOrganizationInvitation.where({ organizationId, status: OrganizationInvitation.StatusType.PENDING }) - .orderBy('updatedAt', 'desc') - .fetchAll() - .then((results) => bookshelfToDomainConverter.buildDomainObjects(BookshelfOrganizationInvitation, results)); - }, +const findPendingByOrganizationId = function ({ organizationId }) { + return BookshelfOrganizationInvitation.where({ organizationId, status: OrganizationInvitation.StatusType.PENDING }) + .orderBy('updatedAt', 'desc') + .fetchAll() + .then((results) => bookshelfToDomainConverter.buildDomainObjects(BookshelfOrganizationInvitation, results)); +}; + +const findOnePendingByOrganizationIdAndEmail = function ({ organizationId, email }) { + return BookshelfOrganizationInvitation.query((qb) => + qb + .where({ organizationId, status: OrganizationInvitation.StatusType.PENDING }) + .whereRaw('LOWER("email") = ?', `${email.toLowerCase()}`) + ) + .fetch({ require: false }) + .then(_toDomain); +}; - findOnePendingByOrganizationIdAndEmail({ organizationId, email }) { - return BookshelfOrganizationInvitation.query((qb) => - qb - .where({ organizationId, status: OrganizationInvitation.StatusType.PENDING }) - .whereRaw('LOWER("email") = ?', `${email.toLowerCase()}`) - ) - .fetch({ require: false }) - .then(_toDomain); - }, +const updateModificationDate = async function (id) { + const organizationInvitation = await knex('organization-invitations') + .where({ id }) + .update({ updatedAt: new Date() }) + .returning('*') + .then(_.first); - async updateModificationDate(id) { - const organizationInvitation = await knex('organization-invitations') - .where({ id }) - .update({ updatedAt: new Date() }) - .returning('*') - .then(_.first); + if (!organizationInvitation) { + throw new NotFoundError(`Organization invitation of id ${id} is not found.`); + } + return new OrganizationInvitation(organizationInvitation); +}; - if (!organizationInvitation) { - throw new NotFoundError(`Organization invitation of id ${id} is not found.`); - } - return new OrganizationInvitation(organizationInvitation); - }, +export { + create, + get, + getByIdAndCode, + markAsAccepted, + markAsCancelled, + findPendingByOrganizationId, + findOnePendingByOrganizationIdAndEmail, + updateModificationDate, }; diff --git a/api/lib/infrastructure/repositories/organization-invited-user-repository.js b/api/lib/infrastructure/repositories/organization-invited-user-repository.js index 969947c1d94..c5d9e197d00 100644 --- a/api/lib/infrastructure/repositories/organization-invited-user-repository.js +++ b/api/lib/infrastructure/repositories/organization-invited-user-repository.js @@ -1,75 +1,75 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const OrganizationInvitedUser = require('../../domain/models/OrganizationInvitedUser.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { OrganizationInvitedUser } from '../../domain/models/OrganizationInvitedUser.js'; +import { NotFoundError } from '../../domain/errors.js'; -module.exports = { - async get({ organizationInvitationId, email }) { - const invitation = await knex('organization-invitations') - .select('id', 'organizationId', 'code', 'role', 'status') - .where({ id: organizationInvitationId }) - .first(); - if (!invitation) { - throw new NotFoundError(`Not found organization-invitation for ID ${organizationInvitationId}`); - } +const get = async function ({ organizationInvitationId, email }) { + const invitation = await knex('organization-invitations') + .select('id', 'organizationId', 'code', 'role', 'status') + .where({ id: organizationInvitationId }) + .first(); + if (!invitation) { + throw new NotFoundError(`Not found organization-invitation for ID ${organizationInvitationId}`); + } - const user = await knex('users').select('id').where({ email }).first(); - if (!user) { - throw new NotFoundError(`Not found user for email ${email}`); - } + const user = await knex('users').select('id').where({ email }).first(); + if (!user) { + throw new NotFoundError(`Not found user for email ${email}`); + } - const memberships = await knex('memberships') - .select('id', 'userId', 'organizationRole') - .where({ - organizationId: invitation.organizationId, - disabledAt: null, - }) - .orderBy('id', 'ASC'); - - const existingMembership = memberships.find((membership) => membership.userId === user.id); + const memberships = await knex('memberships') + .select('id', 'userId', 'organizationRole') + .where({ + organizationId: invitation.organizationId, + disabledAt: null, + }) + .orderBy('id', 'ASC'); - return new OrganizationInvitedUser({ - userId: user.id, - invitation, - currentMembershipId: existingMembership?.id, - currentRole: existingMembership?.organizationRole, - organizationHasMemberships: memberships.length, - status: invitation.status, - }); - }, + const existingMembership = memberships.find((membership) => membership.userId === user.id); - async save({ organizationInvitedUser }) { - const date = new Date(); - - if (organizationInvitedUser.isAlreadyMemberOfOrganization) { - await knex('memberships') - .update({ - organizationRole: organizationInvitedUser.currentRole, - updatedAt: date, - }) - .where({ id: organizationInvitedUser.currentMembershipId }); - } else { - const [{ id: membershipId }] = await knex('memberships') - .insert({ - organizationRole: organizationInvitedUser.currentRole, - organizationId: organizationInvitedUser.invitation.organizationId, - userId: organizationInvitedUser.userId, - }) - .returning('id'); + return new OrganizationInvitedUser({ + userId: user.id, + invitation, + currentMembershipId: existingMembership?.id, + currentRole: existingMembership?.organizationRole, + organizationHasMemberships: memberships.length, + status: invitation.status, + }); +}; - organizationInvitedUser.currentMembershipId = membershipId; - } +const save = async function ({ organizationInvitedUser }) { + const date = new Date(); - await knex('user-orga-settings') + if (organizationInvitedUser.isAlreadyMemberOfOrganization) { + await knex('memberships') + .update({ + organizationRole: organizationInvitedUser.currentRole, + updatedAt: date, + }) + .where({ id: organizationInvitedUser.currentMembershipId }); + } else { + const [{ id: membershipId }] = await knex('memberships') .insert({ + organizationRole: organizationInvitedUser.currentRole, + organizationId: organizationInvitedUser.invitation.organizationId, userId: organizationInvitedUser.userId, - currentOrganizationId: organizationInvitedUser.invitation.organizationId, - updatedAt: new Date(), }) - .onConflict('userId') - .merge(); + .returning('id'); + + organizationInvitedUser.currentMembershipId = membershipId; + } - await knex('organization-invitations') - .update({ status: organizationInvitedUser.status, updatedAt: date }) - .where({ id: organizationInvitedUser.invitation.id }); - }, + await knex('user-orga-settings') + .insert({ + userId: organizationInvitedUser.userId, + currentOrganizationId: organizationInvitedUser.invitation.organizationId, + updatedAt: new Date(), + }) + .onConflict('userId') + .merge(); + + await knex('organization-invitations') + .update({ status: organizationInvitedUser.status, updatedAt: date }) + .where({ id: organizationInvitedUser.invitation.id }); }; + +export { get, save }; diff --git a/api/lib/infrastructure/repositories/organization-learner-activity-repository.js b/api/lib/infrastructure/repositories/organization-learner-activity-repository.js index de3867195f0..7f0bc556d4a 100644 --- a/api/lib/infrastructure/repositories/organization-learner-activity-repository.js +++ b/api/lib/infrastructure/repositories/organization-learner-activity-repository.js @@ -1,6 +1,6 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const OrganizationLearnerParticipation = require('../../domain/read-models/OrganizationLearnerParticipation.js'); -const OrganizationLearnerActivity = require('../../domain/read-models/OrganizationLearnerActivity.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { OrganizationLearnerParticipation } from '../../domain/read-models/OrganizationLearnerParticipation.js'; +import { OrganizationLearnerActivity } from '../../domain/read-models/OrganizationLearnerActivity.js'; async function get(organizationLearnerId) { const organizationLearnerParticipations = await knex('campaign-participations') @@ -34,4 +34,4 @@ async function get(organizationLearnerId) { return new OrganizationLearnerActivity({ organizationLearnerId, participations }); } -module.exports = { get }; +export { get }; diff --git a/api/lib/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository.js b/api/lib/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository.js index 4334f0911e8..f2bb2cd147a 100644 --- a/api/lib/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository.js +++ b/api/lib/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository.js @@ -1,8 +1,8 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../../domain/errors.js'); -const OrganizationLearner = require('../../../domain/read-models/organization-learner-follow-up/OrganizationLearner.js'); -const CampaignTypes = require('../../../domain/models/CampaignTypes.js'); -const CampaignParticipationStatuses = require('../../../domain/models/CampaignParticipationStatuses.js'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../../domain/errors.js'; +import { OrganizationLearner } from '../../../domain/read-models/organization-learner-follow-up/OrganizationLearner.js'; +import { CampaignTypes } from '../../../domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../../domain/models/CampaignParticipationStatuses.js'; function _buildIsCertifiable(queryBuilder, organizationLearnerId) { queryBuilder @@ -66,4 +66,4 @@ async function get(organizationLearnerId) { throw new NotFoundError(`Student not found for ID ${organizationLearnerId}`); } -module.exports = { get }; +export { get }; diff --git a/api/lib/infrastructure/repositories/organization-learner-repository.js b/api/lib/infrastructure/repositories/organization-learner-repository.js index 9320c3064cf..c9c567605d4 100644 --- a/api/lib/infrastructure/repositories/organization-learner-repository.js +++ b/api/lib/infrastructure/repositories/organization-learner-repository.js @@ -1,21 +1,20 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { +import { NotFoundError, OrganizationLearnerNotFound, OrganizationLearnersCouldNotBeSavedError, UserCouldNotBeReconciledError, UserNotFoundError, -} = require('../../domain/errors.js'); +} from '../../domain/errors.js'; -const OrganizationLearner = require('../../domain/models/OrganizationLearner.js'); -const OrganizationLearnerForAdmin = require('../../domain/read-models/OrganizationLearnerForAdmin.js'); -const studentRepository = require('./student-repository.js'); +import { OrganizationLearner } from '../../domain/models/OrganizationLearner.js'; +import { OrganizationLearnerForAdmin } from '../../domain/read-models/OrganizationLearnerForAdmin.js'; +import * as studentRepository from './student-repository.js'; -const { knex } = require('../../../db/knex-database-connection.js'); -const { fetchPage } = require('../utils/knex-utils.js'); - -const DomainTransaction = require('../DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { DomainTransaction } from '../DomainTransaction.js'; function _shouldStudentToImportBeReconciled( allOrganizationLearnersInSameOrganization, @@ -41,293 +40,328 @@ function _shouldStudentToImportBeReconciled( return isFromSameOrganization || isFromDifferentOrganizationWithSameBirthday; } -module.exports = { - async findByIds({ ids }) { - const rawOrganizationLearners = await knex - .select('*') - .from('view-active-organization-learners') - .whereIn('id', ids) - .orderBy('id'); - - return rawOrganizationLearners.map((rawOrganizationLearner) => new OrganizationLearner(rawOrganizationLearner)); - }, - - findByOrganizationId({ organizationId }, transaction = DomainTransaction.emptyTransaction()) { - const knexConn = transaction.knexTransaction || knex; - return knexConn('view-active-organization-learners') - .where({ organizationId }) - .orderByRaw('LOWER("lastName") ASC, LOWER("firstName") ASC') - .then((organizationLearners) => - organizationLearners.map((organizationLearner) => new OrganizationLearner(organizationLearner)) - ); - }, - - async findByOrganizationIdAndUpdatedAtOrderByDivision({ organizationId, page, filter }) { - const BEGINNING_OF_THE_2020_SCHOOL_YEAR = '2020-08-15'; - const query = knex('view-active-organization-learners') - .where({ - organizationId, - isDisabled: false, - }) - .where('updatedAt', '>', BEGINNING_OF_THE_2020_SCHOOL_YEAR) - .orderByRaw('LOWER("division") ASC, LOWER("lastName") ASC, LOWER("firstName") ASC'); +const findByIds = async function ({ ids }) { + const rawOrganizationLearners = await knex + .select('*') + .from('view-active-organization-learners') + .whereIn('id', ids) + .orderBy('id'); - if (filter.divisions) { - query.whereIn('division', filter.divisions); - } + return rawOrganizationLearners.map((rawOrganizationLearner) => new OrganizationLearner(rawOrganizationLearner)); +}; + +const findByOrganizationId = function ({ organizationId }, transaction = DomainTransaction.emptyTransaction()) { + const knexConn = transaction.knexTransaction || knex; + return knexConn('view-active-organization-learners') + .where({ organizationId }) + .orderByRaw('LOWER("lastName") ASC, LOWER("firstName") ASC') + .then((organizationLearners) => + organizationLearners.map((organizationLearner) => new OrganizationLearner(organizationLearner)) + ); +}; - const { results, pagination } = await fetchPage(query, page); +const findByOrganizationIdAndUpdatedAtOrderByDivision = async function ({ organizationId, page, filter }) { + const BEGINNING_OF_THE_2020_SCHOOL_YEAR = '2020-08-15'; + const query = knex('view-active-organization-learners') + .where({ + organizationId, + isDisabled: false, + }) + .where('updatedAt', '>', BEGINNING_OF_THE_2020_SCHOOL_YEAR) + .orderByRaw('LOWER("division") ASC, LOWER("lastName") ASC, LOWER("firstName") ASC'); + + if (filter.divisions) { + query.whereIn('division', filter.divisions); + } + + const { results, pagination } = await fetchPage(query, page); + + return { + data: results.map((result) => new OrganizationLearner(result)), + pagination, + }; +}; + +const findByUserId = async function ({ userId }) { + const rawOrganizationLearners = await knex + .select('*') + .from('view-active-organization-learners') + .where({ userId }) + .orderBy('id'); - return { - data: results.map((result) => new OrganizationLearner(result)), - pagination, - }; - }, + return rawOrganizationLearners.map((rawOrganizationLearner) => new OrganizationLearner(rawOrganizationLearner)); +}; - async findByUserId({ userId }) { - const rawOrganizationLearners = await knex - .select('*') - .from('view-active-organization-learners') - .where({ userId }) - .orderBy('id'); +const isOrganizationLearnerIdLinkedToUserAndSCOOrganization = async function ({ userId, organizationLearnerId }) { + const exist = await knex('view-active-organization-learners') + .select('view-active-organization-learners.id') + .join('organizations', 'view-active-organization-learners.organizationId', 'organizations.id') + .where({ userId, type: 'SCO', 'view-active-organization-learners.id': organizationLearnerId }) + .first(); - return rawOrganizationLearners.map((rawOrganizationLearner) => new OrganizationLearner(rawOrganizationLearner)); - }, + return Boolean(exist); +}; - async isOrganizationLearnerIdLinkedToUserAndSCOOrganization({ userId, organizationLearnerId }) { - const exist = await knex('view-active-organization-learners') - .select('view-active-organization-learners.id') - .join('organizations', 'view-active-organization-learners.organizationId', 'organizations.id') - .where({ userId, type: 'SCO', 'view-active-organization-learners.id': organizationLearnerId }) - .first(); +const disableAllOrganizationLearnersInOrganization = async function ({ domainTransaction, organizationId }) { + const knexConn = domainTransaction.knexTransaction; + await knexConn('organization-learners') + .where({ organizationId, isDisabled: false }) + .update({ isDisabled: true, updatedAt: knexConn.raw('CURRENT_TIMESTAMP') }); +}; + +const addOrUpdateOrganizationOfOrganizationLearners = async function ( + organizationLearnerDatas, + organizationId, + domainTransaction +) { + const knexConn = domainTransaction.knexTransaction; + const organizationLearnersFromFile = organizationLearnerDatas.map( + (organizationLearnerData) => + new OrganizationLearner({ + ...organizationLearnerData, + organizationId, + }) + ); + const existingOrganizationLearners = await this.findByOrganizationId({ organizationId }, domainTransaction); - return Boolean(exist); - }, + const reconciledOrganizationLearnersToImport = await this._reconcileOrganizationLearners( + organizationLearnersFromFile, + existingOrganizationLearners, + domainTransaction + ); - async disableAllOrganizationLearnersInOrganization({ domainTransaction, organizationId }) { - const knexConn = domainTransaction.knexTransaction; + try { + const organizationLearnersToSave = reconciledOrganizationLearnersToImport.map((organizationLearner) => ({ + ..._.omit(organizationLearner, ['id', 'createdAt']), + updatedAt: knexConn.raw('CURRENT_TIMESTAMP'), + isDisabled: false, + })); await knexConn('organization-learners') - .where({ organizationId, isDisabled: false }) - .update({ isDisabled: true, updatedAt: knexConn.raw('CURRENT_TIMESTAMP') }); - }, - - async addOrUpdateOrganizationOfOrganizationLearners(organizationLearnerDatas, organizationId, domainTransaction) { - const knexConn = domainTransaction.knexTransaction; - const organizationLearnersFromFile = organizationLearnerDatas.map( - (organizationLearnerData) => - new OrganizationLearner({ - ...organizationLearnerData, - organizationId, - }) - ); - const existingOrganizationLearners = await this.findByOrganizationId({ organizationId }, domainTransaction); + .insert(organizationLearnersToSave) + .onConflict(['organizationId', 'nationalStudentId']) + .merge(); + } catch (err) { + throw new OrganizationLearnersCouldNotBeSavedError(); + } +}; - const reconciledOrganizationLearnersToImport = await this._reconcileOrganizationLearners( - organizationLearnersFromFile, - existingOrganizationLearners, - domainTransaction +const _reconcileOrganizationLearners = async function ( + studentsToImport, + allOrganizationLearnersInSameOrganization, + domainTransaction +) { + const nationalStudentIdsFromFile = studentsToImport + .map((organizationLearnerData) => organizationLearnerData.nationalStudentId) + .filter(Boolean); + const organizationLearnersWithSameNationalStudentIdsAsImported = + await studentRepository.findReconciledStudentsByNationalStudentId(nationalStudentIdsFromFile, domainTransaction); + + organizationLearnersWithSameNationalStudentIdsAsImported.forEach((organizationLearner) => { + const alreadyReconciledStudentToImport = studentsToImport.find( + (studentToImport) => studentToImport.userId === organizationLearner.account.userId ); - try { - const organizationLearnersToSave = reconciledOrganizationLearnersToImport.map((organizationLearner) => ({ - ..._.omit(organizationLearner, ['id', 'createdAt']), - updatedAt: knexConn.raw('CURRENT_TIMESTAMP'), - isDisabled: false, - })); - await knexConn('organization-learners') - .insert(organizationLearnersToSave) - .onConflict(['organizationId', 'nationalStudentId']) - .merge(); - } catch (err) { - throw new OrganizationLearnersCouldNotBeSavedError(); + if (alreadyReconciledStudentToImport) { + alreadyReconciledStudentToImport.userId = null; + return; } - }, - - async _reconcileOrganizationLearners(studentsToImport, allOrganizationLearnersInSameOrganization, domainTransaction) { - const nationalStudentIdsFromFile = studentsToImport - .map((organizationLearnerData) => organizationLearnerData.nationalStudentId) - .filter(Boolean); - const organizationLearnersWithSameNationalStudentIdsAsImported = - await studentRepository.findReconciledStudentsByNationalStudentId(nationalStudentIdsFromFile, domainTransaction); - - organizationLearnersWithSameNationalStudentIdsAsImported.forEach((organizationLearner) => { - const alreadyReconciledStudentToImport = studentsToImport.find( - (studentToImport) => studentToImport.userId === organizationLearner.account.userId - ); - - if (alreadyReconciledStudentToImport) { - alreadyReconciledStudentToImport.userId = null; - return; - } - - const studentToImport = studentsToImport.find( - (studentToImport) => studentToImport.nationalStudentId === organizationLearner.nationalStudentId - ); - - if ( - _shouldStudentToImportBeReconciled( - allOrganizationLearnersInSameOrganization, - organizationLearner, - studentToImport - ) - ) { - studentToImport.userId = organizationLearner.account.userId; - } - }); - return studentsToImport; - }, - - async findByOrganizationIdAndBirthdate({ organizationId, birthdate }) { - const rawOrganizationLearners = await knex - .select('*') - .from('view-active-organization-learners') - .where({ organizationId, birthdate, isDisabled: false }) - .orderBy('id'); - - return rawOrganizationLearners.map((rawOrganizationLearner) => new OrganizationLearner(rawOrganizationLearner)); - }, - - async reconcileUserToOrganizationLearner({ userId, organizationLearnerId }) { - try { - const [rawOrganizationLearner] = await knex('organization-learners') - .where({ id: organizationLearnerId }) - .where('isDisabled', false) - .update({ userId, updatedAt: knex.fn.now() }) - .returning('*'); - if (!rawOrganizationLearner) throw new Error(); - return new OrganizationLearner(rawOrganizationLearner); - } catch (error) { - throw new UserCouldNotBeReconciledError(); - } - }, - - async reconcileUserByNationalStudentIdAndOrganizationId({ nationalStudentId, userId, organizationId }) { - try { - const [rawOrganizationLearner] = await knex('organization-learners') - .where({ - organizationId, - nationalStudentId, - isDisabled: false, - }) - .update({ userId, updatedAt: knex.fn.now() }) - .returning('*'); - if (!rawOrganizationLearner) throw new Error(); - return new OrganizationLearner(rawOrganizationLearner); - } catch (error) { - throw new UserCouldNotBeReconciledError(); - } - }, - - async getOrganizationLearnerForAdmin(organizationLearnerId) { - const organizationLearner = await knex('view-active-organization-learners') - .select( - 'view-active-organization-learners.id as id', - 'firstName', - 'lastName', - 'birthdate', - 'division', - 'group', - 'organizationId', - 'organizations.name as organizationName', - 'view-active-organization-learners.createdAt as createdAt', - 'view-active-organization-learners.updatedAt as updatedAt', - 'isDisabled', - 'organizations.isManagingStudents as organizationIsManagingStudents' - ) - .innerJoin('organizations', 'organizations.id', 'view-active-organization-learners.organizationId') - .where({ 'view-active-organization-learners.id': organizationLearnerId }) - .first(); - if (!organizationLearner) { - throw new NotFoundError(`Organization Learner not found for ID ${organizationLearnerId}`); + const studentToImport = studentsToImport.find( + (studentToImport) => studentToImport.nationalStudentId === organizationLearner.nationalStudentId + ); + + if ( + _shouldStudentToImportBeReconciled( + allOrganizationLearnersInSameOrganization, + organizationLearner, + studentToImport + ) + ) { + studentToImport.userId = organizationLearner.account.userId; } - return new OrganizationLearnerForAdmin(organizationLearner); - }, + }); + return studentsToImport; +}; - async dissociateUserFromOrganizationLearner(organizationLearnerId) { - await knex('organization-learners').where({ id: organizationLearnerId }).update({ userId: null }); - }, +const findByOrganizationIdAndBirthdate = async function ({ organizationId, birthdate }) { + const rawOrganizationLearners = await knex + .select('*') + .from('view-active-organization-learners') + .where({ organizationId, birthdate, isDisabled: false }) + .orderBy('id'); - async dissociateAllStudentsByUserId({ userId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction.knexTransaction ?? knex; - await knexConn('organization-learners') - .update({ userId: null, updatedAt: knex.fn.now() }) - .where({ userId }) - .whereIn( - 'organization-learners.organizationId', - knex.select('id').from('organizations').where({ isManagingStudents: true }) - ); - }, - - async findOneByUserIdAndOrganizationId({ - userId, - organizationId, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const organizationLearner = await knex('view-active-organization-learners') - .transacting(domainTransaction) - .where({ userId, organizationId }) - .first('*'); - if (!organizationLearner) return null; - return new OrganizationLearner(organizationLearner); - }, - - async get(organizationLearnerId) { - const organizationLearner = await knex - .select('*') - .from('view-active-organization-learners') - .where({ id: organizationLearnerId }) - .first(); + return rawOrganizationLearners.map((rawOrganizationLearner) => new OrganizationLearner(rawOrganizationLearner)); +}; - if (!organizationLearner) { - throw new NotFoundError(`Student not found for ID ${organizationLearnerId}`); - } - return new OrganizationLearner(organizationLearner); - }, - - async getLatestOrganizationLearner({ nationalStudentId, birthdate }) { - const organizationLearner = await knex - .where({ nationalStudentId, birthdate }) - .whereNotNull('userId') - .select() - .from('view-active-organization-learners') - .orderBy('updatedAt', 'desc') - .first(); - - if (!organizationLearner) { - throw new UserNotFoundError(); - } +const reconcileUserToOrganizationLearner = async function ({ userId, organizationLearnerId }) { + try { + const [rawOrganizationLearner] = await knex('organization-learners') + .where({ id: organizationLearnerId }) + .where('isDisabled', false) + .update({ userId, updatedAt: knex.fn.now() }) + .returning('*'); + if (!rawOrganizationLearner) throw new Error(); + return new OrganizationLearner(rawOrganizationLearner); + } catch (error) { + throw new UserCouldNotBeReconciledError(); + } +}; - return organizationLearner; - }, - - async updateUserIdWhereNull({ - organizationLearnerId, - userId, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knexConn = domainTransaction.knexTransaction || knex; - const [rawOrganizationLearner] = await knexConn('organization-learners') - .where({ id: organizationLearnerId, userId: null }) +const reconcileUserByNationalStudentIdAndOrganizationId = async function ({ + nationalStudentId, + userId, + organizationId, +}) { + try { + const [rawOrganizationLearner] = await knex('organization-learners') + .where({ + organizationId, + nationalStudentId, + isDisabled: false, + }) .update({ userId, updatedAt: knex.fn.now() }) .returning('*'); + if (!rawOrganizationLearner) throw new Error(); + return new OrganizationLearner(rawOrganizationLearner); + } catch (error) { + throw new UserCouldNotBeReconciledError(); + } +}; - if (!rawOrganizationLearner) - throw new OrganizationLearnerNotFound( - `OrganizationLearner not found for ID ${organizationLearnerId} and user ID null.` - ); +const getOrganizationLearnerForAdmin = async function (organizationLearnerId) { + const organizationLearner = await knex('view-active-organization-learners') + .select( + 'view-active-organization-learners.id as id', + 'firstName', + 'lastName', + 'birthdate', + 'division', + 'group', + 'organizationId', + 'organizations.name as organizationName', + 'view-active-organization-learners.createdAt as createdAt', + 'view-active-organization-learners.updatedAt as updatedAt', + 'isDisabled', + 'organizations.isManagingStudents as organizationIsManagingStudents' + ) + .innerJoin('organizations', 'organizations.id', 'view-active-organization-learners.organizationId') + .where({ 'view-active-organization-learners.id': organizationLearnerId }) + .first(); + + if (!organizationLearner) { + throw new NotFoundError(`Organization Learner not found for ID ${organizationLearnerId}`); + } + return new OrganizationLearnerForAdmin(organizationLearner); +}; - return new OrganizationLearner(rawOrganizationLearner); - }, - - async isActive({ userId, campaignId }) { - const learner = await knex('view-active-organization-learners') - .select('view-active-organization-learners.isDisabled') - .join('organizations', 'organizations.id', 'view-active-organization-learners.organizationId') - .join('campaigns', 'campaigns.organizationId', 'organizations.id') - .where({ 'campaigns.id': campaignId }) - .andWhere({ 'view-active-organization-learners.userId': userId }) - .first(); - return !learner?.isDisabled; - }, +const dissociateUserFromOrganizationLearner = async function (organizationLearnerId) { + await knex('organization-learners').where({ id: organizationLearnerId }).update({ userId: null }); +}; + +const dissociateAllStudentsByUserId = async function ({ + userId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction ?? knex; + await knexConn('organization-learners') + .update({ userId: null, updatedAt: knex.fn.now() }) + .where({ userId }) + .whereIn( + 'organization-learners.organizationId', + knex.select('id').from('organizations').where({ isManagingStudents: true }) + ); +}; + +const findOneByUserIdAndOrganizationId = async function ({ + userId, + organizationId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const organizationLearner = await knex('view-active-organization-learners') + .transacting(domainTransaction) + .where({ userId, organizationId }) + .first('*'); + if (!organizationLearner) return null; + return new OrganizationLearner(organizationLearner); +}; + +const get = async function (organizationLearnerId) { + const organizationLearner = await knex + .select('*') + .from('view-active-organization-learners') + .where({ id: organizationLearnerId }) + .first(); + + if (!organizationLearner) { + throw new NotFoundError(`Student not found for ID ${organizationLearnerId}`); + } + return new OrganizationLearner(organizationLearner); +}; + +const getLatestOrganizationLearner = async function ({ nationalStudentId, birthdate }) { + const organizationLearner = await knex + .where({ nationalStudentId, birthdate }) + .whereNotNull('userId') + .select() + .from('view-active-organization-learners') + .orderBy('updatedAt', 'desc') + .first(); + + if (!organizationLearner) { + throw new UserNotFoundError(); + } + + return organizationLearner; +}; + +const updateUserIdWhereNull = async function ({ + organizationLearnerId, + userId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction.knexTransaction || knex; + const [rawOrganizationLearner] = await knexConn('organization-learners') + .where({ id: organizationLearnerId, userId: null }) + .update({ userId, updatedAt: knex.fn.now() }) + .returning('*'); + + if (!rawOrganizationLearner) + throw new OrganizationLearnerNotFound( + `OrganizationLearner not found for ID ${organizationLearnerId} and user ID null.` + ); + + return new OrganizationLearner(rawOrganizationLearner); +}; + +const isActive = async function ({ userId, campaignId }) { + const learner = await knex('view-active-organization-learners') + .select('view-active-organization-learners.isDisabled') + .join('organizations', 'organizations.id', 'view-active-organization-learners.organizationId') + .join('campaigns', 'campaigns.organizationId', 'organizations.id') + .where({ 'campaigns.id': campaignId }) + .andWhere({ 'view-active-organization-learners.userId': userId }) + .first(); + return !learner?.isDisabled; +}; + +export { + findByIds, + findByOrganizationId, + findByOrganizationIdAndUpdatedAtOrderByDivision, + findByUserId, + isOrganizationLearnerIdLinkedToUserAndSCOOrganization, + disableAllOrganizationLearnersInOrganization, + addOrUpdateOrganizationOfOrganizationLearners, + _reconcileOrganizationLearners, + findByOrganizationIdAndBirthdate, + reconcileUserToOrganizationLearner, + reconcileUserByNationalStudentIdAndOrganizationId, + getOrganizationLearnerForAdmin, + dissociateUserFromOrganizationLearner, + dissociateAllStudentsByUserId, + findOneByUserIdAndOrganizationId, + get, + getLatestOrganizationLearner, + updateUserIdWhereNull, + isActive, }; diff --git a/api/lib/infrastructure/repositories/organization-member-identity-repository.js b/api/lib/infrastructure/repositories/organization-member-identity-repository.js index a5109a7d17f..a1835c00834 100644 --- a/api/lib/infrastructure/repositories/organization-member-identity-repository.js +++ b/api/lib/infrastructure/repositories/organization-member-identity-repository.js @@ -1,15 +1,15 @@ -const OrganizationMemberIdentity = require('../../domain/models/OrganizationMemberIdentity.js'); -const { knex } = require('../../../db/knex-database-connection.js'); +import { OrganizationMemberIdentity } from '../../domain/models/OrganizationMemberIdentity.js'; +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async findAllByOrganizationId({ organizationId }) { - const sortedMembers = await knex('users') - .select('users.id', 'users.firstName', 'users.lastName') - .join('memberships', 'memberships.userId', 'users.id') - .where({ disabledAt: null, organizationId }) - .orderByRaw('LOWER("firstName") asc') - .orderByRaw('LOWER("lastName") asc'); +const findAllByOrganizationId = async function ({ organizationId }) { + const sortedMembers = await knex('users') + .select('users.id', 'users.firstName', 'users.lastName') + .join('memberships', 'memberships.userId', 'users.id') + .where({ disabledAt: null, organizationId }) + .orderByRaw('LOWER("firstName") asc') + .orderByRaw('LOWER("lastName") asc'); - return sortedMembers.map((sortedMember) => new OrganizationMemberIdentity({ ...sortedMember })); - }, + return sortedMembers.map((sortedMember) => new OrganizationMemberIdentity({ ...sortedMember })); }; + +export { findAllByOrganizationId }; diff --git a/api/lib/infrastructure/repositories/organization-participant-repository.js b/api/lib/infrastructure/repositories/organization-participant-repository.js index 12292f2e532..404f3337718 100644 --- a/api/lib/infrastructure/repositories/organization-participant-repository.js +++ b/api/lib/infrastructure/repositories/organization-participant-repository.js @@ -1,9 +1,9 @@ -const OrganizationParticipant = require('../../domain/read-models/OrganizationParticipant.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const { filterByFullName } = require('../utils/filter-utils.js'); -const CampaignTypes = require('../../domain/models/CampaignTypes.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); +import { OrganizationParticipant } from '../../domain/read-models/OrganizationParticipant.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { filterByFullName } from '../utils/filter-utils.js'; +import { CampaignTypes } from '../../domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; async function getParticipantsByOrganizationId({ organizationId, page, filters = {}, sort = {} }) { const { count } = await knex @@ -142,6 +142,4 @@ function _buildIsCertifiable(queryBuilder, organizationId) { .where('campaign-participations.deletedAt', null); } -module.exports = { - getParticipantsByOrganizationId, -}; +export { getParticipantsByOrganizationId }; diff --git a/api/lib/infrastructure/repositories/organization-places-capacity-repository.js b/api/lib/infrastructure/repositories/organization-places-capacity-repository.js index e5c0b3586c7..2571ffa811b 100644 --- a/api/lib/infrastructure/repositories/organization-places-capacity-repository.js +++ b/api/lib/infrastructure/repositories/organization-places-capacity-repository.js @@ -1,5 +1,5 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const OrganizationPlacesCapacity = require('../../domain/read-models/OrganizationPlacesCapacity.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { OrganizationPlacesCapacity } from '../../domain/read-models/OrganizationPlacesCapacity.js'; async function findByOrganizationId(organizationId) { const now = new Date(); @@ -15,6 +15,4 @@ async function findByOrganizationId(organizationId) { return new OrganizationPlacesCapacity({ placesLots: organizationPlacesLots, organizationId }); } -module.exports = { - findByOrganizationId, -}; +export { findByOrganizationId }; diff --git a/api/lib/infrastructure/repositories/organization-repository.js b/api/lib/infrastructure/repositories/organization-repository.js index 3c20270a75e..f2c03319ba1 100644 --- a/api/lib/infrastructure/repositories/organization-repository.js +++ b/api/lib/infrastructure/repositories/organization-repository.js @@ -1,10 +1,10 @@ -const _ = require('lodash'); -const { NotFoundError } = require('../../domain/errors.js'); -const Organization = require('../../domain/models/Organization.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const Tag = require('../../domain/models/Tag.js'); -const { fetchPage } = require('../utils/knex-utils.js'); +import _ from 'lodash'; +import { NotFoundError } from '../../domain/errors.js'; +import { Organization } from '../../domain/models/Organization.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { Tag } from '../../domain/models/Tag.js'; +import { fetchPage } from '../utils/knex-utils.js'; function _toDomain(rawOrganization) { const organization = new Organization({ @@ -48,153 +48,167 @@ function _setSearchFiltersForQueryBuilder(qb, filter) { } } -module.exports = { - create(organization) { - const organizationRawData = _.pick(organization, [ +const create = function (organization) { + const organizationRawData = _.pick(organization, [ + 'name', + 'type', + 'logoUrl', + 'externalId', + 'provinceCode', + 'email', + 'isManagingStudents', + 'createdBy', + 'documentationUrl', + ]); + + return knex('organizations') + .insert(organizationRawData) + .returning('*') + .then(([organization]) => _toDomain(organization)); +}; + +const batchCreateOrganizations = async function ( + organizations, + domainTransaction = DomainTransaction.emptyTransaction() +) { + const organizationsRawData = organizations.map((organization) => + _.pick(organization, [ 'name', 'type', - 'logoUrl', - 'externalId', - 'provinceCode', 'email', - 'isManagingStudents', - 'createdBy', - 'documentationUrl', - ]); - - return knex('organizations') - .insert(organizationRawData) - .returning('*') - .then(([organization]) => _toDomain(organization)); - }, - - async batchCreateOrganizations(organizations, domainTransaction = DomainTransaction.emptyTransaction()) { - const organizationsRawData = organizations.map((organization) => - _.pick(organization, [ - 'name', - 'type', - 'email', - 'externalId', - 'provinceCode', - 'isManagingStudents', - 'identityProviderForCampaigns', - 'credit', - 'createdBy', - 'documentationUrl', - ]) - ); - return knex - .batchInsert('organizations', organizationsRawData) - .transacting(domainTransaction.knexTransaction) - .returning(['id', 'externalId', 'name']); - }, - - async update(organization) { - const organizationRawData = _.pick(organization, [ - 'name', - 'type', - 'logoUrl', 'externalId', 'provinceCode', 'isManagingStudents', - 'email', + 'identityProviderForCampaigns', 'credit', + 'createdBy', 'documentationUrl', - 'showSkills', - ]); - - const [organizationDB] = await knex('organizations') - .update(organizationRawData) - .where({ id: organization.id }) - .returning('*'); - - const tagsDB = await knex('tags') - .select(['tags.id', 'tags.name']) - .join('organization-tags', 'organization-tags.tagId', 'tags.id') - .where('organization-tags.organizationId', organizationDB.id); - - const tags = tagsDB.map((tagDB) => new Tag(tagDB)); - - return _toDomain({ ...organizationDB, tags }); - }, - - async get(id) { - const organizationDB = await knex('organizations').where({ id }).first(); - if (!organizationDB) { - throw new NotFoundError(`Not found organization for ID ${id}`); - } - - const tagsDB = await knex('tags') - .select(['tags.id', 'tags.name']) - .join('organization-tags', 'organization-tags.tagId', 'tags.id') - .where('organization-tags.organizationId', id); - - const tags = tagsDB.map((tagDB) => new Tag(tagDB)); - return _toDomain({ ...organizationDB, tags }); - }, - - async getIdByCertificationCenterId(certificationCenterId) { - const organizationIds = await knex - .pluck('organizations.id') - .from('organizations') - .innerJoin('certification-centers', function () { - this.on('certification-centers.externalId', 'organizations.externalId').andOn( - 'certification-centers.type', - 'organizations.type' - ); - }) - .where('certification-centers.id', certificationCenterId); - - if (organizationIds.length !== 1) - throw new NotFoundError(`Not found organization for certification center id ${certificationCenterId}`); - return organizationIds[0]; - }, - - async getScoOrganizationByExternalId(externalId) { - const organizationDB = await knex('organizations') - .where({ type: Organization.types.SCO }) - .whereRaw('LOWER("externalId") = ?', externalId.toLowerCase()) - .first(); - - if (!organizationDB) { - throw new NotFoundError(`Could not find organization for externalId ${externalId}.`); - } - return _toDomain(organizationDB); - }, - - async findByExternalIdsFetchingIdsOnly(externalIds) { - const organizationsDB = await knex('organizations') - .whereInArray('externalId', externalIds) - .select(['id', 'externalId']); - - return organizationsDB.map((model) => _toDomain(model)); - }, - - async findScoOrganizationsByUai({ uai }) { - const organizationsDB = await knex('organizations') - .where({ type: Organization.types.SCO }) - .whereRaw('LOWER("externalId") = ? ', `${uai.toLowerCase()}`); - - return organizationsDB.map((model) => _toDomain(model)); - }, - - async findPaginatedFiltered({ filter, page }) { - const query = knex('organizations').modify(_setSearchFiltersForQueryBuilder, filter).orderBy('name', 'ASC'); - - const { results, pagination } = await fetchPage(query, page); - const organizations = results.map((model) => _toDomain(model)); - return { models: organizations, pagination }; - }, - - async findPaginatedFilteredByTargetProfile({ targetProfileId, filter, page }) { - const query = knex('organizations') - .select('organizations.*') - .innerJoin('target-profile-shares', 'organizations.id', 'target-profile-shares.organizationId') - .where({ 'target-profile-shares.targetProfileId': targetProfileId }) - .modify(_setSearchFiltersForQueryBuilder, filter); - - const { results, pagination } = await fetchPage(query, page); - const organizations = results.map((model) => _toDomain(model)); - return { models: organizations, pagination }; - }, + ]) + ); + return knex + .batchInsert('organizations', organizationsRawData) + .transacting(domainTransaction.knexTransaction) + .returning(['id', 'externalId', 'name']); +}; + +const update = async function (organization) { + const organizationRawData = _.pick(organization, [ + 'name', + 'type', + 'logoUrl', + 'externalId', + 'provinceCode', + 'isManagingStudents', + 'email', + 'credit', + 'documentationUrl', + 'showSkills', + ]); + + const [organizationDB] = await knex('organizations') + .update(organizationRawData) + .where({ id: organization.id }) + .returning('*'); + + const tagsDB = await knex('tags') + .select(['tags.id', 'tags.name']) + .join('organization-tags', 'organization-tags.tagId', 'tags.id') + .where('organization-tags.organizationId', organizationDB.id); + + const tags = tagsDB.map((tagDB) => new Tag(tagDB)); + + return _toDomain({ ...organizationDB, tags }); +}; + +const get = async function (id) { + const organizationDB = await knex('organizations').where({ id }).first(); + if (!organizationDB) { + throw new NotFoundError(`Not found organization for ID ${id}`); + } + + const tagsDB = await knex('tags') + .select(['tags.id', 'tags.name']) + .join('organization-tags', 'organization-tags.tagId', 'tags.id') + .where('organization-tags.organizationId', id); + + const tags = tagsDB.map((tagDB) => new Tag(tagDB)); + return _toDomain({ ...organizationDB, tags }); +}; + +const getIdByCertificationCenterId = async function (certificationCenterId) { + const organizationIds = await knex + .pluck('organizations.id') + .from('organizations') + .innerJoin('certification-centers', function () { + this.on('certification-centers.externalId', 'organizations.externalId').andOn( + 'certification-centers.type', + 'organizations.type' + ); + }) + .where('certification-centers.id', certificationCenterId); + + if (organizationIds.length !== 1) + throw new NotFoundError(`Not found organization for certification center id ${certificationCenterId}`); + return organizationIds[0]; +}; + +const getScoOrganizationByExternalId = async function (externalId) { + const organizationDB = await knex('organizations') + .where({ type: Organization.types.SCO }) + .whereRaw('LOWER("externalId") = ?', externalId.toLowerCase()) + .first(); + + if (!organizationDB) { + throw new NotFoundError(`Could not find organization for externalId ${externalId}.`); + } + return _toDomain(organizationDB); +}; + +const findByExternalIdsFetchingIdsOnly = async function (externalIds) { + const organizationsDB = await knex('organizations') + .whereInArray('externalId', externalIds) + .select(['id', 'externalId']); + + return organizationsDB.map((model) => _toDomain(model)); +}; + +const findScoOrganizationsByUai = async function ({ uai }) { + const organizationsDB = await knex('organizations') + .where({ type: Organization.types.SCO }) + .whereRaw('LOWER("externalId") = ? ', `${uai.toLowerCase()}`); + + return organizationsDB.map((model) => _toDomain(model)); +}; + +const findPaginatedFiltered = async function ({ filter, page }) { + const query = knex('organizations').modify(_setSearchFiltersForQueryBuilder, filter).orderBy('name', 'ASC'); + + const { results, pagination } = await fetchPage(query, page); + const organizations = results.map((model) => _toDomain(model)); + return { models: organizations, pagination }; +}; + +const findPaginatedFilteredByTargetProfile = async function ({ targetProfileId, filter, page }) { + const query = knex('organizations') + .select('organizations.*') + .innerJoin('target-profile-shares', 'organizations.id', 'target-profile-shares.organizationId') + .where({ 'target-profile-shares.targetProfileId': targetProfileId }) + .modify(_setSearchFiltersForQueryBuilder, filter); + + const { results, pagination } = await fetchPage(query, page); + const organizations = results.map((model) => _toDomain(model)); + return { models: organizations, pagination }; +}; + +export { + create, + batchCreateOrganizations, + update, + get, + getIdByCertificationCenterId, + getScoOrganizationByExternalId, + findByExternalIdsFetchingIdsOnly, + findScoOrganizationsByUai, + findPaginatedFiltered, + findPaginatedFilteredByTargetProfile, }; diff --git a/api/lib/infrastructure/repositories/organization-tag-repository.js b/api/lib/infrastructure/repositories/organization-tag-repository.js index 5f3019527ea..169ac1d9d2b 100644 --- a/api/lib/infrastructure/repositories/organization-tag-repository.js +++ b/api/lib/infrastructure/repositories/organization-tag-repository.js @@ -1,74 +1,83 @@ -const BookshelfOrganizationTag = require('../orm-models/OrganizationTag.js'); -const Bookshelf = require('../bookshelf.js'); -const bookshelfUtils = require('../utils/knex-utils.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const { AlreadyExistingEntityError, OrganizationTagNotFound } = require('../../domain/errors.js'); -const { omit } = require('lodash'); -const DomainTransaction = require('../DomainTransaction.js'); -const OrganizationTagBookshelf = require('../orm-models/OrganizationTag.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const Tag = require('../../domain/models/Tag.js'); +import { BookshelfOrganizationTag } from '../orm-models/OrganizationTag.js'; +import { Bookshelf } from '../bookshelf.js'; +import * as knexUtils from '../utils/knex-utils.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { AlreadyExistingEntityError, OrganizationTagNotFound } from '../../domain/errors.js'; +import lodash from 'lodash'; -module.exports = { - async create(organizationTag) { - try { - const organizationTagToCreate = omit(organizationTag, 'id'); - const bookshelfOrganizationTag = await new BookshelfOrganizationTag(organizationTagToCreate).save(); - return bookshelfToDomainConverter.buildDomainObject(BookshelfOrganizationTag, bookshelfOrganizationTag); - } catch (err) { - if (bookshelfUtils.isUniqConstraintViolated(err)) { - throw new AlreadyExistingEntityError( - `The tag ${organizationTag.tagId} already exists for the organization ${organizationTag.organizationId}.` - ); - } - throw err; - } - }, +const { omit } = lodash; + +import { DomainTransaction } from '../DomainTransaction.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { Tag } from '../../domain/models/Tag.js'; - async delete({ organizationTagId }) { - try { - await BookshelfOrganizationTag.where({ id: organizationTagId }).destroy({ require: true }); - } catch (err) { - throw new OrganizationTagNotFound('An error occurred while deleting the organization tag'); +const create = async function (organizationTag) { + try { + const organizationTagToCreate = omit(organizationTag, 'id'); + const bookshelfOrganizationTag = await new BookshelfOrganizationTag(organizationTagToCreate).save(); + return bookshelfToDomainConverter.buildDomainObject(BookshelfOrganizationTag, bookshelfOrganizationTag); + } catch (err) { + if (knexUtils.isUniqConstraintViolated(err)) { + throw new AlreadyExistingEntityError( + `The tag ${organizationTag.tagId} already exists for the organization ${organizationTag.organizationId}.` + ); } - }, + throw err; + } +}; + +const remove = async function ({ organizationTagId }) { + try { + await BookshelfOrganizationTag.where({ id: organizationTagId }).destroy({ require: true }); + } catch (err) { + throw new OrganizationTagNotFound('An error occurred while deleting the organization tag'); + } +}; - async findOneByOrganizationIdAndTagId({ organizationId, tagId }) { - const bookshelfOrganizationTags = await BookshelfOrganizationTag.query((qb) => { - qb.where('organizationId', organizationId); - qb.where('tagId', tagId); - }).fetchAll(); +const findOneByOrganizationIdAndTagId = async function ({ organizationId, tagId }) { + const bookshelfOrganizationTags = await BookshelfOrganizationTag.query((qb) => { + qb.where('organizationId', organizationId); + qb.where('tagId', tagId); + }).fetchAll(); - return bookshelfOrganizationTags.length > 0 - ? bookshelfToDomainConverter.buildDomainObjects(OrganizationTagBookshelf, bookshelfOrganizationTags)[0] - : []; - }, + return bookshelfOrganizationTags.length > 0 + ? bookshelfToDomainConverter.buildDomainObjects(BookshelfOrganizationTag, bookshelfOrganizationTags)[0] + : []; +}; - async batchCreate(organizationsTags, domainTransaction = DomainTransaction.emptyTransaction()) { - return Bookshelf.knex - .batchInsert('organization-tags', organizationsTags) - .transacting(domainTransaction.knexTransaction); - }, +const batchCreate = async function (organizationsTags, domainTransaction = DomainTransaction.emptyTransaction()) { + return Bookshelf.knex + .batchInsert('organization-tags', organizationsTags) + .transacting(domainTransaction.knexTransaction); +}; - async isExistingByOrganizationIdAndTagId({ organizationId, tagId }) { - const organizationTag = await BookshelfOrganizationTag.where({ organizationId, tagId }).fetch({ require: false }); +const isExistingByOrganizationIdAndTagId = async function ({ organizationId, tagId }) { + const organizationTag = await BookshelfOrganizationTag.where({ organizationId, tagId }).fetch({ require: false }); - return !!organizationTag; - }, + return !!organizationTag; +}; + +const getRecentlyUsedTags = async function ({ tagId, numberOfRecentTags }) { + const organizationIds = ( + await knex.select('organizationId').from('organization-tags').where('tagId', '=', tagId) + ).map(({ organizationId }) => organizationId); + const tags = await knex + .select(knex.raw('"organization-tags"."tagId", "tags"."name", COUNT("organization-tags"."tagId") AS "usedCount"')) + .from('organization-tags') + .join('tags', 'tags.id', '=', 'organization-tags.tagId') + .whereIn('organization-tags.organizationId', organizationIds) + .andWhere('organization-tags.tagId', '!=', tagId) + .groupByRaw('"organization-tags"."tagId", "tags"."name"') + .orderByRaw('"usedCount" DESC, "tags"."name" ASC') + .limit(numberOfRecentTags); + return tags.map(({ tagId: id, name }) => new Tag({ id, name })); +}; - async getRecentlyUsedTags({ tagId, numberOfRecentTags }) { - const organizationIds = ( - await knex.select('organizationId').from('organization-tags').where('tagId', '=', tagId) - ).map(({ organizationId }) => organizationId); - const tags = await knex - .select(knex.raw('"organization-tags"."tagId", "tags"."name", COUNT("organization-tags"."tagId") AS "usedCount"')) - .from('organization-tags') - .join('tags', 'tags.id', '=', 'organization-tags.tagId') - .whereIn('organization-tags.organizationId', organizationIds) - .andWhere('organization-tags.tagId', '!=', tagId) - .groupByRaw('"organization-tags"."tagId", "tags"."name"') - .orderByRaw('"usedCount" DESC, "tags"."name" ASC') - .limit(numberOfRecentTags); - return tags.map(({ tagId: id, name }) => new Tag({ id, name })); - }, +export { + create, + remove, + findOneByOrganizationIdAndTagId, + batchCreate, + isExistingByOrganizationIdAndTagId, + getRecentlyUsedTags, }; diff --git a/api/lib/infrastructure/repositories/organizations-administration/organization-feature-repository.js b/api/lib/infrastructure/repositories/organizations-administration/organization-feature-repository.js index cbfbc111893..acc2cae288a 100644 --- a/api/lib/infrastructure/repositories/organizations-administration/organization-feature-repository.js +++ b/api/lib/infrastructure/repositories/organizations-administration/organization-feature-repository.js @@ -1,34 +1,35 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -module.exports = { - addFeatureToOrganization({ organizationId, featureKey }) { - return knex('organization-features') - .insert({ - organizationId, - featureId: function () { - return this.select('id').from('features').where({ key: featureKey }); - }, - }) - .onConflict() - .ignore(); - }, +import { knex } from '../../../../db/knex-database-connection.js'; - removeFeatureToOrganization({ organizationId, featureKey }) { - return knex('organization-features') - .where({ - organizationId, - featureId: function () { - return this.select('id').from('features').where({ key: featureKey }); - }, - }) - .delete(); - }, +const addFeatureToOrganization = function ({ organizationId, featureKey }) { + return knex('organization-features') + .insert({ + organizationId, + featureId: function () { + return this.select('id').from('features').where({ key: featureKey }); + }, + }) + .onConflict() + .ignore(); +}; + +const removeFeatureToOrganization = function ({ organizationId, featureKey }) { + return knex('organization-features') + .where({ + organizationId, + featureId: function () { + return this.select('id').from('features').where({ key: featureKey }); + }, + }) + .delete(); +}; - async getFeaturesListFromOrganization(organizationId) { - return knex('features') - .select('key') - .join('organization-features', function () { - this.on('featureId', 'features.id').andOn('organization-features.organizationId', organizationId); - }) - .pluck('key'); - }, +const getFeaturesListFromOrganization = async function (organizationId) { + return knex('features') + .select('key') + .join('organization-features', function () { + this.on('featureId', 'features.id').andOn('organization-features.organizationId', organizationId); + }) + .pluck('key'); }; + +export { addFeatureToOrganization, removeFeatureToOrganization, getFeaturesListFromOrganization }; diff --git a/api/lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js b/api/lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js index dbede587ebe..07bd1db5aa0 100644 --- a/api/lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js +++ b/api/lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js @@ -1,26 +1,25 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { foreignKeyConstraintViolated } from '../utils/knex-utils.js'; +import { NotFoundError } from '../../domain/errors.js'; -const { foreignKeyConstraintViolated } = require('../utils/knex-utils.js'); -const { NotFoundError } = require('../../domain/errors.js'); +const attachOrganizations = async function (targetProfile) { + const rows = targetProfile.organizations.map((organizationId) => { + return { + organizationId, + targetProfileId: targetProfile.id, + }; + }); + const attachedOrganizationIds = await _createTargetProfileShares(rows); -module.exports = { - async attachOrganizations(targetProfile) { - const rows = targetProfile.organizations.map((organizationId) => { - return { - organizationId, - targetProfileId: targetProfile.id, - }; - }); - const attachedOrganizationIds = await _createTargetProfileShares(rows); + const duplicatedOrganizationIds = targetProfile.organizations.filter( + (organizationId) => !attachedOrganizationIds.includes(organizationId) + ); - const duplicatedOrganizationIds = targetProfile.organizations.filter( - (organizationId) => !attachedOrganizationIds.includes(organizationId) - ); - - return { duplicatedIds: duplicatedOrganizationIds, attachedIds: attachedOrganizationIds }; - }, + return { duplicatedIds: duplicatedOrganizationIds, attachedIds: attachedOrganizationIds }; }; +export { attachOrganizations }; + async function _createTargetProfileShares(targetProfileShares) { try { const insertedTargetProfileShares = await knex('target-profile-shares') diff --git a/api/lib/infrastructure/repositories/organizations/organization-places-lot-repository.js b/api/lib/infrastructure/repositories/organizations/organization-places-lot-repository.js index 198d0ef02e6..a2dc19c616f 100644 --- a/api/lib/infrastructure/repositories/organizations/organization-places-lot-repository.js +++ b/api/lib/infrastructure/repositories/organizations/organization-places-lot-repository.js @@ -1,66 +1,67 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const OrganizationPlacesLotManagement = require('../../../domain/read-models/OrganizationPlacesLotManagement.js'); -const { NotFoundError, DeletedError } = require('../../../domain/errors.js'); -module.exports = { - async findByOrganizationId(organizationId) { - const results = await knex('organization-places') - .select( - 'organization-places.id AS id', - 'count', - 'activationDate', - 'expirationDate', - 'reference', - 'category', - 'users.firstName AS creatorFirstName', - 'users.lastName AS creatorLastName' - ) - .join('users', 'users.id', 'createdBy') - .where({ organizationId }) - .whereNull('deletedAt') - .orderBy('activationDate', 'desc') - .orderBy('expirationDate', 'desc') - .orderBy('organization-places.createdAt', 'desc'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { OrganizationPlacesLotManagement } from '../../../domain/read-models/OrganizationPlacesLotManagement.js'; +import { NotFoundError, DeletedError } from '../../../domain/errors.js'; - return results.map((result) => { - return new OrganizationPlacesLotManagement(result); - }); - }, +const findByOrganizationId = async function (organizationId) { + const results = await knex('organization-places') + .select( + 'organization-places.id AS id', + 'count', + 'activationDate', + 'expirationDate', + 'reference', + 'category', + 'users.firstName AS creatorFirstName', + 'users.lastName AS creatorLastName' + ) + .join('users', 'users.id', 'createdBy') + .where({ organizationId }) + .whereNull('deletedAt') + .orderBy('activationDate', 'desc') + .orderBy('expirationDate', 'desc') + .orderBy('organization-places.createdAt', 'desc'); - async get(id) { - const result = await knex('organization-places') - .select( - 'organization-places.id AS id', - 'count', - 'activationDate', - 'expirationDate', - 'reference', - 'category', - 'users.firstName AS creatorFirstName', - 'users.lastName AS creatorLastName' - ) - .join('users', 'users.id', 'createdBy') - .where({ 'organization-places.id': id }) - .first(); + return results.map((result) => { + return new OrganizationPlacesLotManagement(result); + }); +}; - if (!result) { - throw new NotFoundError(); - } +const get = async function (id) { + const result = await knex('organization-places') + .select( + 'organization-places.id AS id', + 'count', + 'activationDate', + 'expirationDate', + 'reference', + 'category', + 'users.firstName AS creatorFirstName', + 'users.lastName AS creatorLastName' + ) + .join('users', 'users.id', 'createdBy') + .where({ 'organization-places.id': id }) + .first(); - return new OrganizationPlacesLotManagement(result); - }, + if (!result) { + throw new NotFoundError(); + } - async create(places) { - const [{ id }] = await knex('organization-places').insert(places).returning('id'); - return id; - }, + return new OrganizationPlacesLotManagement(result); +}; - async delete({ id, deletedBy }) { - const result = await knex('organization-places') - .update({ deletedAt: new Date(), deletedBy }) - .where({ id, deletedBy: null }); +const create = async function (places) { + const [{ id }] = await knex('organization-places').insert(places).returning('id'); + return id; +}; + +const remove = async function ({ id, deletedBy }) { + const result = await knex('organization-places') + .update({ deletedAt: new Date(), deletedBy }) + .where({ id, deletedBy: null }); - if (!result) { - throw new DeletedError('Organization places lot already deleted'); - } - }, + if (!result) { + throw new DeletedError('Organization places lot already deleted'); + } }; + +export { findByOrganizationId, get, create, remove }; diff --git a/api/lib/infrastructure/repositories/participant-result-repository.js b/api/lib/infrastructure/repositories/participant-result-repository.js index 80940f48e12..78e9f8a7f93 100644 --- a/api/lib/infrastructure/repositories/participant-result-repository.js +++ b/api/lib/infrastructure/repositories/participant-result-repository.js @@ -1,44 +1,42 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const _ = require('lodash'); -const Assessment = require('../../domain/models/Assessment.js'); -const AssessmentResult = require('../../domain/read-models/participant-results/AssessmentResult.js'); -const competenceRepository = require('./competence-repository.js'); -const answerRepository = require('./answer-repository.js'); -const challengeRepository = require('./challenge-repository.js'); -const areaRepository = require('./area-repository.js'); -const knowledgeElementRepository = require('./knowledge-element-repository.js'); -const flashAssessmentResultRepository = require('./flash-assessment-result-repository.js'); -const campaignRepository = require('./campaign-repository.js'); -const stageCollectionRepository = require('./user-campaign-results/stage-collection-repository.js'); -const flash = require('../../domain/services/algorithm-methods/flash.js'); -const dataFetcher = require('../../domain/services/algorithm-methods/data-fetcher.js'); -const { NotFoundError } = require('../../domain/errors.js'); - -const ParticipantResultRepository = { - async getByUserIdAndCampaignId({ userId, campaignId, badges, locale }) { - const participationResults = await _getParticipationResults(userId, campaignId, locale); - let flashScoringResults; - if (participationResults.isFlash) { - flashScoringResults = await _getFlashScoringResults(participationResults.assessmentId, locale); - } - const isCampaignMultipleSendings = await _isCampaignMultipleSendings(campaignId); - const isOrganizationLearnerActive = await _isOrganizationLearnerActive(userId, campaignId); - const isCampaignArchived = await _isCampaignArchived(campaignId); - const competences = await _findTargetedCompetences(campaignId, locale); - const badgeResultsDTO = await _getBadgeResults(badges); - const stageCollection = await _getStageCollection(campaignId); - - return new AssessmentResult({ - participationResults, - competences, - badgeResultsDTO, - stageCollection, - isCampaignMultipleSendings, - isOrganizationLearnerActive, - isCampaignArchived, - flashScoringResults, - }); - }, +import { knex } from '../../../db/knex-database-connection.js'; +import _ from 'lodash'; +import { Assessment } from '../../domain/models/Assessment.js'; +import { AssessmentResult } from '../../domain/read-models/participant-results/AssessmentResult.js'; +import * as competenceRepository from './competence-repository.js'; +import * as answerRepository from './answer-repository.js'; +import * as challengeRepository from './challenge-repository.js'; +import * as areaRepository from './area-repository.js'; +import * as knowledgeElementRepository from './knowledge-element-repository.js'; +import * as flashAssessmentResultRepository from './flash-assessment-result-repository.js'; +import * as campaignRepository from './campaign-repository.js'; +import * as stageCollectionRepository from './user-campaign-results/stage-collection-repository.js'; +import * as flash from '../../domain/services/algorithm-methods/flash.js'; +import * as dataFetcher from '../../domain/services/algorithm-methods/data-fetcher.js'; +import { NotFoundError } from '../../domain/errors.js'; + +const getByUserIdAndCampaignId = async function ({ userId, campaignId, badges, locale }) { + const participationResults = await _getParticipationResults(userId, campaignId, locale); + let flashScoringResults; + if (participationResults.isFlash) { + flashScoringResults = await _getFlashScoringResults(participationResults.assessmentId, locale); + } + const isCampaignMultipleSendings = await _isCampaignMultipleSendings(campaignId); + const isOrganizationLearnerActive = await _isOrganizationLearnerActive(userId, campaignId); + const isCampaignArchived = await _isCampaignArchived(campaignId); + const competences = await _findTargetedCompetences(campaignId, locale); + const badgeResultsDTO = await _getBadgeResults(badges); + const stageCollection = await _getStageCollection(campaignId); + + return new AssessmentResult({ + participationResults, + competences, + badgeResultsDTO, + stageCollection, + isCampaignMultipleSendings, + isOrganizationLearnerActive, + isCampaignArchived, + flashScoringResults, + }); }; async function _getParticipationResults(userId, campaignId) { @@ -235,4 +233,4 @@ async function _isOrganizationLearnerActive(userId, campaignId) { return !organizationLearner?.isDisabled; } -module.exports = ParticipantResultRepository; +export { getByUserIdAndCampaignId }; diff --git a/api/lib/infrastructure/repositories/participant-results-shared-repository.js b/api/lib/infrastructure/repositories/participant-results-shared-repository.js index dac52a64f17..a70315a7aca 100644 --- a/api/lib/infrastructure/repositories/participant-results-shared-repository.js +++ b/api/lib/infrastructure/repositories/participant-results-shared-repository.js @@ -1,8 +1,8 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const ParticipantResultsShared = require('../../../lib/domain/models/ParticipantResultsShared.js'); -const placementProfileService = require('../../domain/services/placement-profile-service.js'); -const competenceRepository = require('./competence-repository.js'); -const campaignRepository = require('./campaign-repository.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { ParticipantResultsShared } from '../../../lib/domain/models/ParticipantResultsShared.js'; +import * as placementProfileService from '../../domain/services/placement-profile-service.js'; +import * as competenceRepository from './competence-repository.js'; +import * as campaignRepository from './campaign-repository.js'; async function _fetchKnowledgeElements(campaignParticipationId) { const { snapshot: knowledgeElements } = await knex('campaign-participations') @@ -55,4 +55,4 @@ const participantResultsSharedRepository = { }, }; -module.exports = participantResultsSharedRepository; +export { participantResultsSharedRepository }; diff --git a/api/lib/infrastructure/repositories/participations-for-campaign-management-repository.js b/api/lib/infrastructure/repositories/participations-for-campaign-management-repository.js index e51ff24b9dd..ff863a8ae88 100644 --- a/api/lib/infrastructure/repositories/participations-for-campaign-management-repository.js +++ b/api/lib/infrastructure/repositories/participations-for-campaign-management-repository.js @@ -1,52 +1,52 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const ParticipationForCampaignManagement = require('../../domain/models/ParticipationForCampaignManagement.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const { NotFoundError } = require('../../domain/errors.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { ParticipationForCampaignManagement } from '../../domain/models/ParticipationForCampaignManagement.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { NotFoundError } from '../../domain/errors.js'; -module.exports = { - async findPaginatedParticipationsForCampaignManagement({ campaignId, page }) { - const query = knex('campaign-participations') - .select({ - id: 'campaign-participations.id', - lastName: 'view-active-organization-learners.lastName', - firstName: 'view-active-organization-learners.firstName', - userId: 'users.id', - userFirstName: 'users.firstName', - userLastName: 'users.lastName', - participantExternalId: 'campaign-participations.participantExternalId', - status: 'campaign-participations.status', - createdAt: 'campaign-participations.createdAt', - sharedAt: 'campaign-participations.sharedAt', - deletedAt: 'campaign-participations.deletedAt', - deletedBy: 'deletedByUsers.id', - deletedByFirstName: 'deletedByUsers.firstName', - deletedByLastName: 'deletedByUsers.lastName', - }) - .join( - 'view-active-organization-learners', - 'view-active-organization-learners.id', - 'campaign-participations.organizationLearnerId' - ) - .leftJoin('users as deletedByUsers', 'deletedByUsers.id', 'campaign-participations.deletedBy') - .innerJoin('users', 'users.id', 'campaign-participations.userId') - .where('campaignId', campaignId) - .orderBy(['lastName', 'firstName'], ['asc', 'asc']); +const findPaginatedParticipationsForCampaignManagement = async function ({ campaignId, page }) { + const query = knex('campaign-participations') + .select({ + id: 'campaign-participations.id', + lastName: 'view-active-organization-learners.lastName', + firstName: 'view-active-organization-learners.firstName', + userId: 'users.id', + userFirstName: 'users.firstName', + userLastName: 'users.lastName', + participantExternalId: 'campaign-participations.participantExternalId', + status: 'campaign-participations.status', + createdAt: 'campaign-participations.createdAt', + sharedAt: 'campaign-participations.sharedAt', + deletedAt: 'campaign-participations.deletedAt', + deletedBy: 'deletedByUsers.id', + deletedByFirstName: 'deletedByUsers.firstName', + deletedByLastName: 'deletedByUsers.lastName', + }) + .join( + 'view-active-organization-learners', + 'view-active-organization-learners.id', + 'campaign-participations.organizationLearnerId' + ) + .leftJoin('users as deletedByUsers', 'deletedByUsers.id', 'campaign-participations.deletedBy') + .innerJoin('users', 'users.id', 'campaign-participations.userId') + .where('campaignId', campaignId) + .orderBy(['lastName', 'firstName'], ['asc', 'asc']); - const { results, pagination } = await fetchPage(query, page); + const { results, pagination } = await fetchPage(query, page); - const participationsForCampaignManagement = results.map( - (attributes) => new ParticipationForCampaignManagement(attributes) - ); - return { models: participationsForCampaignManagement, meta: { ...pagination } }; - }, + const participationsForCampaignManagement = results.map( + (attributes) => new ParticipationForCampaignManagement(attributes) + ); + return { models: participationsForCampaignManagement, meta: { ...pagination } }; +}; - async updateParticipantExternalId({ campaignParticipationId, participantExternalId }) { - const updatedRows = await knex('campaign-participations') - .where('id', campaignParticipationId) - .update({ participantExternalId }); +const updateParticipantExternalId = async function ({ campaignParticipationId, participantExternalId }) { + const updatedRows = await knex('campaign-participations') + .where('id', campaignParticipationId) + .update({ participantExternalId }); - if (!updatedRows) { - throw new NotFoundError(`La participation avec l'id ${campaignParticipationId} n'existe pas.`); - } - }, + if (!updatedRows) { + throw new NotFoundError(`La participation avec l'id ${campaignParticipationId} n'existe pas.`); + } }; + +export { findPaginatedParticipationsForCampaignManagement, updateParticipantExternalId }; diff --git a/api/lib/infrastructure/repositories/participations-for-user-management-repository.js b/api/lib/infrastructure/repositories/participations-for-user-management-repository.js index 85114ce2ff7..5cf72de4910 100644 --- a/api/lib/infrastructure/repositories/participations-for-user-management-repository.js +++ b/api/lib/infrastructure/repositories/participations-for-user-management-repository.js @@ -1,35 +1,35 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignParticipationForUserManagement = require('../../domain/read-models/CampaignParticipationForUserManagement.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { CampaignParticipationForUserManagement } from '../../domain/read-models/CampaignParticipationForUserManagement.js'; -module.exports = { - async findByUserId(userId) { - const campaignParticipations = await knex('campaign-participations') - .select({ - id: 'campaign-participations.id', - participantExternalId: 'campaign-participations.participantExternalId', - status: 'campaign-participations.status', - campaignId: 'campaigns.id', - campaignCode: 'campaigns.code', - createdAt: 'campaign-participations.createdAt', - sharedAt: 'campaign-participations.sharedAt', - deletedAt: 'campaign-participations.deletedAt', - deletedBy: 'deletedByUsers.id', - deletedByFirstName: 'deletedByUsers.firstName', - deletedByLastName: 'deletedByUsers.lastName', - organizationLearnerFirstName: 'view-active-organization-learners.firstName', - organizationLearnerLastName: 'view-active-organization-learners.lastName', - }) - .innerJoin('campaigns', 'campaigns.id', 'campaign-participations.campaignId') - .innerJoin( - 'view-active-organization-learners', - 'view-active-organization-learners.id', - 'campaign-participations.organizationLearnerId' - ) - .leftJoin('users as deletedByUsers', 'deletedByUsers.id', 'campaign-participations.deletedBy') - .where('campaign-participations.userId', userId) - .orderBy('campaignCode', 'asc') - .orderBy('sharedAt', 'desc'); +const findByUserId = async function (userId) { + const campaignParticipations = await knex('campaign-participations') + .select({ + id: 'campaign-participations.id', + participantExternalId: 'campaign-participations.participantExternalId', + status: 'campaign-participations.status', + campaignId: 'campaigns.id', + campaignCode: 'campaigns.code', + createdAt: 'campaign-participations.createdAt', + sharedAt: 'campaign-participations.sharedAt', + deletedAt: 'campaign-participations.deletedAt', + deletedBy: 'deletedByUsers.id', + deletedByFirstName: 'deletedByUsers.firstName', + deletedByLastName: 'deletedByUsers.lastName', + organizationLearnerFirstName: 'view-active-organization-learners.firstName', + organizationLearnerLastName: 'view-active-organization-learners.lastName', + }) + .innerJoin('campaigns', 'campaigns.id', 'campaign-participations.campaignId') + .innerJoin( + 'view-active-organization-learners', + 'view-active-organization-learners.id', + 'campaign-participations.organizationLearnerId' + ) + .leftJoin('users as deletedByUsers', 'deletedByUsers.id', 'campaign-participations.deletedBy') + .where('campaign-participations.userId', userId) + .orderBy('campaignCode', 'asc') + .orderBy('sharedAt', 'desc'); - return campaignParticipations.map((attributes) => new CampaignParticipationForUserManagement(attributes)); - }, + return campaignParticipations.map((attributes) => new CampaignParticipationForUserManagement(attributes)); }; + +export { findByUserId }; diff --git a/api/lib/infrastructure/repositories/partner-certification-scoring-repository.js b/api/lib/infrastructure/repositories/partner-certification-scoring-repository.js index 827f90ec09f..d96fc765fc3 100644 --- a/api/lib/infrastructure/repositories/partner-certification-scoring-repository.js +++ b/api/lib/infrastructure/repositories/partner-certification-scoring-repository.js @@ -1,43 +1,46 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const ComplementaryCertificationCourseResultBookshelf = require('../orm-models/ComplementaryCertificationCourseResult.js'); -const ComplementaryCertificationCourseResult = require('../../domain/models/ComplementaryCertificationCourseResult.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { BookshelfComplementaryCertificationCourseResult } from '../orm-models/ComplementaryCertificationCourseResult.js'; +import { ComplementaryCertificationCourseResult } from '../../domain/models/ComplementaryCertificationCourseResult.js'; -module.exports = { - async save({ partnerCertificationScoring, domainTransaction = DomainTransaction.emptyTransaction() }) { - const partnerCertificationToSave = new ComplementaryCertificationCourseResultBookshelf( - _adaptModelToDB({ - ...partnerCertificationScoring, - source: ComplementaryCertificationCourseResult.sources.PIX, - complementaryCertificationCourseId: partnerCertificationScoring.complementaryCertificationCourseId, - acquired: partnerCertificationScoring.isAcquired(), - }) - ); +const save = async function ({ + partnerCertificationScoring, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const partnerCertificationToSave = new BookshelfComplementaryCertificationCourseResult( + _adaptModelToDB({ + ...partnerCertificationScoring, + source: ComplementaryCertificationCourseResult.sources.PIX, + complementaryCertificationCourseId: partnerCertificationScoring.complementaryCertificationCourseId, + acquired: partnerCertificationScoring.isAcquired(), + }) + ); - const complementaryCertificationCourseResult = await knex - .select('id') - .from('complementary-certification-course-results') - .where({ - complementaryCertificationCourseId: partnerCertificationScoring.complementaryCertificationCourseId, - partnerKey: partnerCertificationScoring.partnerKey, - source: partnerCertificationScoring.source, - }) - .first(); + const complementaryCertificationCourseResult = await knex + .select('id') + .from('complementary-certification-course-results') + .where({ + complementaryCertificationCourseId: partnerCertificationScoring.complementaryCertificationCourseId, + partnerKey: partnerCertificationScoring.partnerKey, + source: partnerCertificationScoring.source, + }) + .first(); - if (complementaryCertificationCourseResult) { - return partnerCertificationToSave - .query(function (qb) { - qb.where({ - id: complementaryCertificationCourseResult.id, - }); - }) - .save(null, { transacting: domainTransaction.knexTransaction, method: 'update' }); - } + if (complementaryCertificationCourseResult) { + return partnerCertificationToSave + .query(function (qb) { + qb.where({ + id: complementaryCertificationCourseResult.id, + }); + }) + .save(null, { transacting: domainTransaction.knexTransaction, method: 'update' }); + } - return partnerCertificationToSave.save(null, { transacting: domainTransaction.knexTransaction, method: 'insert' }); - }, + return partnerCertificationToSave.save(null, { transacting: domainTransaction.knexTransaction, method: 'insert' }); }; +export { save }; + function _adaptModelToDB({ complementaryCertificationCourseId, partnerKey, source, acquired }) { return { complementaryCertificationCourseId, partnerKey, source, acquired }; } diff --git a/api/lib/infrastructure/repositories/pole-emploi-sending-repository.js b/api/lib/infrastructure/repositories/pole-emploi-sending-repository.js index 882465fb15d..7bbd17a4a0c 100644 --- a/api/lib/infrastructure/repositories/pole-emploi-sending-repository.js +++ b/api/lib/infrastructure/repositories/pole-emploi-sending-repository.js @@ -1,43 +1,43 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const settings = require('../../../lib/config.js'); -const OidcIdentityProviders = require('../../domain/constants/oidc-identity-providers.js'); - -module.exports = { - create({ poleEmploiSending }) { - return knex('pole-emploi-sendings').insert({ ...poleEmploiSending }); - }, - - async find(sending, filters) { - const POLE_EMPLOI_SENDINGS_LIMIT = settings.poleEmploi.poleEmploiSendingsLimit; - - const rawSendings = await knex('pole-emploi-sendings') - .select( - 'pole-emploi-sendings.id AS idEnvoi', - 'pole-emploi-sendings.createdAt AS dateEnvoi', - 'pole-emploi-sendings.payload AS resultat', - 'authentication-methods.externalIdentifier AS idPoleEmploi' - ) - .join('campaign-participations', 'campaign-participations.id', 'pole-emploi-sendings.campaignParticipationId') - .join('authentication-methods', 'authentication-methods.userId', 'campaign-participations.userId') - .where('authentication-methods.identityProvider', OidcIdentityProviders.POLE_EMPLOI.service.code) - .modify(_olderThan, sending) - .modify(_filterByStatus, filters) - .orderBy([ - { column: 'pole-emploi-sendings.createdAt', order: 'desc' }, - { column: 'pole-emploi-sendings.id', order: 'desc' }, - ]) - .limit(POLE_EMPLOI_SENDINGS_LIMIT); - - const sendings = rawSendings.map((rawSending) => { - const { idPoleEmploi, ...sending } = rawSending; - sending.resultat.individu['idPoleEmploi'] = idPoleEmploi; - return sending; - }); - - return sendings; - }, +import { knex } from '../../../db/knex-database-connection.js'; +import { config } from '../../../lib/config.js'; +import * as OidcIdentityProviders from '../../domain/constants/oidc-identity-providers.js'; + +const create = function ({ poleEmploiSending }) { + return knex('pole-emploi-sendings').insert({ ...poleEmploiSending }); }; +const find = async function (sending, filters) { + const POLE_EMPLOI_SENDINGS_LIMIT = config.poleEmploi.poleEmploiSendingsLimit; + + const rawSendings = await knex('pole-emploi-sendings') + .select( + 'pole-emploi-sendings.id AS idEnvoi', + 'pole-emploi-sendings.createdAt AS dateEnvoi', + 'pole-emploi-sendings.payload AS resultat', + 'authentication-methods.externalIdentifier AS idPoleEmploi' + ) + .join('campaign-participations', 'campaign-participations.id', 'pole-emploi-sendings.campaignParticipationId') + .join('authentication-methods', 'authentication-methods.userId', 'campaign-participations.userId') + .where('authentication-methods.identityProvider', OidcIdentityProviders.POLE_EMPLOI.service.code) + .modify(_olderThan, sending) + .modify(_filterByStatus, filters) + .orderBy([ + { column: 'pole-emploi-sendings.createdAt', order: 'desc' }, + { column: 'pole-emploi-sendings.id', order: 'desc' }, + ]) + .limit(POLE_EMPLOI_SENDINGS_LIMIT); + + const sendings = rawSendings.map((rawSending) => { + const { idPoleEmploi, ...sending } = rawSending; + sending.resultat.individu['idPoleEmploi'] = idPoleEmploi; + return sending; + }); + + return sendings; +}; + +export { create, find }; + function _olderThan(qb, sending) { if (sending) { qb.where('pole-emploi-sendings.createdAt', '<', sending.dateEnvoi).where( diff --git a/api/lib/infrastructure/repositories/prescriber-repository.js b/api/lib/infrastructure/repositories/prescriber-repository.js index 0ab9050193f..a95cc4ad90b 100644 --- a/api/lib/infrastructure/repositories/prescriber-repository.js +++ b/api/lib/infrastructure/repositories/prescriber-repository.js @@ -1,13 +1,13 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const settings = require('../../config.js'); -const BookshelfUser = require('../orm-models/User.js'); -const BookshelfMembership = require('../orm-models/Membership.js'); -const BookshelfUserOrgaSettings = require('../orm-models/UserOrgaSettings.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const { ForbiddenAccess, UserNotFoundError } = require('../../domain/errors.js'); -const Prescriber = require('../../domain/read-models/Prescriber.js'); -const apps = require('../../domain/constants.js'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { config } from '../../config.js'; +import { BookshelfUser } from '../orm-models/User.js'; +import { BookshelfMembership } from '../orm-models/Membership.js'; +import { BookshelfUserOrgaSettings } from '../orm-models/UserOrgaSettings.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { ForbiddenAccess, UserNotFoundError } from '../../domain/errors.js'; +import { Prescriber } from '../../domain/read-models/Prescriber.js'; +import * as apps from '../../domain/constants.js'; function _toPrescriberDomain(bookshelfUser) { const { id, firstName, lastName, pixOrgaTermsOfServiceAccepted, lang } = bookshelfUser.toJSON(); @@ -35,11 +35,11 @@ async function _areNewYearOrganizationLearnersImportedForPrescriber(prescriber) .join('view-active-organization-learners', 'view-active-organization-learners.organizationId', 'organizations.id') .where((qb) => { qb.where('organizations.id', currentOrganizationId); - if (settings.features.newYearOrganizationLearnersImportDate) { + if (config.features.newYearOrganizationLearnersImportDate) { qb.where( 'view-active-organization-learners.createdAt', '>=', - settings.features.newYearOrganizationLearnersImportDate + config.features.newYearOrganizationLearnersImportDate ); } }) @@ -80,35 +80,35 @@ async function _isMultipleSendingAssessmentEnabled(prescriber) { ); } -module.exports = { - async getPrescriber(userId) { - try { - const prescriberFromDB = await BookshelfUser.where({ id: userId }).fetch({ - columns: ['id', 'firstName', 'lastName', 'pixOrgaTermsOfServiceAccepted', 'lang'], - withRelated: [ - { memberships: (qb) => qb.where({ disabledAt: null }).orderBy('id') }, - 'memberships.organization', - 'userOrgaSettings', - 'userOrgaSettings.currentOrganization', - 'userOrgaSettings.currentOrganization.tags', - ], - }); - const prescriber = _toPrescriberDomain(prescriberFromDB); +const getPrescriber = async function (userId) { + try { + const prescriberFromDB = await BookshelfUser.where({ id: userId }).fetch({ + columns: ['id', 'firstName', 'lastName', 'pixOrgaTermsOfServiceAccepted', 'lang'], + withRelated: [ + { memberships: (qb) => qb.where({ disabledAt: null }).orderBy('id') }, + 'memberships.organization', + 'userOrgaSettings', + 'userOrgaSettings.currentOrganization', + 'userOrgaSettings.currentOrganization.tags', + ], + }); + const prescriber = _toPrescriberDomain(prescriberFromDB); - if (_.isEmpty(prescriber.memberships)) { - throw new ForbiddenAccess(`User of ID ${userId} is not a prescriber`); - } + if (_.isEmpty(prescriber.memberships)) { + throw new ForbiddenAccess(`User of ID ${userId} is not a prescriber`); + } - await _areNewYearOrganizationLearnersImportedForPrescriber(prescriber); - await _getParticipantCount(prescriber); - await _isMultipleSendingAssessmentEnabled(prescriber); + await _areNewYearOrganizationLearnersImportedForPrescriber(prescriber); + await _getParticipantCount(prescriber); + await _isMultipleSendingAssessmentEnabled(prescriber); - return prescriber; - } catch (err) { - if (err instanceof BookshelfUser.NotFoundError) { - throw new UserNotFoundError(`User not found for ID ${userId}`); - } - throw err; + return prescriber; + } catch (err) { + if (err instanceof BookshelfUser.NotFoundError) { + throw new UserNotFoundError(`User not found for ID ${userId}`); } - }, + throw err; + } }; + +export { getPrescriber }; diff --git a/api/lib/infrastructure/repositories/prescriber-role-repository.js b/api/lib/infrastructure/repositories/prescriber-role-repository.js index dce4acd54c1..de31307f389 100644 --- a/api/lib/infrastructure/repositories/prescriber-role-repository.js +++ b/api/lib/infrastructure/repositories/prescriber-role-repository.js @@ -1,20 +1,20 @@ -const { NotFoundError } = require('../../domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const CampaignAuthorization = require('../../application/preHandlers/models/CampaignAuthorization.js'); +import { NotFoundError } from '../../domain/errors.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { prescriberRoles } from '../../application/preHandlers/models/CampaignAuthorization.js'; -module.exports = { - async getForCampaign({ userId, campaignId }) { - const { organizationId, ownerId } = await _getOrganizationIdAndOwnerId({ campaignId }); - const organizationRole = await _getOrganizationRole({ userId, organizationId }); +const getForCampaign = async function ({ userId, campaignId }) { + const { organizationId, ownerId } = await _getOrganizationIdAndOwnerId({ campaignId }); + const organizationRole = await _getOrganizationRole({ userId, organizationId }); - let prescriberRole = organizationRole; - if (userId === ownerId) { - prescriberRole = CampaignAuthorization.prescriberRoles.OWNER; - } - return prescriberRole; - }, + let prescriberRole = organizationRole; + if (userId === ownerId) { + prescriberRole = prescriberRoles.OWNER; + } + return prescriberRole; }; +export { getForCampaign }; + async function _getOrganizationIdAndOwnerId({ campaignId }) { const result = await knex('campaigns').select('organizationId', 'ownerId').where({ id: campaignId }).first(); if (!result) { diff --git a/api/lib/infrastructure/repositories/reset-password-demands-repository.js b/api/lib/infrastructure/repositories/reset-password-demands-repository.js index 1dbba64cfa3..cafc28f4e4e 100644 --- a/api/lib/infrastructure/repositories/reset-password-demands-repository.js +++ b/api/lib/infrastructure/repositories/reset-password-demands-repository.js @@ -1,44 +1,44 @@ -const ResetPasswordDemand = require('../orm-models/ResetPasswordDemand.js'); -const { PasswordResetDemandNotFoundError } = require('../../../lib/domain/errors.js'); +import { ResetPasswordDemand } from '../orm-models/ResetPasswordDemand.js'; +import { PasswordResetDemandNotFoundError } from '../../../lib/domain/errors.js'; -module.exports = { - create(demand) { - return new ResetPasswordDemand(demand).save(); - }, +const create = function (demand) { + return new ResetPasswordDemand(demand).save(); +}; - markAsBeingUsed(email) { - return ResetPasswordDemand.query((qb) => qb.whereRaw('LOWER("email") = ?', email.toLowerCase())).save( - { used: true }, - { - patch: true, - require: false, - } - ); - }, +const markAsBeingUsed = function (email) { + return ResetPasswordDemand.query((qb) => qb.whereRaw('LOWER("email") = ?', email.toLowerCase())).save( + { used: true }, + { + patch: true, + require: false, + } + ); +}; - findByTemporaryKey(temporaryKey) { - return ResetPasswordDemand.where({ temporaryKey, used: false }) - .fetch() - .catch((err) => { - if (err instanceof ResetPasswordDemand.NotFoundError) { - throw new PasswordResetDemandNotFoundError(); - } - throw err; - }); - }, +const findByTemporaryKey = function (temporaryKey) { + return ResetPasswordDemand.where({ temporaryKey, used: false }) + .fetch() + .catch((err) => { + if (err instanceof ResetPasswordDemand.NotFoundError) { + throw new PasswordResetDemandNotFoundError(); + } + throw err; + }); +}; - findByUserEmail(email, temporaryKey) { - return ResetPasswordDemand.query((qb) => { - qb.whereRaw('LOWER("email") = ?', email.toLowerCase()); - qb.where({ used: false }); - qb.where({ temporaryKey }); - }) - .fetch() - .catch((err) => { - if (err instanceof ResetPasswordDemand.NotFoundError) { - throw new PasswordResetDemandNotFoundError(); - } - throw err; - }); - }, +const findByUserEmail = function (email, temporaryKey) { + return ResetPasswordDemand.query((qb) => { + qb.whereRaw('LOWER("email") = ?', email.toLowerCase()); + qb.where({ used: false }); + qb.where({ temporaryKey }); + }) + .fetch() + .catch((err) => { + if (err instanceof ResetPasswordDemand.NotFoundError) { + throw new PasswordResetDemandNotFoundError(); + } + throw err; + }); }; + +export { create, markAsBeingUsed, findByTemporaryKey, findByUserEmail }; diff --git a/api/lib/infrastructure/repositories/sco-certification-candidate-repository.js b/api/lib/infrastructure/repositories/sco-certification-candidate-repository.js index a449bf93a10..a7efc5b71bb 100644 --- a/api/lib/infrastructure/repositories/sco-certification-candidate-repository.js +++ b/api/lib/infrastructure/repositories/sco-certification-candidate-repository.js @@ -1,48 +1,48 @@ -const { knex } = require('../../../db/knex-database-connection.js'); - -module.exports = { - async addNonEnrolledCandidatesToSession({ sessionId, scoCertificationCandidates }) { - const organizationLearnerIds = scoCertificationCandidates.map((candidate) => candidate.organizationLearnerId); - - const alreadyEnrolledCandidate = await knex - .select(['organizationLearnerId']) - .from('certification-candidates') - .whereIn('organizationLearnerId', organizationLearnerIds) - .where({ sessionId }); - - const alreadyEnrolledCandidateOrganizationLearnerIds = alreadyEnrolledCandidate.map( - (candidate) => candidate.organizationLearnerId - ); - - const scoCandidateToDTO = _scoCandidateToDTOForSession(sessionId); - const candidatesToBeEnrolledDTOs = scoCertificationCandidates - .filter((candidate) => !alreadyEnrolledCandidateOrganizationLearnerIds.includes(candidate.organizationLearnerId)) - .map(scoCandidateToDTO); - - await knex.batchInsert('certification-candidates', candidatesToBeEnrolledDTOs); - }, - - async findIdsByOrganizationIdAndDivision({ organizationId, division }) { - const rows = await knex - .select(['certification-candidates.id']) - .from('certification-candidates') - .join( - 'view-active-organization-learners', - 'view-active-organization-learners.id', - 'certification-candidates.organizationLearnerId' - ) - .where({ - 'view-active-organization-learners.organizationId': organizationId, - 'view-active-organization-learners.isDisabled': false, - }) - .whereRaw('LOWER("view-active-organization-learners"."division") = ?', division.toLowerCase()) - .orderBy('certification-candidates.lastName', 'ASC') - .orderBy('certification-candidates.firstName', 'ASC'); - - return rows.map((row) => row.id); - }, +import { knex } from '../../../db/knex-database-connection.js'; + +const addNonEnrolledCandidatesToSession = async function ({ sessionId, scoCertificationCandidates }) { + const organizationLearnerIds = scoCertificationCandidates.map((candidate) => candidate.organizationLearnerId); + + const alreadyEnrolledCandidate = await knex + .select(['organizationLearnerId']) + .from('certification-candidates') + .whereIn('organizationLearnerId', organizationLearnerIds) + .where({ sessionId }); + + const alreadyEnrolledCandidateOrganizationLearnerIds = alreadyEnrolledCandidate.map( + (candidate) => candidate.organizationLearnerId + ); + + const scoCandidateToDTO = _scoCandidateToDTOForSession(sessionId); + const candidatesToBeEnrolledDTOs = scoCertificationCandidates + .filter((candidate) => !alreadyEnrolledCandidateOrganizationLearnerIds.includes(candidate.organizationLearnerId)) + .map(scoCandidateToDTO); + + await knex.batchInsert('certification-candidates', candidatesToBeEnrolledDTOs); +}; + +const findIdsByOrganizationIdAndDivision = async function ({ organizationId, division }) { + const rows = await knex + .select(['certification-candidates.id']) + .from('certification-candidates') + .join( + 'view-active-organization-learners', + 'view-active-organization-learners.id', + 'certification-candidates.organizationLearnerId' + ) + .where({ + 'view-active-organization-learners.organizationId': organizationId, + 'view-active-organization-learners.isDisabled': false, + }) + .whereRaw('LOWER("view-active-organization-learners"."division") = ?', division.toLowerCase()) + .orderBy('certification-candidates.lastName', 'ASC') + .orderBy('certification-candidates.firstName', 'ASC'); + + return rows.map((row) => row.id); }; +export { addNonEnrolledCandidatesToSession, findIdsByOrganizationIdAndDivision }; + function _scoCandidateToDTOForSession(sessionId) { return (scoCandidate) => { return { diff --git a/api/lib/infrastructure/repositories/sco-organization-participant-repository.js b/api/lib/infrastructure/repositories/sco-organization-participant-repository.js index 508e73598dc..6e14e1bdeaf 100644 --- a/api/lib/infrastructure/repositories/sco-organization-participant-repository.js +++ b/api/lib/infrastructure/repositories/sco-organization-participant-repository.js @@ -1,12 +1,11 @@ -const _ = require('lodash'); -const { filterByFullName } = require('../utils/filter-utils.js'); - -const AuthenticationMethod = require('../../domain/models/AuthenticationMethod.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const ScoOrganizationParticipant = require('../../domain/read-models/ScoOrganizationParticipant.js'); -const CampaignTypes = require('../../domain/models/CampaignTypes.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); +import _ from 'lodash'; +import { filterByFullName } from '../utils/filter-utils.js'; +import { AuthenticationMethod } from '../../domain/models/AuthenticationMethod.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { ScoOrganizationParticipant } from '../../domain/read-models/ScoOrganizationParticipant.js'; +import { CampaignTypes } from '../../domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; function _setFilters(qb, { search, divisions, connectionTypes, certificability } = {}) { if (search) { @@ -78,102 +77,102 @@ function _buildIsCertifiable(queryBuilder, organizationId) { .where('campaign-participations.deletedAt', null); } -module.exports = { - async findPaginatedFilteredScoParticipants({ organizationId, filter, page = {}, sort = {} }) { - const { totalScoParticipants } = await knex - .count('id', { as: 'totalScoParticipants' }) - .from('view-active-organization-learners') - .where({ organizationId: organizationId, isDisabled: false }) - .first(); +const findPaginatedFilteredScoParticipants = async function ({ organizationId, filter, page = {}, sort = {} }) { + const { totalScoParticipants } = await knex + .count('id', { as: 'totalScoParticipants' }) + .from('view-active-organization-learners') + .where({ organizationId: organizationId, isDisabled: false }) + .first(); - const orderByClause = [ - 'view-active-organization-learners.lastName', - 'view-active-organization-learners.firstName', - 'view-active-organization-learners.id', - ]; - if (sort?.participationCount) { - orderByClause.unshift({ - column: 'participationCount', - order: sort.participationCount == 'desc' ? 'desc' : 'asc', - }); - } - if (sort?.lastnameSort) { - orderByClause.unshift({ - column: 'view-active-organization-learners.lastName', - order: sort.lastnameSort == 'desc' ? 'desc' : 'asc', - }); - } + const orderByClause = [ + 'view-active-organization-learners.lastName', + 'view-active-organization-learners.firstName', + 'view-active-organization-learners.id', + ]; + if (sort?.participationCount) { + orderByClause.unshift({ + column: 'participationCount', + order: sort.participationCount == 'desc' ? 'desc' : 'asc', + }); + } + if (sort?.lastnameSort) { + orderByClause.unshift({ + column: 'view-active-organization-learners.lastName', + order: sort.lastnameSort == 'desc' ? 'desc' : 'asc', + }); + } - const query = knex - .with('subquery', (qb) => _buildIsCertifiable(qb, organizationId)) - .distinct('view-active-organization-learners.id') - .select([ - 'view-active-organization-learners.id', - 'view-active-organization-learners.firstName', - 'view-active-organization-learners.lastName', - knex.raw('LOWER("view-active-organization-learners"."firstName") AS "lowerFirstName"'), - knex.raw('LOWER("view-active-organization-learners"."lastName") AS "lowerLastName"'), - 'view-active-organization-learners.birthdate', - 'view-active-organization-learners.division', - 'view-active-organization-learners.userId', - 'view-active-organization-learners.organizationId', - 'users.username', - 'users.email', - 'authentication-methods.externalIdentifier as samlId', - 'subquery.isCertifiable', - 'subquery.certifiableAt', - knex.raw( - 'FIRST_VALUE("name") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "campaignName"' - ), - knex.raw( - 'FIRST_VALUE("campaign-participations"."status") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "participationStatus"' - ), - knex.raw( - 'FIRST_VALUE("type") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "campaignType"' - ), - knex.raw( - 'COUNT(*) FILTER (WHERE "campaign-participations"."id" IS NOT NULL) OVER(PARTITION BY "view-active-organization-learners"."id") AS "participationCount"' - ), - knex.raw( - 'max("campaign-participations"."createdAt") OVER(PARTITION BY "view-active-organization-learners"."id") AS "lastParticipationDate"' - ), - ]) - .from('view-active-organization-learners') - .leftJoin('subquery', 'subquery.organizationLearnerId', 'view-active-organization-learners.id') - .leftJoin('campaign-participations', function () { - this.on('campaign-participations.organizationLearnerId', 'view-active-organization-learners.id') - .andOn('campaign-participations.isImproved', '=', knex.raw('false')) - .andOn('campaign-participations.deletedAt', knex.raw('is'), knex.raw('null')); - }) - .leftJoin('users', 'users.id', 'view-active-organization-learners.userId') - .leftJoin('authentication-methods', function () { - this.on('users.id', 'authentication-methods.userId').andOnVal( - 'authentication-methods.identityProvider', - AuthenticationMethod.identityProviders.GAR - ); - }) - .leftJoin('campaigns', function () { - this.on('campaigns.id', 'campaign-participations.campaignId').andOn( - 'campaigns.organizationId', - 'view-active-organization-learners.organizationId' - ); - }) - .where('view-active-organization-learners.isDisabled', false) - .where('view-active-organization-learners.organizationId', organizationId) - .modify(_setFilters, filter) - .orderBy(orderByClause); + const query = knex + .with('subquery', (qb) => _buildIsCertifiable(qb, organizationId)) + .distinct('view-active-organization-learners.id') + .select([ + 'view-active-organization-learners.id', + 'view-active-organization-learners.firstName', + 'view-active-organization-learners.lastName', + knex.raw('LOWER("view-active-organization-learners"."firstName") AS "lowerFirstName"'), + knex.raw('LOWER("view-active-organization-learners"."lastName") AS "lowerLastName"'), + 'view-active-organization-learners.birthdate', + 'view-active-organization-learners.division', + 'view-active-organization-learners.userId', + 'view-active-organization-learners.organizationId', + 'users.username', + 'users.email', + 'authentication-methods.externalIdentifier as samlId', + 'subquery.isCertifiable', + 'subquery.certifiableAt', + knex.raw( + 'FIRST_VALUE("name") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "campaignName"' + ), + knex.raw( + 'FIRST_VALUE("campaign-participations"."status") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "participationStatus"' + ), + knex.raw( + 'FIRST_VALUE("type") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "campaignType"' + ), + knex.raw( + 'COUNT(*) FILTER (WHERE "campaign-participations"."id" IS NOT NULL) OVER(PARTITION BY "view-active-organization-learners"."id") AS "participationCount"' + ), + knex.raw( + 'max("campaign-participations"."createdAt") OVER(PARTITION BY "view-active-organization-learners"."id") AS "lastParticipationDate"' + ), + ]) + .from('view-active-organization-learners') + .leftJoin('subquery', 'subquery.organizationLearnerId', 'view-active-organization-learners.id') + .leftJoin('campaign-participations', function () { + this.on('campaign-participations.organizationLearnerId', 'view-active-organization-learners.id') + .andOn('campaign-participations.isImproved', '=', knex.raw('false')) + .andOn('campaign-participations.deletedAt', knex.raw('is'), knex.raw('null')); + }) + .leftJoin('users', 'users.id', 'view-active-organization-learners.userId') + .leftJoin('authentication-methods', function () { + this.on('users.id', 'authentication-methods.userId').andOnVal( + 'authentication-methods.identityProvider', + AuthenticationMethod.identityProviders.GAR + ); + }) + .leftJoin('campaigns', function () { + this.on('campaigns.id', 'campaign-participations.campaignId').andOn( + 'campaigns.organizationId', + 'view-active-organization-learners.organizationId' + ); + }) + .where('view-active-organization-learners.isDisabled', false) + .where('view-active-organization-learners.organizationId', organizationId) + .modify(_setFilters, filter) + .orderBy(orderByClause); - const { results, pagination } = await fetchPage(query, page); + const { results, pagination } = await fetchPage(query, page); - const scoOrganizationParticipants = results.map((result) => { - return new ScoOrganizationParticipant({ - ...result, - isAuthenticatedFromGAR: !!result.samlId, - }); + const scoOrganizationParticipants = results.map((result) => { + return new ScoOrganizationParticipant({ + ...result, + isAuthenticatedFromGAR: !!result.samlId, }); - return { - data: scoOrganizationParticipants, - meta: { ...pagination, participantCount: totalScoParticipants }, - }; - }, + }); + return { + data: scoOrganizationParticipants, + meta: { ...pagination, participantCount: totalScoParticipants }, + }; }; + +export { findPaginatedFilteredScoParticipants }; diff --git a/api/lib/infrastructure/repositories/sessions/finalized-session-repository.js b/api/lib/infrastructure/repositories/sessions/finalized-session-repository.js index d61f8dfc4a2..2d77ab94e6a 100644 --- a/api/lib/infrastructure/repositories/sessions/finalized-session-repository.js +++ b/api/lib/infrastructure/repositories/sessions/finalized-session-repository.js @@ -1,51 +1,50 @@ -const _ = require('lodash'); -const { NotFoundError } = require('../../../domain/errors.js'); -const { knex } = require('../../bookshelf.js'); - -const FinalizedSessionBookshelf = require('../../orm-models/FinalizedSession.js'); - -const bookshelfToDomainConverter = require('../../utils/bookshelf-to-domain-converter.js'); - -module.exports = { - async save(finalizedSession) { - await knex('finalized-sessions').insert(_toDTO(finalizedSession)).onConflict('sessionId').merge(); - return finalizedSession; - }, - - async get({ sessionId }) { - const bookshelfFinalizedSession = await FinalizedSessionBookshelf.where({ sessionId }).fetch({ require: false }); - - if (bookshelfFinalizedSession) { - return bookshelfToDomainConverter.buildDomainObject(FinalizedSessionBookshelf, bookshelfFinalizedSession); - } - - throw new NotFoundError(`Session of id ${sessionId} does not exist.`); - }, - - async findFinalizedSessionsToPublish() { - const publishableFinalizedSessions = await FinalizedSessionBookshelf.where({ - isPublishable: true, - publishedAt: null, - assignedCertificationOfficerName: null, - }) - .orderBy('finalizedAt') - .fetchAll(); - - return bookshelfToDomainConverter.buildDomainObjects(FinalizedSessionBookshelf, publishableFinalizedSessions); - }, - - async findFinalizedSessionsWithRequiredAction() { - const publishableFinalizedSessions = await FinalizedSessionBookshelf.where({ - isPublishable: false, - publishedAt: null, - }) - .orderBy('finalizedAt') - .fetchAll(); - - return bookshelfToDomainConverter.buildDomainObjects(FinalizedSessionBookshelf, publishableFinalizedSessions); - }, +import _ from 'lodash'; +import { NotFoundError } from '../../../domain/errors.js'; +import { knex } from '../../bookshelf.js'; +import { BookshelfFinalizedSession } from '../../orm-models/FinalizedSession.js'; + +import * as bookshelfToDomainConverter from '../../utils/bookshelf-to-domain-converter.js'; + +const save = async function (finalizedSession) { + await knex('finalized-sessions').insert(_toDTO(finalizedSession)).onConflict('sessionId').merge(); + return finalizedSession; }; +const get = async function ({ sessionId }) { + const bookshelfFinalizedSession = await BookshelfFinalizedSession.where({ sessionId }).fetch({ require: false }); + + if (bookshelfFinalizedSession) { + return bookshelfToDomainConverter.buildDomainObject(BookshelfFinalizedSession, bookshelfFinalizedSession); + } + + throw new NotFoundError(`Session of id ${sessionId} does not exist.`); +}; + +const findFinalizedSessionsToPublish = async function () { + const publishableFinalizedSessions = await BookshelfFinalizedSession.where({ + isPublishable: true, + publishedAt: null, + assignedCertificationOfficerName: null, + }) + .orderBy('finalizedAt') + .fetchAll(); + + return bookshelfToDomainConverter.buildDomainObjects(BookshelfFinalizedSession, publishableFinalizedSessions); +}; + +const findFinalizedSessionsWithRequiredAction = async function () { + const publishableFinalizedSessions = await BookshelfFinalizedSession.where({ + isPublishable: false, + publishedAt: null, + }) + .orderBy('finalizedAt') + .fetchAll(); + + return bookshelfToDomainConverter.buildDomainObjects(BookshelfFinalizedSession, publishableFinalizedSessions); +}; + +export { save, get, findFinalizedSessionsToPublish, findFinalizedSessionsWithRequiredAction }; + function _toDTO(finalizedSession) { return _.omit( { diff --git a/api/lib/infrastructure/repositories/sessions/jury-session-repository.js b/api/lib/infrastructure/repositories/sessions/jury-session-repository.js index b05a3af0ba0..b90976dc501 100644 --- a/api/lib/infrastructure/repositories/sessions/jury-session-repository.js +++ b/api/lib/infrastructure/repositories/sessions/jury-session-repository.js @@ -1,10 +1,9 @@ -const { knex } = require('../../bookshelf.js'); -const { fetchPage } = require('../../utils/knex-utils.js'); -const { NotFoundError } = require('../../../domain/errors.js'); -const JurySession = require('../../../domain/models/JurySession.js'); -const { statuses } = require('../../../domain/models/JurySession.js'); -const CertificationOfficer = require('../../../domain/models/CertificationOfficer.js'); -const { PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR } = require('../../../../db/pgsql-errors.js'); +import { knex } from '../../bookshelf.js'; +import { fetchPage } from '../../utils/knex-utils.js'; +import { NotFoundError } from '../../../domain/errors.js'; +import { JurySession, statuses } from '../../../domain/models/JurySession.js'; +import { CertificationOfficer } from '../../../domain/models/CertificationOfficer.js'; +import { PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR } from '../../../../db/pgsql-errors.js'; const COLUMNS = Object.freeze([ 'sessions.*', @@ -18,58 +17,58 @@ const ALIASED_COLUMNS = Object.freeze({ juryCommentAuthorLastName: 'jury-comment-authors.lastName', }); -module.exports = { - async get(id) { - const jurySessionDTO = await knex - .select(COLUMNS) - .select(ALIASED_COLUMNS) - .from('sessions') - .leftJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') - .leftJoin('users', 'users.id', 'sessions.assignedCertificationOfficerId') - .leftJoin({ 'jury-comment-authors': 'users' }, 'jury-comment-authors.id', 'sessions.juryCommentAuthorId') - .where('sessions.id', '=', id) - .first(); - if (!jurySessionDTO) { - throw new NotFoundError("La session n'existe pas ou son accès est restreint"); - } - return _toDomain(jurySessionDTO); - }, - - async findPaginatedFiltered({ filters, page }) { - const query = knex - .select(COLUMNS) - .select(ALIASED_COLUMNS) - .from('sessions') - .leftJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') - .leftJoin('users', 'users.id', 'sessions.assignedCertificationOfficerId') - .leftJoin({ 'jury-comment-authors': 'users' }, 'jury-comment-authors.id', 'sessions.juryCommentAuthorId') - .modify(_setupFilters, filters) - .orderByRaw('?? ASC NULLS FIRST', 'publishedAt') - .orderByRaw('?? ASC', 'finalizedAt') - .orderBy('id'); - - const { results, pagination } = await fetchPage(query, page); - const jurySessions = results.map(_toDomain); - - return { - jurySessions, - pagination, - }; - }, - - async assignCertificationOfficer({ id, assignedCertificationOfficerId }) { - try { - await knex('sessions').where({ id }).update({ assignedCertificationOfficerId }).returning('*'); - return this.get(id); - } catch (error) { - if (error.code === PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR) { - throw new NotFoundError(`L'utilisateur d'id ${assignedCertificationOfficerId} n'existe pas`); - } - throw new NotFoundError(`La session d'id ${id} n'existe pas.`); +const get = async function (id) { + const jurySessionDTO = await knex + .select(COLUMNS) + .select(ALIASED_COLUMNS) + .from('sessions') + .leftJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') + .leftJoin('users', 'users.id', 'sessions.assignedCertificationOfficerId') + .leftJoin({ 'jury-comment-authors': 'users' }, 'jury-comment-authors.id', 'sessions.juryCommentAuthorId') + .where('sessions.id', '=', id) + .first(); + if (!jurySessionDTO) { + throw new NotFoundError("La session n'existe pas ou son accès est restreint"); + } + return _toDomain(jurySessionDTO); +}; + +const findPaginatedFiltered = async function ({ filters, page }) { + const query = knex + .select(COLUMNS) + .select(ALIASED_COLUMNS) + .from('sessions') + .leftJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') + .leftJoin('users', 'users.id', 'sessions.assignedCertificationOfficerId') + .leftJoin({ 'jury-comment-authors': 'users' }, 'jury-comment-authors.id', 'sessions.juryCommentAuthorId') + .modify(_setupFilters, filters) + .orderByRaw('?? ASC NULLS FIRST', 'publishedAt') + .orderByRaw('?? ASC', 'finalizedAt') + .orderBy('id'); + + const { results, pagination } = await fetchPage(query, page); + const jurySessions = results.map(_toDomain); + + return { + jurySessions, + pagination, + }; +}; + +const assignCertificationOfficer = async function ({ id, assignedCertificationOfficerId }) { + try { + await knex('sessions').where({ id }).update({ assignedCertificationOfficerId }).returning('*'); + return this.get(id); + } catch (error) { + if (error.code === PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR) { + throw new NotFoundError(`L'utilisateur d'id ${assignedCertificationOfficerId} n'existe pas`); } - }, + throw new NotFoundError(`La session d'id ${id} n'existe pas.`); + } }; +export { get, findPaginatedFiltered, assignCertificationOfficer }; + function _toDomain(jurySessionFromDB) { let assignedCertificationOfficer = null; if (jurySessionFromDB.assignedCertificationOfficerId) { diff --git a/api/lib/infrastructure/repositories/sessions/session-for-attendance-sheet-repository.js b/api/lib/infrastructure/repositories/sessions/session-for-attendance-sheet-repository.js index 90a44c4eea2..06effdb22f4 100644 --- a/api/lib/infrastructure/repositories/sessions/session-for-attendance-sheet-repository.js +++ b/api/lib/infrastructure/repositories/sessions/session-for-attendance-sheet-repository.js @@ -1,60 +1,60 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../../domain/errors.js'); -const SessionForAttendanceSheet = require('../../../domain/read-models/SessionForAttendanceSheet.js'); -const CertificationCandidateForAttendanceSheet = require('../../../domain/read-models/CertificationCandidateForAttendanceSheet.js'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../../domain/errors.js'; +import { SessionForAttendanceSheet } from '../../../domain/read-models/SessionForAttendanceSheet.js'; +import { CertificationCandidateForAttendanceSheet } from '../../../domain/read-models/CertificationCandidateForAttendanceSheet.js'; -module.exports = { - async getWithCertificationCandidates(idSession) { - const results = await knex - .select( - 'sessions.id', - 'sessions.date', - 'sessions.time', - 'sessions.address', - 'sessions.room', - 'sessions.examiner', - 'certification-centers.name as certificationCenterName', - 'certification-centers.type as certificationCenterType', - 'organizations.isManagingStudents' - ) - .select({ - certificationCandidates: knex.raw(` - json_agg(json_build_object( - 'firstName', "certification-candidates"."firstName", - 'lastName', "certification-candidates"."lastName", - 'birthdate', "certification-candidates"."birthdate", - 'externalId', "certification-candidates"."externalId", - 'extraTimePercentage', "certification-candidates"."extraTimePercentage", - 'division', "view-active-organization-learners".division) - order by lower("certification-candidates"."lastName"), lower("certification-candidates"."firstName")) - `), - }) - .from('sessions') - .join('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') - .leftJoin('organizations', function () { - this.on('organizations.externalId', 'certification-centers.externalId').andOn( - 'organizations.type', - 'certification-centers.type' - ); - }) - .leftJoin('certification-candidates', 'certification-candidates.sessionId', 'sessions.id') - .leftJoin( - 'view-active-organization-learners', - 'view-active-organization-learners.id', - 'certification-candidates.organizationLearnerId' - ) - .groupBy('sessions.id', 'certification-centers.id', 'organizations.id') - .where({ 'sessions.id': idSession }) - .first(); +const getWithCertificationCandidates = async function (idSession) { + const results = await knex + .select( + 'sessions.id', + 'sessions.date', + 'sessions.time', + 'sessions.address', + 'sessions.room', + 'sessions.examiner', + 'certification-centers.name as certificationCenterName', + 'certification-centers.type as certificationCenterType', + 'organizations.isManagingStudents' + ) + .select({ + certificationCandidates: knex.raw(` + json_agg(json_build_object( + 'firstName', "certification-candidates"."firstName", + 'lastName', "certification-candidates"."lastName", + 'birthdate', "certification-candidates"."birthdate", + 'externalId', "certification-candidates"."externalId", + 'extraTimePercentage', "certification-candidates"."extraTimePercentage", + 'division', "view-active-organization-learners".division) + order by lower("certification-candidates"."lastName"), lower("certification-candidates"."firstName")) + `), + }) + .from('sessions') + .join('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') + .leftJoin('organizations', function () { + this.on('organizations.externalId', 'certification-centers.externalId').andOn( + 'organizations.type', + 'certification-centers.type' + ); + }) + .leftJoin('certification-candidates', 'certification-candidates.sessionId', 'sessions.id') + .leftJoin( + 'view-active-organization-learners', + 'view-active-organization-learners.id', + 'certification-candidates.organizationLearnerId' + ) + .groupBy('sessions.id', 'certification-centers.id', 'organizations.id') + .where({ 'sessions.id': idSession }) + .first(); - if (!results) { - throw new NotFoundError("La session n'existe pas"); - } + if (!results) { + throw new NotFoundError("La session n'existe pas"); + } - return _toDomain(results); - }, + return _toDomain(results); }; +export { getWithCertificationCandidates }; + function _toDomain(results) { const toDomainCertificationCandidates = results.certificationCandidates.map((candidate) => { return new CertificationCandidateForAttendanceSheet({ ...candidate }); diff --git a/api/lib/infrastructure/repositories/sessions/session-for-supervising-repository.js b/api/lib/infrastructure/repositories/sessions/session-for-supervising-repository.js index f8b7ac9b2cc..712c7ff7239 100644 --- a/api/lib/infrastructure/repositories/sessions/session-for-supervising-repository.js +++ b/api/lib/infrastructure/repositories/sessions/session-for-supervising-repository.js @@ -1,67 +1,67 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../../domain/errors.js'); -const CertificationCandidateForSupervising = require('../../../domain/models/CertificationCandidateForSupervising.js'); -const ComplementaryCertificationForSupervising = require('../../../domain/models/ComplementaryCertificationForSupervising.js'); -const SessionForSupervising = require('../../../domain/read-models/SessionForSupervising.js'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../../domain/errors.js'; +import { CertificationCandidateForSupervising } from '../../../domain/models/CertificationCandidateForSupervising.js'; +import { ComplementaryCertificationForSupervising } from '../../../domain/models/ComplementaryCertificationForSupervising.js'; +import { SessionForSupervising } from '../../../domain/read-models/SessionForSupervising.js'; -module.exports = { - async get(idSession) { - const results = await knex - .select({ - id: 'sessions.id', - date: 'sessions.date', - time: 'sessions.time', - room: 'sessions.room', - examiner: 'sessions.examiner', - accessCode: 'sessions.accessCode', - certificationCenterName: 'certification-centers.name', - certificationCandidates: knex.raw(` - json_agg(json_build_object( - 'userId', "certification-candidates"."userId", - 'firstName', "certification-candidates"."firstName", - 'lastName', "certification-candidates"."lastName", - 'birthdate', "certification-candidates"."birthdate", - 'id', "certification-candidates"."id", - 'extraTimePercentage', "certification-candidates"."extraTimePercentage", - 'authorizedToStart', "certification-candidates"."authorizedToStart", - 'assessmentStatus', "assessments"."state", - 'startDateTime', "certification-courses"."createdAt", - 'complementaryCertification', json_build_object( - 'key', "complementary-certifications"."key", - 'label', "complementary-certifications"."label", - 'certificationExtraTime', "complementary-certifications"."certificationExtraTime" - ) - ) order by lower("certification-candidates"."lastName"), lower("certification-candidates"."firstName")) - `), - }) - .from('sessions') - .leftJoin('certification-candidates', 'certification-candidates.sessionId', 'sessions.id') - .leftJoin('certification-courses', function () { - this.on('certification-courses.sessionId', '=', 'sessions.id'); - this.on('certification-courses.userId', '=', 'certification-candidates.userId'); - }) - .leftJoin('assessments', 'assessments.certificationCourseId', 'certification-courses.id') - .innerJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') - .leftJoin( - 'complementary-certification-subscriptions', - 'complementary-certification-subscriptions.certificationCandidateId', - 'certification-candidates.id' - ) - .leftJoin( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-subscriptions.complementaryCertificationId' - ) - .groupBy('sessions.id', 'certification-centers.id') - .where({ 'sessions.id': idSession }) - .first(); - if (!results) { - throw new NotFoundError("La session n'existe pas"); - } - return _toDomain(results); - }, +const get = async function (idSession) { + const results = await knex + .select({ + id: 'sessions.id', + date: 'sessions.date', + time: 'sessions.time', + room: 'sessions.room', + examiner: 'sessions.examiner', + accessCode: 'sessions.accessCode', + certificationCenterName: 'certification-centers.name', + certificationCandidates: knex.raw(` + json_agg(json_build_object( + 'userId', "certification-candidates"."userId", + 'firstName', "certification-candidates"."firstName", + 'lastName', "certification-candidates"."lastName", + 'birthdate', "certification-candidates"."birthdate", + 'id', "certification-candidates"."id", + 'extraTimePercentage', "certification-candidates"."extraTimePercentage", + 'authorizedToStart', "certification-candidates"."authorizedToStart", + 'assessmentStatus', "assessments"."state", + 'startDateTime', "certification-courses"."createdAt", + 'complementaryCertification', json_build_object( + 'key', "complementary-certifications"."key", + 'label', "complementary-certifications"."label", + 'certificationExtraTime', "complementary-certifications"."certificationExtraTime" + ) + ) order by lower("certification-candidates"."lastName"), lower("certification-candidates"."firstName")) + `), + }) + .from('sessions') + .leftJoin('certification-candidates', 'certification-candidates.sessionId', 'sessions.id') + .leftJoin('certification-courses', function () { + this.on('certification-courses.sessionId', '=', 'sessions.id'); + this.on('certification-courses.userId', '=', 'certification-candidates.userId'); + }) + .leftJoin('assessments', 'assessments.certificationCourseId', 'certification-courses.id') + .innerJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') + .leftJoin( + 'complementary-certification-subscriptions', + 'complementary-certification-subscriptions.certificationCandidateId', + 'certification-candidates.id' + ) + .leftJoin( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-subscriptions.complementaryCertificationId' + ) + .groupBy('sessions.id', 'certification-centers.id') + .where({ 'sessions.id': idSession }) + .first(); + if (!results) { + throw new NotFoundError("La session n'existe pas"); + } + return _toDomain(results); }; +export { get }; + function _toDomainComplementaryCertification(complementaryCertification) { if (complementaryCertification?.key) { return new ComplementaryCertificationForSupervising(complementaryCertification); diff --git a/api/lib/infrastructure/repositories/sessions/session-for-supervisor-kit-repository.js b/api/lib/infrastructure/repositories/sessions/session-for-supervisor-kit-repository.js index 6e5b10d9c5a..16c3ca361a7 100644 --- a/api/lib/infrastructure/repositories/sessions/session-for-supervisor-kit-repository.js +++ b/api/lib/infrastructure/repositories/sessions/session-for-supervisor-kit-repository.js @@ -1,27 +1,27 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const SessionForSupervisorKit = require('../../../domain/read-models/SessionForSupervisorKit.js'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { SessionForSupervisorKit } from '../../../domain/read-models/SessionForSupervisorKit.js'; -module.exports = { - async get(idSession) { - const results = await knex - .select( - 'sessions.id', - 'sessions.date', - 'sessions.time', - 'sessions.address', - 'sessions.room', - 'sessions.examiner', - 'sessions.accessCode', - 'sessions.supervisorPassword' - ) - .from('sessions') - .where({ 'sessions.id': idSession }) - .first(); +const get = async function (idSession) { + const results = await knex + .select( + 'sessions.id', + 'sessions.date', + 'sessions.time', + 'sessions.address', + 'sessions.room', + 'sessions.examiner', + 'sessions.accessCode', + 'sessions.supervisorPassword' + ) + .from('sessions') + .where({ 'sessions.id': idSession }) + .first(); - return _toDomain(results); - }, + return _toDomain(results); }; +export { get }; + function _toDomain(results) { return new SessionForSupervisorKit({ ...results, diff --git a/api/lib/infrastructure/repositories/sessions/session-jury-comment-repository.js b/api/lib/infrastructure/repositories/sessions/session-jury-comment-repository.js index 5062c79c0ee..b278bb54a33 100644 --- a/api/lib/infrastructure/repositories/sessions/session-jury-comment-repository.js +++ b/api/lib/infrastructure/repositories/sessions/session-jury-comment-repository.js @@ -1,46 +1,46 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../../domain/errors.js'); -const SessionJuryComment = require('../../../domain/models/SessionJuryComment.js'); - -module.exports = { - async get(sessionId) { - const result = await knex - .select({ - id: 'id', - comment: 'juryComment', - authorId: 'juryCommentAuthorId', - updatedAt: 'juryCommentedAt', - }) - .from('sessions') - .where({ id: sessionId }) - .first(); - - if (!result) { - throw new NotFoundError(`La session ${sessionId} n'existe pas ou son accès est restreint.`); - } - - return new SessionJuryComment(result); - }, - - async save(sessionJuryComment) { - const columnsToSave = { - juryComment: sessionJuryComment.comment, - juryCommentAuthorId: sessionJuryComment.authorId, - juryCommentedAt: sessionJuryComment.updatedAt, - }; - await _persist(sessionJuryComment.id, columnsToSave); - }, - - async delete(sessionJuryCommentId) { - const columnsToSave = { - juryComment: null, - juryCommentAuthorId: null, - juryCommentedAt: null, - }; - await _persist(sessionJuryCommentId, columnsToSave); - }, +import { knex } from '../../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../../domain/errors.js'; +import { SessionJuryComment } from '../../../domain/models/SessionJuryComment.js'; + +const get = async function (sessionId) { + const result = await knex + .select({ + id: 'id', + comment: 'juryComment', + authorId: 'juryCommentAuthorId', + updatedAt: 'juryCommentedAt', + }) + .from('sessions') + .where({ id: sessionId }) + .first(); + + if (!result) { + throw new NotFoundError(`La session ${sessionId} n'existe pas ou son accès est restreint.`); + } + + return new SessionJuryComment(result); }; +const save = async function (sessionJuryComment) { + const columnsToSave = { + juryComment: sessionJuryComment.comment, + juryCommentAuthorId: sessionJuryComment.authorId, + juryCommentedAt: sessionJuryComment.updatedAt, + }; + await _persist(sessionJuryComment.id, columnsToSave); +}; + +const remove = async function (sessionJuryCommentId) { + const columnsToSave = { + juryComment: null, + juryCommentAuthorId: null, + juryCommentedAt: null, + }; + await _persist(sessionJuryCommentId, columnsToSave); +}; + +export { get, save, remove }; + async function _persist(sessionId, columnsToSave) { const updatedSessionIds = await knex('sessions').update(columnsToSave).where({ id: sessionId }).returning('id'); diff --git a/api/lib/infrastructure/repositories/sessions/session-repository.js b/api/lib/infrastructure/repositories/sessions/session-repository.js index bb5b99a8bdc..9554617e995 100644 --- a/api/lib/infrastructure/repositories/sessions/session-repository.js +++ b/api/lib/infrastructure/repositories/sessions/session-repository.js @@ -1,214 +1,227 @@ -const _ = require('lodash'); - -const { knex } = require('../../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../../domain/errors.js'); -const Session = require('../../../domain/models/Session.js'); -const CertificationCenter = require('../../../domain/models/CertificationCenter.js'); -const CertificationCandidate = require('../../../domain/models/CertificationCandidate.js'); -const ComplementaryCertification = require('../../../domain/models/ComplementaryCertification.js'); -const DomainTransaction = require('../../DomainTransaction.js'); - -module.exports = { - async save(sessionData, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const knexConn = knexTransaction ?? knex; - sessionData = _.omit(sessionData, ['certificationCandidates']); - const [savedSession] = await knexConn('sessions').insert(sessionData).returning('*'); - - return new Session(savedSession); - }, - - async saveSessions(sessionsData) { - const sessions = sessionsData.map((session) => { - return _.omit(session, ['certificationCandidates']); - }); - return knex.batchInsert('sessions', sessions); - }, - - async isFinalized(id) { - const session = await knex.select('id').from('sessions').where({ id }).whereNotNull('finalizedAt').first(); - return Boolean(session); - }, - - async get(sessionId) { - const foundSession = await knex.select('*').from('sessions').where({ id: sessionId }).first(); - if (!foundSession) { - throw new NotFoundError("La session n'existe pas ou son accès est restreint"); - } - return new Session({ ...foundSession }); - }, +import _ from 'lodash'; + +import { knex } from '../../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../../domain/errors.js'; +import { Session } from '../../../domain/models/Session.js'; +import { CertificationCenter } from '../../../domain/models/CertificationCenter.js'; +import { CertificationCandidate } from '../../../domain/models/CertificationCandidate.js'; +import { ComplementaryCertification } from '../../../domain/models/ComplementaryCertification.js'; +import { DomainTransaction } from '../../DomainTransaction.js'; + +const save = async function (sessionData, { knexTransaction } = DomainTransaction.emptyTransaction()) { + const knexConn = knexTransaction ?? knex; + sessionData = _.omit(sessionData, ['certificationCandidates']); + const [savedSession] = await knexConn('sessions').insert(sessionData).returning('*'); + + return new Session(savedSession); +}; + +const saveSessions = async function (sessionsData) { + const sessions = sessionsData.map((session) => { + return _.omit(session, ['certificationCandidates']); + }); + return knex.batchInsert('sessions', sessions); +}; + +const isFinalized = async function (id) { + const session = await knex.select('id').from('sessions').where({ id }).whereNotNull('finalizedAt').first(); + return Boolean(session); +}; + +const get = async function (sessionId) { + const foundSession = await knex.select('*').from('sessions').where({ id: sessionId }).first(); + if (!foundSession) { + throw new NotFoundError("La session n'existe pas ou son accès est restreint"); + } + return new Session({ ...foundSession }); +}; + +const isSessionExisting = async function ({ address, room, date, time }) { + const sessions = await knex('sessions').where({ address, room, date, time }); + return sessions.length > 0; +}; + +const isSessionExistingBySessionAndCertificationCenterIds = async function ({ sessionId, certificationCenterId }) { + const [session] = await knex('sessions').where({ id: sessionId, certificationCenterId }); + return Boolean(session); +}; + +const getWithCertificationCandidates = async function (sessionId) { + const session = await knex.from('sessions').where({ 'sessions.id': sessionId }).first(); + + if (!session) { + throw new NotFoundError("La session n'existe pas ou son accès est restreint"); + } + + const certificationCandidates = await knex + .select('certification-candidates.*') + .select({ + complementaryCertifications: knex.raw(` + json_agg(json_build_object('id', "complementary-certifications"."id", 'label', "complementary-certifications"."label", 'key', "complementary-certifications"."key")) + `), + }) + .from('certification-candidates') + .leftJoin( + 'complementary-certification-subscriptions', + 'complementary-certification-subscriptions.certificationCandidateId', + 'certification-candidates.id' + ) + .leftJoin( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-subscriptions.complementaryCertificationId' + ) + .groupBy('certification-candidates.id') + .where({ sessionId }) + .orderByRaw('LOWER(??) ASC, LOWER(??) ASC', ['lastName', 'firstName']); + + return _toDomain({ ...session, certificationCandidates }); +}; + +const updateSessionInfo = async function (session) { + const sessionDataToUpdate = _.pick(session, [ + 'address', + 'room', + 'accessCode', + 'examiner', + 'date', + 'time', + 'description', + ]); + + const [updatedSession] = await knex('sessions').where({ id: session.id }).update(sessionDataToUpdate).returning('*'); + return new Session(updatedSession); +}; + +const doesUserHaveCertificationCenterMembershipForSession = async function (userId, sessionId) { + const sessions = await knex + .select('sessions.id') + .from('sessions') + .where({ + 'sessions.id': sessionId, + 'certification-center-memberships.userId': userId, + 'certification-center-memberships.disabledAt': null, + }) + .innerJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') + .innerJoin( + 'certification-center-memberships', + 'certification-center-memberships.certificationCenterId', + 'certification-centers.id' + ); + return Boolean(sessions.length); +}; + +const finalize = async function ({ id, examinerGlobalComment, hasIncident, hasJoiningIssue, finalizedAt }) { + const [finalizedSession] = await knex('sessions') + .where({ id }) + .update({ examinerGlobalComment, hasIncident, hasJoiningIssue, finalizedAt }) + .returning('*'); + return new Session(finalizedSession); +}; + +const flagResultsAsSentToPrescriber = async function ({ id, resultsSentToPrescriberAt }) { + const [flaggedSession] = await knex('sessions').where({ id }).update({ resultsSentToPrescriberAt }).returning('*'); + return new Session(flaggedSession); +}; - async isSessionExisting({ address, room, date, time }) { - const sessions = await knex('sessions').where({ address, room, date, time }); - return sessions.length > 0; - }, +const updatePublishedAt = async function ({ id, publishedAt }) { + const [publishedSession] = await knex('sessions').where({ id }).update({ publishedAt }).returning('*'); + return new Session(publishedSession); +}; + +const isSco = async function ({ sessionId }) { + const result = await knex + .select('certification-centers.type') + .from('sessions') + .where('sessions.id', '=', sessionId) + .innerJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') + .first(); - async isSessionExistingBySessionAndCertificationCenterIds({ sessionId, certificationCenterId }) { - const [session] = await knex('sessions').where({ id: sessionId, certificationCenterId }); - return Boolean(session); - }, + return result.type === CertificationCenter.types.SCO; +}; - async getWithCertificationCandidates(sessionId) { - const session = await knex.from('sessions').where({ 'sessions.id': sessionId }).first(); +const remove = async function (sessionId) { + await knex.transaction(async (trx) => { + const certificationCandidateIdsInSession = await knex('certification-candidates').where({ sessionId }).pluck('id'); + const supervisorAccessIds = await knex('supervisor-accesses').where({ sessionId }).pluck('id'); + + if (supervisorAccessIds) { + await trx('supervisor-accesses').whereIn('id', supervisorAccessIds).del(); + } - if (!session) { - throw new NotFoundError("La session n'existe pas ou son accès est restreint"); + if (certificationCandidateIdsInSession.length) { + await trx('complementary-certification-subscriptions') + .whereIn('certificationCandidateId', certificationCandidateIdsInSession) + .del(); + await trx('certification-candidates').whereIn('id', certificationCandidateIdsInSession).del(); } + const nbSessionsDeleted = await trx('sessions').where('id', sessionId).del(); + if (nbSessionsDeleted === 0) throw new NotFoundError(); + }); + + return; +}; + +const hasSomeCleaAcquired = async function (sessionId) { + const result = await knex + .select(1) + .from('sessions') + .innerJoin('certification-courses', 'certification-courses.sessionId', 'sessions.id') + .innerJoin( + 'complementary-certification-courses', + 'complementary-certification-courses.certificationCourseId', + 'certification-courses.id' + ) + .innerJoin( + 'complementary-certifications', + 'complementary-certifications.id', + 'complementary-certification-courses.complementaryCertificationId' + ) + .innerJoin( + 'complementary-certification-course-results', + 'complementary-certification-course-results.complementaryCertificationCourseId', + 'complementary-certification-courses.id' + ) + .where('sessions.id', sessionId) + .whereNotNull('sessions.publishedAt') + .where('complementary-certification-course-results.acquired', true) + .where('complementary-certifications.key', ComplementaryCertification.CLEA) + .first(); + return Boolean(result); +}; + +const hasNoStartedCertification = async function (sessionId) { + const result = await knex.select(1).from('certification-courses').where('sessionId', sessionId).first(); + return !result; +}; + +const countUncompletedCertifications = async function (sessionId) { + const { count } = await knex + .count('id') + .from('certification-courses') + .where({ sessionId, completedAt: null }) + .first(); + return count; +}; - const certificationCandidates = await knex - .select('certification-candidates.*') - .select({ - complementaryCertifications: knex.raw(` - json_agg(json_build_object('id', "complementary-certifications"."id", 'label', "complementary-certifications"."label", 'key', "complementary-certifications"."key")) - `), - }) - .from('certification-candidates') - .leftJoin( - 'complementary-certification-subscriptions', - 'complementary-certification-subscriptions.certificationCandidateId', - 'certification-candidates.id' - ) - .leftJoin( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-subscriptions.complementaryCertificationId' - ) - .groupBy('certification-candidates.id') - .where({ sessionId }) - .orderByRaw('LOWER(??) ASC, LOWER(??) ASC', ['lastName', 'firstName']); - - return _toDomain({ ...session, certificationCandidates }); - }, - - async updateSessionInfo(session) { - const sessionDataToUpdate = _.pick(session, [ - 'address', - 'room', - 'accessCode', - 'examiner', - 'date', - 'time', - 'description', - ]); - - const [updatedSession] = await knex('sessions') - .where({ id: session.id }) - .update(sessionDataToUpdate) - .returning('*'); - return new Session(updatedSession); - }, - - async doesUserHaveCertificationCenterMembershipForSession(userId, sessionId) { - const sessions = await knex - .select('sessions.id') - .from('sessions') - .where({ - 'sessions.id': sessionId, - 'certification-center-memberships.userId': userId, - 'certification-center-memberships.disabledAt': null, - }) - .innerJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') - .innerJoin( - 'certification-center-memberships', - 'certification-center-memberships.certificationCenterId', - 'certification-centers.id' - ); - return Boolean(sessions.length); - }, - - async finalize({ id, examinerGlobalComment, hasIncident, hasJoiningIssue, finalizedAt }) { - const [finalizedSession] = await knex('sessions') - .where({ id }) - .update({ examinerGlobalComment, hasIncident, hasJoiningIssue, finalizedAt }) - .returning('*'); - return new Session(finalizedSession); - }, - - async flagResultsAsSentToPrescriber({ id, resultsSentToPrescriberAt }) { - const [flaggedSession] = await knex('sessions').where({ id }).update({ resultsSentToPrescriberAt }).returning('*'); - return new Session(flaggedSession); - }, - - async updatePublishedAt({ id, publishedAt }) { - const [publishedSession] = await knex('sessions').where({ id }).update({ publishedAt }).returning('*'); - return new Session(publishedSession); - }, - - async isSco({ sessionId }) { - const result = await knex - .select('certification-centers.type') - .from('sessions') - .where('sessions.id', '=', sessionId) - .innerJoin('certification-centers', 'certification-centers.id', 'sessions.certificationCenterId') - .first(); - - return result.type === CertificationCenter.types.SCO; - }, - - async delete(sessionId) { - await knex.transaction(async (trx) => { - const certificationCandidateIdsInSession = await knex('certification-candidates') - .where({ sessionId }) - .pluck('id'); - const supervisorAccessIds = await knex('supervisor-accesses').where({ sessionId }).pluck('id'); - - if (supervisorAccessIds) { - await trx('supervisor-accesses').whereIn('id', supervisorAccessIds).del(); - } - - if (certificationCandidateIdsInSession.length) { - await trx('complementary-certification-subscriptions') - .whereIn('certificationCandidateId', certificationCandidateIdsInSession) - .del(); - await trx('certification-candidates').whereIn('id', certificationCandidateIdsInSession).del(); - } - const nbSessionsDeleted = await trx('sessions').where('id', sessionId).del(); - if (nbSessionsDeleted === 0) throw new NotFoundError(); - }); - - return; - }, - - async hasSomeCleaAcquired(sessionId) { - const result = await knex - .select(1) - .from('sessions') - .innerJoin('certification-courses', 'certification-courses.sessionId', 'sessions.id') - .innerJoin( - 'complementary-certification-courses', - 'complementary-certification-courses.certificationCourseId', - 'certification-courses.id' - ) - .innerJoin( - 'complementary-certifications', - 'complementary-certifications.id', - 'complementary-certification-courses.complementaryCertificationId' - ) - .innerJoin( - 'complementary-certification-course-results', - 'complementary-certification-course-results.complementaryCertificationCourseId', - 'complementary-certification-courses.id' - ) - .where('sessions.id', sessionId) - .whereNotNull('sessions.publishedAt') - .where('complementary-certification-course-results.acquired', true) - .where('complementary-certifications.key', ComplementaryCertification.CLEA) - .first(); - return Boolean(result); - }, - - async hasNoStartedCertification(sessionId) { - const result = await knex.select(1).from('certification-courses').where('sessionId', sessionId).first(); - return !result; - }, - - async countUncompletedCertifications(sessionId) { - const { count } = await knex - .count('id') - .from('certification-courses') - .where({ sessionId, completedAt: null }) - .first(); - return count; - }, +export { + save, + saveSessions, + isFinalized, + get, + isSessionExisting, + isSessionExistingBySessionAndCertificationCenterIds, + getWithCertificationCandidates, + updateSessionInfo, + doesUserHaveCertificationCenterMembershipForSession, + finalize, + flagResultsAsSentToPrescriber, + updatePublishedAt, + isSco, + remove, + hasSomeCleaAcquired, + hasNoStartedCertification, + countUncompletedCertifications, }; function _toDomain(results) { diff --git a/api/lib/infrastructure/repositories/sessions/session-summary-repository.js b/api/lib/infrastructure/repositories/sessions/session-summary-repository.js index 1b9fe2025b1..70ee0ad98ee 100644 --- a/api/lib/infrastructure/repositories/sessions/session-summary-repository.js +++ b/api/lib/infrastructure/repositories/sessions/session-summary-repository.js @@ -1,47 +1,47 @@ -const { knex } = require('../../bookshelf.js'); -const { fetchPage } = require('../../utils/knex-utils.js'); -const SessionSummary = require('../../../domain/read-models/SessionSummary.js'); +import { knex } from '../../bookshelf.js'; +import { fetchPage } from '../../utils/knex-utils.js'; +import { SessionSummary } from '../../../domain/read-models/SessionSummary.js'; -module.exports = { - async findPaginatedByCertificationCenterId({ certificationCenterId, page }) { - const query = knex('sessions') - .distinct('sessions.id') - .select({ - id: 'sessions.id', - address: 'sessions.address', - room: 'sessions.room', - date: 'sessions.date', - time: 'sessions.time', - examiner: 'sessions.examiner', - finalizedAt: 'sessions.finalizedAt', - publishedAt: 'sessions.publishedAt', - createdAt: 'sessions.createdAt', - }) - .select( - knex.raw( - 'COUNT(*) FILTER (WHERE "certification-candidates"."id" IS NOT NULL) OVER (partition by "sessions"."id") AS "enrolledCandidatesCount"' - ), - knex.raw( - 'COUNT(*) FILTER (WHERE "certification-courses"."id" IS NOT NULL) OVER (partition by "sessions"."id") AS "effectiveCandidatesCount"' - ) +const findPaginatedByCertificationCenterId = async function ({ certificationCenterId, page }) { + const query = knex('sessions') + .distinct('sessions.id') + .select({ + id: 'sessions.id', + address: 'sessions.address', + room: 'sessions.room', + date: 'sessions.date', + time: 'sessions.time', + examiner: 'sessions.examiner', + finalizedAt: 'sessions.finalizedAt', + publishedAt: 'sessions.publishedAt', + createdAt: 'sessions.createdAt', + }) + .select( + knex.raw( + 'COUNT(*) FILTER (WHERE "certification-candidates"."id" IS NOT NULL) OVER (partition by "sessions"."id") AS "enrolledCandidatesCount"' + ), + knex.raw( + 'COUNT(*) FILTER (WHERE "certification-courses"."id" IS NOT NULL) OVER (partition by "sessions"."id") AS "effectiveCandidatesCount"' ) - .leftJoin('certification-candidates', 'certification-candidates.sessionId', 'sessions.id') - .leftJoin('certification-courses', function () { - this.on('certification-courses.userId', 'certification-candidates.userId').andOn( - 'certification-courses.sessionId', - 'certification-candidates.sessionId' - ); - }) - .where({ certificationCenterId }) - .orderBy('sessions.date', 'DESC') - .orderBy('sessions.time', 'DESC') - .orderBy('sessions.id', 'ASC'); + ) + .leftJoin('certification-candidates', 'certification-candidates.sessionId', 'sessions.id') + .leftJoin('certification-courses', function () { + this.on('certification-courses.userId', 'certification-candidates.userId').andOn( + 'certification-courses.sessionId', + 'certification-candidates.sessionId' + ); + }) + .where({ certificationCenterId }) + .orderBy('sessions.date', 'DESC') + .orderBy('sessions.time', 'DESC') + .orderBy('sessions.id', 'ASC'); - const { results, pagination } = await fetchPage(query, page); - const atLeastOneSession = await knex('sessions').select('id').where({ certificationCenterId }).first(); - const hasSessions = Boolean(atLeastOneSession); + const { results, pagination } = await fetchPage(query, page); + const atLeastOneSession = await knex('sessions').select('id').where({ certificationCenterId }).first(); + const hasSessions = Boolean(atLeastOneSession); - const sessionSummaries = results.map((result) => SessionSummary.from(result)); - return { models: sessionSummaries, meta: { ...pagination, hasSessions } }; - }, + const sessionSummaries = results.map((result) => SessionSummary.from(result)); + return { models: sessionSummaries, meta: { ...pagination, hasSessions } }; }; + +export { findPaginatedByCertificationCenterId }; diff --git a/api/lib/infrastructure/repositories/skill-repository.js b/api/lib/infrastructure/repositories/skill-repository.js index 1f72b92ed2b..215435e6cb8 100644 --- a/api/lib/infrastructure/repositories/skill-repository.js +++ b/api/lib/infrastructure/repositories/skill-repository.js @@ -1,6 +1,6 @@ -const { NotFoundError } = require('../../domain/errors.js'); -const Skill = require('../../domain/models/Skill.js'); -const { skillDatasource } = require('../datasources/learning-content/skill-datasource.js'); +import { NotFoundError } from '../../domain/errors.js'; +import { Skill } from '../../domain/models/Skill.js'; +import { skillDatasource } from '../datasources/learning-content/skill-datasource.js'; function _toDomain(skillData) { return new Skill({ @@ -16,52 +16,62 @@ function _toDomain(skillData) { }); } -module.exports = { - async get(id) { - try { - return _toDomain(await skillDatasource.get(id)); - } catch (e) { - throw new NotFoundError('Erreur, compétence introuvable'); - } - }, +const get = async function (id) { + try { + return _toDomain(await skillDatasource.get(id)); + } catch (e) { + throw new NotFoundError('Erreur, compétence introuvable'); + } +}; - async list() { - const skillDatas = await skillDatasource.list(); - return skillDatas.map(_toDomain); - }, +const list = async function () { + const skillDatas = await skillDatasource.list(); + return skillDatas.map(_toDomain); +}; - async findActiveByTubeId(tubeId) { - const skillDatas = await skillDatasource.findActiveByTubeId(tubeId); - return skillDatas.map(_toDomain); - }, +const findActiveByTubeId = async function (tubeId) { + const skillDatas = await skillDatasource.findActiveByTubeId(tubeId); + return skillDatas.map(_toDomain); +}; + +const findOperativeByTubeId = async function (tubeId) { + const skillDatas = await skillDatasource.findOperativeByTubeId(tubeId); + return skillDatas.map(_toDomain); +}; - async findOperativeByTubeId(tubeId) { - const skillDatas = await skillDatasource.findOperativeByTubeId(tubeId); - return skillDatas.map(_toDomain); - }, +const findActiveByCompetenceId = async function (competenceId) { + const skillDatas = await skillDatasource.findActiveByCompetenceId(competenceId); + return skillDatas.map(_toDomain); +}; - async findActiveByCompetenceId(competenceId) { - const skillDatas = await skillDatasource.findActiveByCompetenceId(competenceId); - return skillDatas.map(_toDomain); - }, +const findOperativeByCompetenceId = async function (competenceId) { + const skillDatas = await skillDatasource.findOperativeByCompetenceId(competenceId); + return skillDatas.map(_toDomain); +}; - async findOperativeByCompetenceId(competenceId) { - const skillDatas = await skillDatasource.findOperativeByCompetenceId(competenceId); - return skillDatas.map(_toDomain); - }, +const findOperativeByCompetenceIds = async function (competenceIds) { + const skillDatas = await skillDatasource.findOperativeByCompetenceIds(competenceIds); + return skillDatas.map(_toDomain); +}; - async findOperativeByCompetenceIds(competenceIds) { - const skillDatas = await skillDatasource.findOperativeByCompetenceIds(competenceIds); - return skillDatas.map(_toDomain); - }, +const findOperativeByIds = async function (skillIds) { + const skillDatas = await skillDatasource.findOperativeByRecordIds(skillIds); + return skillDatas.map(_toDomain); +}; - async findOperativeByIds(skillIds) { - const skillDatas = await skillDatasource.findOperativeByRecordIds(skillIds); - return skillDatas.map(_toDomain); - }, +const findByRecordIds = async function (skillIds) { + const skillDatas = await skillDatasource.findByRecordIds(skillIds); + return skillDatas.map(_toDomain); +}; - async findByRecordIds(skillIds) { - const skillDatas = await skillDatasource.findByRecordIds(skillIds); - return skillDatas.map(_toDomain); - }, +export { + get, + list, + findActiveByTubeId, + findOperativeByTubeId, + findActiveByCompetenceId, + findOperativeByCompetenceId, + findOperativeByCompetenceIds, + findOperativeByIds, + findByRecordIds, }; diff --git a/api/lib/infrastructure/repositories/skill-set-repository.js b/api/lib/infrastructure/repositories/skill-set-repository.js index 97d0c138500..a1b1928d14a 100644 --- a/api/lib/infrastructure/repositories/skill-set-repository.js +++ b/api/lib/infrastructure/repositories/skill-set-repository.js @@ -1,12 +1,12 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); -const SkillSet = require('../../../lib/domain/models/SkillSet.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import { SkillSet } from '../../../lib/domain/models/SkillSet.js'; const TABLE_NAME = 'skill-sets'; -module.exports = { - async save({ skillSet }, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const savedSkillSet = await (knexTransaction ?? knex)(TABLE_NAME).insert(skillSet).returning('*'); - return new SkillSet(savedSkillSet[0]); - }, +const save = async function ({ skillSet }, { knexTransaction } = DomainTransaction.emptyTransaction()) { + const savedSkillSet = await (knexTransaction ?? knex)(TABLE_NAME).insert(skillSet).returning('*'); + return new SkillSet(savedSkillSet[0]); }; + +export { save }; diff --git a/api/lib/infrastructure/repositories/student-repository.js b/api/lib/infrastructure/repositories/student-repository.js index 6cccd41a73a..c62a97985fa 100644 --- a/api/lib/infrastructure/repositories/student-repository.js +++ b/api/lib/infrastructure/repositories/student-repository.js @@ -1,63 +1,63 @@ -const _ = require('lodash'); -const Student = require('../../domain/models/Student.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import _ from 'lodash'; +import { Student } from '../../domain/models/Student.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; -module.exports = { - _toStudents(results) { - const students = []; - const resultsGroupedByNatId = _.groupBy(results, 'nationalStudentId'); - for (const [nationalStudentId, accounts] of Object.entries(resultsGroupedByNatId)) { - const mostRelevantAccount = _.orderBy(accounts, ['certificationCount', 'updatedAt'], ['desc', 'desc'])[0]; - students.push( - new Student({ - nationalStudentId, - account: _.pick(mostRelevantAccount, [ - 'userId', - 'certificationCount', - 'organizationId', - 'birthdate', - 'updatedAt', - ]), - }) - ); - } - return students; - }, - - async findReconciledStudentsByNationalStudentId( - nationalStudentIds, - domainTransaction = DomainTransaction.emptyTransaction() - ) { - const knexConn = domainTransaction.knexTransaction || knex; - const results = await knexConn - .select({ - nationalStudentId: 'view-active-organization-learners.nationalStudentId', - userId: 'users.id', - birthdate: 'view-active-organization-learners.birthdate', - organizationId: 'view-active-organization-learners.organizationId', - updatedAt: 'users.updatedAt', +const _toStudents = function (results) { + const students = []; + const resultsGroupedByNatId = _.groupBy(results, 'nationalStudentId'); + for (const [nationalStudentId, accounts] of Object.entries(resultsGroupedByNatId)) { + const mostRelevantAccount = _.orderBy(accounts, ['certificationCount', 'updatedAt'], ['desc', 'desc'])[0]; + students.push( + new Student({ + nationalStudentId, + account: _.pick(mostRelevantAccount, [ + 'userId', + 'certificationCount', + 'organizationId', + 'birthdate', + 'updatedAt', + ]), }) - .count('certification-courses.id as certificationCount') - .from('view-active-organization-learners') - .join('users', 'users.id', 'view-active-organization-learners.userId') - .leftJoin('certification-courses', 'certification-courses.userId', 'users.id') - .whereIn('nationalStudentId', nationalStudentIds) - .groupBy( - 'view-active-organization-learners.nationalStudentId', - 'users.id', - 'view-active-organization-learners.organizationId', - 'view-active-organization-learners.birthdate', - 'users.updatedAt' - ) - .orderBy('users.id'); + ); + } + return students; +}; - return this._toStudents(results); - }, +const findReconciledStudentsByNationalStudentId = async function ( + nationalStudentIds, + domainTransaction = DomainTransaction.emptyTransaction() +) { + const knexConn = domainTransaction.knexTransaction || knex; + const results = await knexConn + .select({ + nationalStudentId: 'view-active-organization-learners.nationalStudentId', + userId: 'users.id', + birthdate: 'view-active-organization-learners.birthdate', + organizationId: 'view-active-organization-learners.organizationId', + updatedAt: 'users.updatedAt', + }) + .count('certification-courses.id as certificationCount') + .from('view-active-organization-learners') + .join('users', 'users.id', 'view-active-organization-learners.userId') + .leftJoin('certification-courses', 'certification-courses.userId', 'users.id') + .whereIn('nationalStudentId', nationalStudentIds) + .groupBy( + 'view-active-organization-learners.nationalStudentId', + 'users.id', + 'view-active-organization-learners.organizationId', + 'view-active-organization-learners.birthdate', + 'users.updatedAt' + ) + .orderBy('users.id'); - async getReconciledStudentByNationalStudentId(nationalStudentId) { - const [result] = await this.findReconciledStudentsByNationalStudentId([nationalStudentId]); + return this._toStudents(results); +}; - return result ?? null; - }, +const getReconciledStudentByNationalStudentId = async function (nationalStudentId) { + const [result] = await this.findReconciledStudentsByNationalStudentId([nationalStudentId]); + + return result ?? null; }; + +export { _toStudents, findReconciledStudentsByNationalStudentId, getReconciledStudentByNationalStudentId }; diff --git a/api/lib/infrastructure/repositories/sup-organization-learner-repository.js b/api/lib/infrastructure/repositories/sup-organization-learner-repository.js index 5e716bcca77..52da7964b28 100644 --- a/api/lib/infrastructure/repositories/sup-organization-learner-repository.js +++ b/api/lib/infrastructure/repositories/sup-organization-learner-repository.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { OrganizationLearnersCouldNotBeSavedError } = require('../../domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const BookshelfOrganizationLearner = require('../orm-models/OrganizationLearner.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); +import _ from 'lodash'; +import { OrganizationLearnersCouldNotBeSavedError } from '../../domain/errors.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { BookshelfOrganizationLearner } from '../orm-models/OrganizationLearner.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; const ATTRIBUTES_TO_SAVE = [ 'firstName', @@ -21,46 +21,52 @@ const ATTRIBUTES_TO_SAVE = [ 'organizationId', ]; -module.exports = { - async updateStudentNumber(studentId, studentNumber) { - await BookshelfOrganizationLearner.where('id', studentId).save( - { studentNumber }, - { - patch: true, - } - ); - }, +const updateStudentNumber = async function (studentId, studentNumber) { + await BookshelfOrganizationLearner.where('id', studentId).save( + { studentNumber }, + { + patch: true, + } + ); +}; + +const findOneByStudentNumberAndBirthdate = async function ({ organizationId, studentNumber, birthdate }) { + const organizationLearner = await BookshelfOrganizationLearner.query((qb) => { + qb.where('organizationId', organizationId); + qb.where('birthdate', birthdate); + qb.where('isDisabled', false); + qb.whereRaw('LOWER(?)=LOWER(??)', [studentNumber, 'studentNumber']); + }).fetch({ require: false }); - async findOneByStudentNumberAndBirthdate({ organizationId, studentNumber, birthdate }) { - const organizationLearner = await BookshelfOrganizationLearner.query((qb) => { - qb.where('organizationId', organizationId); - qb.where('birthdate', birthdate); - qb.where('isDisabled', false); - qb.whereRaw('LOWER(?)=LOWER(??)', [studentNumber, 'studentNumber']); - }).fetch({ require: false }); + return bookshelfToDomainConverter.buildDomainObject(BookshelfOrganizationLearner, organizationLearner); +}; - return bookshelfToDomainConverter.buildDomainObject(BookshelfOrganizationLearner, organizationLearner); - }, +const findOneByStudentNumber = async function ({ organizationId, studentNumber }) { + const organizationLearner = await BookshelfOrganizationLearner.query((qb) => { + qb.where('organizationId', organizationId); + qb.whereRaw('LOWER(?)=LOWER(??)', [studentNumber, 'studentNumber']); + }).fetch({ require: false }); - async findOneByStudentNumber({ organizationId, studentNumber }) { - const organizationLearner = await BookshelfOrganizationLearner.query((qb) => { - qb.where('organizationId', organizationId); - qb.whereRaw('LOWER(?)=LOWER(??)', [studentNumber, 'studentNumber']); - }).fetch({ require: false }); + return bookshelfToDomainConverter.buildDomainObject(BookshelfOrganizationLearner, organizationLearner); +}; - return bookshelfToDomainConverter.buildDomainObject(BookshelfOrganizationLearner, organizationLearner); - }, +const addStudents = async function (supOrganizationLearners) { + await _upsertStudents(knex, supOrganizationLearners); +}; - async addStudents(supOrganizationLearners) { - await _upsertStudents(knex, supOrganizationLearners); - }, +const replaceStudents = async function (organizationId, supOrganizationLearners) { + await knex.transaction(async (transaction) => { + await _disableAllOrganizationLearners(transaction, organizationId); + await _upsertStudents(transaction, supOrganizationLearners); + }); +}; - async replaceStudents(organizationId, supOrganizationLearners) { - await knex.transaction(async (transaction) => { - await _disableAllOrganizationLearners(transaction, organizationId); - await _upsertStudents(transaction, supOrganizationLearners); - }); - }, +export { + updateStudentNumber, + findOneByStudentNumberAndBirthdate, + findOneByStudentNumber, + addStudents, + replaceStudents, }; async function _disableAllOrganizationLearners(queryBuilder, organizationId) { diff --git a/api/lib/infrastructure/repositories/sup-organization-participant-repository.js b/api/lib/infrastructure/repositories/sup-organization-participant-repository.js index 018823edf9b..f31e1104cd7 100644 --- a/api/lib/infrastructure/repositories/sup-organization-participant-repository.js +++ b/api/lib/infrastructure/repositories/sup-organization-participant-repository.js @@ -1,9 +1,9 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const SupOrganizationParticipant = require('../../domain/read-models/SupOrganizationParticipant.js'); -const CampaignTypes = require('../../domain/models/CampaignTypes.js'); -const CampaignParticipationStatuses = require('../../domain/models/CampaignParticipationStatuses.js'); -const { filterByFullName } = require('../utils/filter-utils.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { SupOrganizationParticipant } from '../../domain/read-models/SupOrganizationParticipant.js'; +import { CampaignTypes } from '../../domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../domain/models/CampaignParticipationStatuses.js'; +import { filterByFullName } from '../utils/filter-utils.js'; function _setFilters(qb, { search, studentNumber, groups, certificability } = {}) { if (search) { @@ -59,89 +59,89 @@ function _buildIsCertifiable(queryBuilder, organizationId) { .where('campaign-participations.deletedAt', null); } -module.exports = { - async findPaginatedFilteredSupParticipants({ organizationId, filter, page = {}, sort = {} }) { - const { totalSupParticipants } = await knex - .count('id', { as: 'totalSupParticipants' }) - .from('view-active-organization-learners') - .where({ organizationId: organizationId, isDisabled: false }) - .first(); +const findPaginatedFilteredSupParticipants = async function ({ organizationId, filter, page = {}, sort = {} }) { + const { totalSupParticipants } = await knex + .count('id', { as: 'totalSupParticipants' }) + .from('view-active-organization-learners') + .where({ organizationId: organizationId, isDisabled: false }) + .first(); - const orderByClause = [ - 'view-active-organization-learners.lastName', - 'view-active-organization-learners.firstName', - 'view-active-organization-learners.id', - ]; - if (sort?.participationCount) { - orderByClause.unshift({ - column: 'participationCount', - order: sort.participationCount == 'desc' ? 'desc' : 'asc', - }); - } - if (sort?.lastnameSort) { - orderByClause.unshift({ - column: 'view-active-organization-learners.lastName', - order: sort.lastnameSort == 'desc' ? 'desc' : 'asc', - }); - } + const orderByClause = [ + 'view-active-organization-learners.lastName', + 'view-active-organization-learners.firstName', + 'view-active-organization-learners.id', + ]; + if (sort?.participationCount) { + orderByClause.unshift({ + column: 'participationCount', + order: sort.participationCount == 'desc' ? 'desc' : 'asc', + }); + } + if (sort?.lastnameSort) { + orderByClause.unshift({ + column: 'view-active-organization-learners.lastName', + order: sort.lastnameSort == 'desc' ? 'desc' : 'asc', + }); + } - const query = knex - .with('subquery', (qb) => _buildIsCertifiable(qb, organizationId)) - .distinct('view-active-organization-learners.id') - .select([ - 'view-active-organization-learners.id', - 'view-active-organization-learners.firstName', - 'view-active-organization-learners.lastName', - knex.raw('LOWER("view-active-organization-learners"."firstName") AS "lowerFirstName"'), - knex.raw('LOWER("view-active-organization-learners"."lastName") AS "lowerLastName"'), - 'view-active-organization-learners.birthdate', - 'view-active-organization-learners.group', - 'view-active-organization-learners.studentNumber', - 'view-active-organization-learners.organizationId', - 'subquery.isCertifiable', - 'subquery.certifiableAt', - knex.raw( - 'FIRST_VALUE("name") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "campaignName"' - ), - knex.raw( - 'FIRST_VALUE("campaign-participations"."status") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "participationStatus"' - ), - knex.raw( - 'FIRST_VALUE("type") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "campaignType"' - ), - knex.raw( - 'COUNT(*) FILTER (WHERE "campaign-participations"."id" IS NOT NULL) OVER(PARTITION BY "view-active-organization-learners"."id") AS "participationCount"' - ), - knex.raw( - 'max("campaign-participations"."createdAt") OVER(PARTITION BY "view-active-organization-learners"."id") AS "lastParticipationDate"' - ), - ]) - .from('view-active-organization-learners') - .leftJoin('subquery', 'subquery.organizationLearnerId', 'view-active-organization-learners.id') - .leftJoin('campaign-participations', function () { - this.on('campaign-participations.organizationLearnerId', 'view-active-organization-learners.id') - .andOn('campaign-participations.isImproved', '=', knex.raw('false')) - .andOn('campaign-participations.deletedAt', knex.raw('is'), knex.raw('null')); - }) - .leftJoin('campaigns', function () { - this.on('campaigns.id', 'campaign-participations.campaignId').andOn( - 'campaigns.organizationId', - 'view-active-organization-learners.organizationId' - ); - }) - .where('view-active-organization-learners.isDisabled', false) - .where('view-active-organization-learners.organizationId', organizationId) - .modify(_setFilters, filter) - .orderBy(orderByClause); + const query = knex + .with('subquery', (qb) => _buildIsCertifiable(qb, organizationId)) + .distinct('view-active-organization-learners.id') + .select([ + 'view-active-organization-learners.id', + 'view-active-organization-learners.firstName', + 'view-active-organization-learners.lastName', + knex.raw('LOWER("view-active-organization-learners"."firstName") AS "lowerFirstName"'), + knex.raw('LOWER("view-active-organization-learners"."lastName") AS "lowerLastName"'), + 'view-active-organization-learners.birthdate', + 'view-active-organization-learners.group', + 'view-active-organization-learners.studentNumber', + 'view-active-organization-learners.organizationId', + 'subquery.isCertifiable', + 'subquery.certifiableAt', + knex.raw( + 'FIRST_VALUE("name") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "campaignName"' + ), + knex.raw( + 'FIRST_VALUE("campaign-participations"."status") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "participationStatus"' + ), + knex.raw( + 'FIRST_VALUE("type") OVER(PARTITION BY "view-active-organization-learners"."id" ORDER BY "campaign-participations"."createdAt" DESC) AS "campaignType"' + ), + knex.raw( + 'COUNT(*) FILTER (WHERE "campaign-participations"."id" IS NOT NULL) OVER(PARTITION BY "view-active-organization-learners"."id") AS "participationCount"' + ), + knex.raw( + 'max("campaign-participations"."createdAt") OVER(PARTITION BY "view-active-organization-learners"."id") AS "lastParticipationDate"' + ), + ]) + .from('view-active-organization-learners') + .leftJoin('subquery', 'subquery.organizationLearnerId', 'view-active-organization-learners.id') + .leftJoin('campaign-participations', function () { + this.on('campaign-participations.organizationLearnerId', 'view-active-organization-learners.id') + .andOn('campaign-participations.isImproved', '=', knex.raw('false')) + .andOn('campaign-participations.deletedAt', knex.raw('is'), knex.raw('null')); + }) + .leftJoin('campaigns', function () { + this.on('campaigns.id', 'campaign-participations.campaignId').andOn( + 'campaigns.organizationId', + 'view-active-organization-learners.organizationId' + ); + }) + .where('view-active-organization-learners.isDisabled', false) + .where('view-active-organization-learners.organizationId', organizationId) + .modify(_setFilters, filter) + .orderBy(orderByClause); - const { results, pagination } = await fetchPage(query, page); + const { results, pagination } = await fetchPage(query, page); - const supOrganizationParticipants = results.map((result) => { - return new SupOrganizationParticipant({ ...result }); - }); - return { - data: supOrganizationParticipants, - meta: { ...pagination, participantCount: totalSupParticipants }, - }; - }, + const supOrganizationParticipants = results.map((result) => { + return new SupOrganizationParticipant({ ...result }); + }); + return { + data: supOrganizationParticipants, + meta: { ...pagination, participantCount: totalSupParticipants }, + }; }; + +export { findPaginatedFilteredSupParticipants }; diff --git a/api/lib/infrastructure/repositories/supervisor-access-repository.js b/api/lib/infrastructure/repositories/supervisor-access-repository.js index abc93069749..d8e0e32a77b 100644 --- a/api/lib/infrastructure/repositories/supervisor-access-repository.js +++ b/api/lib/infrastructure/repositories/supervisor-access-repository.js @@ -1,27 +1,27 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async create({ sessionId, userId }) { - await knex('supervisor-accesses').insert({ sessionId, userId }); - }, +const create = async function ({ sessionId, userId }) { + await knex('supervisor-accesses').insert({ sessionId, userId }); +}; - async isUserSupervisorForSession({ sessionId, userId }) { - const result = await knex.select(1).from('supervisor-accesses').where({ sessionId, userId }).first(); - return Boolean(result); - }, +const isUserSupervisorForSession = async function ({ sessionId, userId }) { + const result = await knex.select(1).from('supervisor-accesses').where({ sessionId, userId }).first(); + return Boolean(result); +}; - async sessionHasSupervisorAccess({ sessionId }) { - const result = await knex.select(1).from('supervisor-accesses').where({ sessionId }).first(); - return Boolean(result); - }, +const sessionHasSupervisorAccess = async function ({ sessionId }) { + const result = await knex.select(1).from('supervisor-accesses').where({ sessionId }).first(); + return Boolean(result); +}; - async isUserSupervisorForSessionCandidate({ supervisorId, certificationCandidateId }) { - const result = await knex - .select(1) - .from('supervisor-accesses') - .innerJoin('certification-candidates', 'supervisor-accesses.sessionId', 'certification-candidates.sessionId') - .where({ 'certification-candidates.id': certificationCandidateId, 'supervisor-accesses.userId': supervisorId }) - .first(); - return Boolean(result); - }, +const isUserSupervisorForSessionCandidate = async function ({ supervisorId, certificationCandidateId }) { + const result = await knex + .select(1) + .from('supervisor-accesses') + .innerJoin('certification-candidates', 'supervisor-accesses.sessionId', 'certification-candidates.sessionId') + .where({ 'certification-candidates.id': certificationCandidateId, 'supervisor-accesses.userId': supervisorId }) + .first(); + return Boolean(result); }; + +export { create, isUserSupervisorForSession, sessionHasSupervisorAccess, isUserSupervisorForSessionCandidate }; diff --git a/api/lib/infrastructure/repositories/tag-repository.js b/api/lib/infrastructure/repositories/tag-repository.js index 98941870b8f..842ed839a6c 100644 --- a/api/lib/infrastructure/repositories/tag-repository.js +++ b/api/lib/infrastructure/repositories/tag-repository.js @@ -1,40 +1,44 @@ -const knexUtils = require('../utils/knex-utils.js'); -const { AlreadyExistingEntityError, NotFoundError } = require('../../domain/errors.js'); -const omit = require('lodash/omit'); -const { knex } = require('../../../db/knex-database-connection.js'); -const Tag = require('../../domain/models/Tag.js'); -module.exports = { - async create(tag) { - try { - const tagToCreate = omit(tag, 'id'); - const [row] = await knex('tags').insert(tagToCreate).returning('*'); - return new Tag(row); - } catch (error) { - if (knexUtils.isUniqConstraintViolated(error)) { - throw new AlreadyExistingEntityError(`A tag with name ${tag.name} already exists.`); - } - throw error; - } - }, +import * as knexUtils from '../utils/knex-utils.js'; +import { AlreadyExistingEntityError, NotFoundError } from '../../domain/errors.js'; +import lodash from 'lodash'; - async findByName({ name }) { - const row = await knex('tags').where({ name }).first(); - if (!row) { - return null; - } - return new Tag(row); - }, +const { omit } = lodash; - async findAll() { - const rows = await knex('tags'); - return rows.map((row) => new Tag(row)); - }, +import { knex } from '../../../db/knex-database-connection.js'; +import { Tag } from '../../domain/models/Tag.js'; - async get(id) { - const row = await knex('tags').where({ id }).first(); - if (!row) { - throw new NotFoundError("Le tag n'existe pas"); - } +const create = async function (tag) { + try { + const tagToCreate = omit(tag, 'id'); + const [row] = await knex('tags').insert(tagToCreate).returning('*'); return new Tag(row); - }, + } catch (error) { + if (knexUtils.isUniqConstraintViolated(error)) { + throw new AlreadyExistingEntityError(`A tag with name ${tag.name} already exists.`); + } + throw error; + } +}; + +const findByName = async function ({ name }) { + const row = await knex('tags').where({ name }).first(); + if (!row) { + return null; + } + return new Tag(row); +}; + +const findAll = async function () { + const rows = await knex('tags'); + return rows.map((row) => new Tag(row)); }; + +const get = async function (id) { + const row = await knex('tags').where({ id }).first(); + if (!row) { + throw new NotFoundError("Le tag n'existe pas"); + } + return new Tag(row); +}; + +export { create, findByName, findAll, get }; diff --git a/api/lib/infrastructure/repositories/target-profile-for-admin-repository.js b/api/lib/infrastructure/repositories/target-profile-for-admin-repository.js index 22255b80812..5c4e0ff299d 100644 --- a/api/lib/infrastructure/repositories/target-profile-for-admin-repository.js +++ b/api/lib/infrastructure/repositories/target-profile-for-admin-repository.js @@ -1,45 +1,48 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const { FRENCH_FRANCE } = require('../../domain/constants.js').LOCALE; -const areaRepository = require('./area-repository.js'); -const competenceRepository = require('./competence-repository.js'); -const thematicRepository = require('./thematic-repository.js'); -const tubeRepository = require('./tube-repository.js'); -const TargetProfileForAdmin = require('../../domain/models/TargetProfileForAdmin.js'); -const StageCollection = require('../../domain/models/target-profile-management/StageCollection'); -const { BadgeDetails, BadgeCriterion, CappedTube, SCOPES } = require('../../domain/models/BadgeDetails.js'); - -module.exports = { - async get({ id, locale = FRENCH_FRANCE }) { - const targetProfileDTO = await knex('target-profiles') - .select( - 'target-profiles.id', - 'target-profiles.name', - 'target-profiles.outdated', - 'target-profiles.isPublic', - 'target-profiles.imageUrl', - 'target-profiles.createdAt', - 'target-profiles.description', - 'target-profiles.comment', - 'target-profiles.ownerOrganizationId', - 'target-profiles.category', - 'target-profiles.isSimplifiedAccess' - ) - .where('id', id) - .first(); - - if (targetProfileDTO == null) { - throw new NotFoundError("Le profil cible n'existe pas"); - } +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { LOCALE } from '../../domain/constants.js'; + +const { FRENCH_FRANCE } = LOCALE; + +import * as areaRepository from './area-repository.js'; +import * as competenceRepository from './competence-repository.js'; +import * as thematicRepository from './thematic-repository.js'; +import * as tubeRepository from './tube-repository.js'; +import { TargetProfileForAdmin } from '../../domain/models/TargetProfileForAdmin.js'; +import { StageCollection } from '../../domain/models/target-profile-management/StageCollection.js'; +import { BadgeDetails, BadgeCriterion, CappedTube, SCOPES } from '../../domain/models/BadgeDetails.js'; + +const get = async function ({ id, locale = FRENCH_FRANCE }) { + const targetProfileDTO = await knex('target-profiles') + .select( + 'target-profiles.id', + 'target-profiles.name', + 'target-profiles.outdated', + 'target-profiles.isPublic', + 'target-profiles.imageUrl', + 'target-profiles.createdAt', + 'target-profiles.description', + 'target-profiles.comment', + 'target-profiles.ownerOrganizationId', + 'target-profiles.category', + 'target-profiles.isSimplifiedAccess' + ) + .where('id', id) + .first(); + + if (targetProfileDTO == null) { + throw new NotFoundError("Le profil cible n'existe pas"); + } - const tubesData = await knex('target-profile_tubes') - .select('tubeId', 'level') - .where('targetProfileId', targetProfileDTO.id); - return _toDomain(targetProfileDTO, tubesData, locale); - }, + const tubesData = await knex('target-profile_tubes') + .select('tubeId', 'level') + .where('targetProfileId', targetProfileDTO.id); + return _toDomain(targetProfileDTO, tubesData, locale); }; +export { get }; + async function _toDomain(targetProfileDTO, tubesData, locale) { const { areas, competences, thematics, tubes } = await _getLearningContent(targetProfileDTO.id, tubesData, locale); const badges = await _findBadges(targetProfileDTO.id); diff --git a/api/lib/infrastructure/repositories/target-profile-for-update-repository.js b/api/lib/infrastructure/repositories/target-profile-for-update-repository.js index 30be580b0dc..eb2475e3500 100644 --- a/api/lib/infrastructure/repositories/target-profile-for-update-repository.js +++ b/api/lib/infrastructure/repositories/target-profile-for-update-repository.js @@ -1,14 +1,14 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; -module.exports = { - async update({ targetProfileId, name, imageUrl, description, comment, category }) { - const targetProfileToUpdate = { - name, - imageUrl, - description, - comment, - category, - }; - return knex('target-profiles').where({ id: targetProfileId }).update(targetProfileToUpdate); - }, +const update = async function ({ targetProfileId, name, imageUrl, description, comment, category }) { + const targetProfileToUpdate = { + name, + imageUrl, + description, + comment, + category, + }; + return knex('target-profiles').where({ id: targetProfileId }).update(targetProfileToUpdate); }; + +export { update }; diff --git a/api/lib/infrastructure/repositories/target-profile-management/stage-collection-repository.js b/api/lib/infrastructure/repositories/target-profile-management/stage-collection-repository.js index be771c64972..1ef63d68e11 100644 --- a/api/lib/infrastructure/repositories/target-profile-management/stage-collection-repository.js +++ b/api/lib/infrastructure/repositories/target-profile-management/stage-collection-repository.js @@ -1,46 +1,46 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const StageCollection = require('../../../domain/models/target-profile-management/StageCollection.js'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { StageCollection } from '../../../domain/models/target-profile-management/StageCollection.js'; -module.exports = { - async getByTargetProfileId(targetProfileId) { - const stages = await knex('stages').where({ targetProfileId }).orderBy('id', 'asc'); - const { max: maxLevel } = await knex('target-profile_tubes') - .max('level') - .where('targetProfileId', targetProfileId) - .first(); +const getByTargetProfileId = async function (targetProfileId) { + const stages = await knex('stages').where({ targetProfileId }).orderBy('id', 'asc'); + const { max: maxLevel } = await knex('target-profile_tubes') + .max('level') + .where('targetProfileId', targetProfileId) + .first(); - return new StageCollection({ id: targetProfileId, stages, maxLevel }); - }, + return new StageCollection({ id: targetProfileId, stages, maxLevel }); +}; - async update(stageCollectionUpdate) { - const stageIdsToDelete = stageCollectionUpdate.stageIdsToDelete; - const stagesToUpdate = stageCollectionUpdate.stagesToUpdate.map((stage) => ({ - id: stage.id, - level: stage.level, - threshold: stage.threshold, - isFirstSkill: stage.isFirstSkill, - title: stage.title, - message: stage.message, - prescriberTitle: stage.prescriberTitle, - prescriberDescription: stage.prescriberDescription, - targetProfileId: stage.targetProfileId, - })); - const stagesToCreate = stageCollectionUpdate.stagesToCreate.map((stage) => ({ - level: stage.level, - threshold: stage.threshold, - isFirstSkill: stage.isFirstSkill, - title: stage.title, - message: stage.message, - prescriberTitle: stage.prescriberTitle, - prescriberDescription: stage.prescriberDescription, - targetProfileId: stage.targetProfileId, - })); - await knex.transaction(async (trx) => { - await trx('stages').whereIn('id', stageIdsToDelete).del(); - await trx('stages') - .insert([...stagesToCreate, ...stagesToUpdate]) - .onConflict('id') - .merge(); - }); - }, +const update = async function (stageCollectionUpdate) { + const stageIdsToDelete = stageCollectionUpdate.stageIdsToDelete; + const stagesToUpdate = stageCollectionUpdate.stagesToUpdate.map((stage) => ({ + id: stage.id, + level: stage.level, + threshold: stage.threshold, + isFirstSkill: stage.isFirstSkill, + title: stage.title, + message: stage.message, + prescriberTitle: stage.prescriberTitle, + prescriberDescription: stage.prescriberDescription, + targetProfileId: stage.targetProfileId, + })); + const stagesToCreate = stageCollectionUpdate.stagesToCreate.map((stage) => ({ + level: stage.level, + threshold: stage.threshold, + isFirstSkill: stage.isFirstSkill, + title: stage.title, + message: stage.message, + prescriberTitle: stage.prescriberTitle, + prescriberDescription: stage.prescriberDescription, + targetProfileId: stage.targetProfileId, + })); + await knex.transaction(async (trx) => { + await trx('stages').whereIn('id', stageIdsToDelete).del(); + await trx('stages') + .insert([...stagesToCreate, ...stagesToUpdate]) + .onConflict('id') + .merge(); + }); }; + +export { getByTargetProfileId, update }; diff --git a/api/lib/infrastructure/repositories/target-profile-repository.js b/api/lib/infrastructure/repositories/target-profile-repository.js index 30c11a3352b..fdb5d1ed142 100644 --- a/api/lib/infrastructure/repositories/target-profile-repository.js +++ b/api/lib/infrastructure/repositories/target-profile-repository.js @@ -1,148 +1,144 @@ -const _ = require('lodash'); -const BookshelfTargetProfile = require('../orm-models/TargetProfile.js'); -const targetProfileAdapter = require('../adapters/target-profile-adapter.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError, ObjectValidationError, InvalidSkillSetError } = require('../../domain/errors.js'); -const DomainTransaction = require('../../infrastructure/DomainTransaction.js'); -const TargetProfile = require('../../domain/models/TargetProfile.js'); +import _ from 'lodash'; +import { BookshelfTargetProfile } from '../orm-models/TargetProfile.js'; +import * as targetProfileAdapter from '../adapters/target-profile-adapter.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError, ObjectValidationError, InvalidSkillSetError } from '../../domain/errors.js'; +import { DomainTransaction } from '../../infrastructure/DomainTransaction.js'; +import { TargetProfile } from '../../domain/models/TargetProfile.js'; const TARGET_PROFILE_TABLE = 'target-profiles'; -module.exports = { - async create({ targetProfileForCreation, domainTransaction }) { - const knexConn = domainTransaction.knexTransaction; - const targetProfileRawData = _.pick(targetProfileForCreation, [ - 'name', - 'category', - 'description', - 'comment', - 'isPublic', - 'imageUrl', - 'ownerOrganizationId', - ]); - const [{ id: targetProfileId }] = await knexConn(TARGET_PROFILE_TABLE).insert(targetProfileRawData).returning('id'); - - const tubesData = targetProfileForCreation.tubes.map((tube) => ({ - targetProfileId, - tubeId: tube.id, - level: tube.level, - })); - await knexConn.batchInsert('target-profile_tubes', tubesData); - - return targetProfileId; - }, - - async get(id, domainTransaction = DomainTransaction.emptyTransaction()) { - const bookshelfTargetProfile = await BookshelfTargetProfile.where({ id }).fetch({ - require: false, - transacting: domainTransaction.knexTransaction, - }); +const create = async function ({ targetProfileForCreation, domainTransaction }) { + const knexConn = domainTransaction.knexTransaction; + const targetProfileRawData = _.pick(targetProfileForCreation, [ + 'name', + 'category', + 'description', + 'comment', + 'isPublic', + 'imageUrl', + 'ownerOrganizationId', + ]); + const [{ id: targetProfileId }] = await knexConn(TARGET_PROFILE_TABLE).insert(targetProfileRawData).returning('id'); + + const tubesData = targetProfileForCreation.tubes.map((tube) => ({ + targetProfileId, + tubeId: tube.id, + level: tube.level, + })); + await knexConn.batchInsert('target-profile_tubes', tubesData); + + return targetProfileId; +}; - if (!bookshelfTargetProfile) { - throw new NotFoundError(`Le profil cible avec l'id ${id} n'existe pas`); - } +const get = async function (id, domainTransaction = DomainTransaction.emptyTransaction()) { + const bookshelfTargetProfile = await BookshelfTargetProfile.where({ id }).fetch({ + require: false, + transacting: domainTransaction.knexTransaction, + }); - return targetProfileAdapter.fromDatasourceObjects({ - bookshelfTargetProfile, - }); - }, - - async getByCampaignId(campaignId) { - const bookshelfTargetProfile = await BookshelfTargetProfile.query((qb) => { - qb.innerJoin('campaigns', 'campaigns.targetProfileId', 'target-profiles.id'); - }) - .where({ 'campaigns.id': campaignId }) - .fetch({ - withRelated: ['badges'], - }); - return targetProfileAdapter.fromDatasourceObjects({ - bookshelfTargetProfile, + if (!bookshelfTargetProfile) { + throw new NotFoundError(`Le profil cible avec l'id ${id} n'existe pas`); + } + + return targetProfileAdapter.fromDatasourceObjects({ + bookshelfTargetProfile, + }); +}; + +const getByCampaignId = async function (campaignId) { + const bookshelfTargetProfile = await BookshelfTargetProfile.query((qb) => { + qb.innerJoin('campaigns', 'campaigns.targetProfileId', 'target-profiles.id'); + }) + .where({ 'campaigns.id': campaignId }) + .fetch({ + withRelated: ['badges'], }); - }, - - async findByIds(targetProfileIds) { - const targetProfilesBookshelf = await BookshelfTargetProfile.query((qb) => { - qb.whereIn('id', targetProfileIds); - }).fetchAll(); - - return bookshelfToDomainConverter.buildDomainObjects(BookshelfTargetProfile, targetProfilesBookshelf); - }, - - async update(targetProfile) { - let results; - const editedAttributes = _.pick(targetProfile, [ - 'name', - 'outdated', - 'description', - 'comment', - 'isSimplifiedAccess', - ]); - - try { - results = await knex(TARGET_PROFILE_TABLE) - .where({ id: targetProfile.id }) - .update(editedAttributes) - .returning(['id', 'isSimplifiedAccess']); - } catch (error) { - throw new ObjectValidationError(); - } + return targetProfileAdapter.fromDatasourceObjects({ + bookshelfTargetProfile, + }); +}; - if (!results.length) { - throw new NotFoundError(`Le profil cible avec l'id ${targetProfile.id} n'existe pas`); - } +const findByIds = async function (targetProfileIds) { + const targetProfilesBookshelf = await BookshelfTargetProfile.query((qb) => { + qb.whereIn('id', targetProfileIds); + }).fetchAll(); - return new TargetProfile(results[0]); - }, + return bookshelfToDomainConverter.buildDomainObjects(BookshelfTargetProfile, targetProfilesBookshelf); +}; - async findOrganizationIds(targetProfileId) { - const targetProfile = await knex(TARGET_PROFILE_TABLE).select('id').where({ id: targetProfileId }).first(); - if (!targetProfile) { - throw new NotFoundError(`No target profile for ID ${targetProfileId}`); - } +const update = async function (targetProfile) { + let results; + const editedAttributes = _.pick(targetProfile, ['name', 'outdated', 'description', 'comment', 'isSimplifiedAccess']); - const targetProfileShares = await knex('target-profile-shares') - .select('organizationId') - .where({ 'target-profile-shares.targetProfileId': targetProfileId }); - return targetProfileShares.map((targetProfileShare) => targetProfileShare.organizationId); - }, - - // TODO remove me with badge skill set - async hasSkills({ targetProfileId, skillIds }, { knexTransaction } = DomainTransaction.emptyTransaction()) { - const result = await (knexTransaction ?? knex)('target-profiles_skills') - .select('skillId') - .whereIn('skillId', skillIds) - .andWhere('targetProfileId', targetProfileId); - - const unknownSkillIds = _.difference(skillIds, _.map(result, 'skillId')); - if (unknownSkillIds.length) { - throw new InvalidSkillSetError(`Les acquis suivants ne font pas partie du profil cible : ${unknownSkillIds}`); + try { + results = await knex(TARGET_PROFILE_TABLE) + .where({ id: targetProfile.id }) + .update(editedAttributes) + .returning(['id', 'isSimplifiedAccess']); + } catch (error) { + throw new ObjectValidationError(); + } + + if (!results.length) { + throw new NotFoundError(`Le profil cible avec l'id ${targetProfile.id} n'existe pas`); + } + + return new TargetProfile(results[0]); +}; + +const findOrganizationIds = async function (targetProfileId) { + const targetProfile = await knex(TARGET_PROFILE_TABLE).select('id').where({ id: targetProfileId }).first(); + if (!targetProfile) { + throw new NotFoundError(`No target profile for ID ${targetProfileId}`); + } + + const targetProfileShares = await knex('target-profile-shares') + .select('organizationId') + .where({ 'target-profile-shares.targetProfileId': targetProfileId }); + return targetProfileShares.map((targetProfileShare) => targetProfileShare.organizationId); +}; + +const hasSkills = async function ( + { targetProfileId, skillIds }, + { knexTransaction } = DomainTransaction.emptyTransaction() +) { + const result = await (knexTransaction ?? knex)('target-profiles_skills') + .select('skillId') + .whereIn('skillId', skillIds) + .andWhere('targetProfileId', targetProfileId); + + const unknownSkillIds = _.difference(skillIds, _.map(result, 'skillId')); + if (unknownSkillIds.length) { + throw new InvalidSkillSetError(`Les acquis suivants ne font pas partie du profil cible : ${unknownSkillIds}`); + } + + return true; +}; + +const hasTubesWithLevels = async function ( + { targetProfileId, tubesWithLevels }, + { knexTransaction } = DomainTransaction.emptyTransaction() +) { + const tubeIds = tubesWithLevels.map(({ id }) => id); + + const result = await (knexTransaction ?? knex)('target-profile_tubes') + .whereIn('tubeId', tubeIds) + .andWhere('targetProfileId', targetProfileId); + + for (const tubeWithLevel of tubesWithLevels) { + const targetProfileTube = result.find(({ tubeId }) => tubeId === tubeWithLevel.id); + if (!targetProfileTube) { + throw new ObjectValidationError(`Le sujet ${tubeWithLevel.id} ne fait pas partie du profil cible`); } - return true; - }, - - async hasTubesWithLevels( - { targetProfileId, tubesWithLevels }, - { knexTransaction } = DomainTransaction.emptyTransaction() - ) { - const tubeIds = tubesWithLevels.map(({ id }) => id); - - const result = await (knexTransaction ?? knex)('target-profile_tubes') - .whereIn('tubeId', tubeIds) - .andWhere('targetProfileId', targetProfileId); - - for (const tubeWithLevel of tubesWithLevels) { - const targetProfileTube = result.find(({ tubeId }) => tubeId === tubeWithLevel.id); - if (!targetProfileTube) { - throw new ObjectValidationError(`Le sujet ${tubeWithLevel.id} ne fait pas partie du profil cible`); - } - - if (tubeWithLevel.level > targetProfileTube.level) { - throw new ObjectValidationError( - `Le niveau ${tubeWithLevel.level} dépasse le niveau max du sujet ${tubeWithLevel.id}` - ); - } + if (tubeWithLevel.level > targetProfileTube.level) { + throw new ObjectValidationError( + `Le niveau ${tubeWithLevel.level} dépasse le niveau max du sujet ${tubeWithLevel.id}` + ); } - }, + } }; + +export { create, get, getByCampaignId, findByIds, update, findOrganizationIds, hasSkills, hasTubesWithLevels }; diff --git a/api/lib/infrastructure/repositories/target-profile-share-repository.js b/api/lib/infrastructure/repositories/target-profile-share-repository.js index b63e85a7f8c..4f35e1c4266 100644 --- a/api/lib/infrastructure/repositories/target-profile-share-repository.js +++ b/api/lib/infrastructure/repositories/target-profile-share-repository.js @@ -1,23 +1,23 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; -module.exports = { - async addTargetProfilesToOrganization({ organizationId, targetProfileIdList }) { - const targetProfileShareToAdd = targetProfileIdList.map((targetProfileId) => { - return { organizationId, targetProfileId }; - }); - await knex('target-profile-shares') - .insert(targetProfileShareToAdd) - .onConflict(['targetProfileId', 'organizationId']) - .ignore(); - }, +const addTargetProfilesToOrganization = async function ({ organizationId, targetProfileIdList }) { + const targetProfileShareToAdd = targetProfileIdList.map((targetProfileId) => { + return { organizationId, targetProfileId }; + }); + await knex('target-profile-shares') + .insert(targetProfileShareToAdd) + .onConflict(['targetProfileId', 'organizationId']) + .ignore(); +}; - async batchAddTargetProfilesToOrganization( - organizationTargetProfiles, - domainTransaction = DomainTransaction.emptyTransaction() - ) { - await knex - .batchInsert('target-profile-shares', organizationTargetProfiles) - .transacting(domainTransaction.knexTransaction); - }, +const batchAddTargetProfilesToOrganization = async function ( + organizationTargetProfiles, + domainTransaction = DomainTransaction.emptyTransaction() +) { + await knex + .batchInsert('target-profile-shares', organizationTargetProfiles) + .transacting(domainTransaction.knexTransaction); }; + +export { addTargetProfilesToOrganization, batchAddTargetProfilesToOrganization }; diff --git a/api/lib/infrastructure/repositories/target-profile-summary-for-admin-repository.js b/api/lib/infrastructure/repositories/target-profile-summary-for-admin-repository.js index 783c893169f..426ffd5b87d 100644 --- a/api/lib/infrastructure/repositories/target-profile-summary-for-admin-repository.js +++ b/api/lib/infrastructure/repositories/target-profile-summary-for-admin-repository.js @@ -1,61 +1,61 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const TargetProfileSummaryForAdmin = require('../../domain/models/TargetProfileSummaryForAdmin.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import { TargetProfileSummaryForAdmin } from '../../domain/models/TargetProfileSummaryForAdmin.js'; +import { DomainTransaction } from '../DomainTransaction.js'; -module.exports = { - async findPaginatedFiltered({ filter, page }) { - const query = knex('target-profiles') - .select('id', 'name', 'outdated', 'createdAt') - .orderBy('outdated', 'ASC') - .orderBy('name', 'ASC') - .modify(_applyFilters, filter); +const findPaginatedFiltered = async function ({ filter, page }) { + const query = knex('target-profiles') + .select('id', 'name', 'outdated', 'createdAt') + .orderBy('outdated', 'ASC') + .orderBy('name', 'ASC') + .modify(_applyFilters, filter); - const { results, pagination } = await fetchPage(query, page); + const { results, pagination } = await fetchPage(query, page); - const targetProfileSummaries = results.map((attributes) => new TargetProfileSummaryForAdmin(attributes)); - return { models: targetProfileSummaries, meta: { ...pagination } }; - }, + const targetProfileSummaries = results.map((attributes) => new TargetProfileSummaryForAdmin(attributes)); + return { models: targetProfileSummaries, meta: { ...pagination } }; +}; - async findByOrganization({ organizationId }) { - const results = await knex('target-profiles') - .select({ - id: 'target-profiles.id', - name: 'target-profiles.name', - outdated: 'target-profiles.outdated', - }) - .leftJoin('target-profile-shares', function () { - this.on('target-profile-shares.targetProfileId', 'target-profiles.id').on( - 'target-profile-shares.organizationId', - organizationId - ); - }) - .where({ outdated: false }) - .where((qb) => { - qb.orWhere({ isPublic: true }); - qb.orWhere({ ownerOrganizationId: organizationId }); - qb.orWhere((subQb) => { - subQb.whereNotNull('target-profile-shares.id'); - }); - }) - .orderBy('id', 'ASC'); +const findByOrganization = async function ({ organizationId }) { + const results = await knex('target-profiles') + .select({ + id: 'target-profiles.id', + name: 'target-profiles.name', + outdated: 'target-profiles.outdated', + }) + .leftJoin('target-profile-shares', function () { + this.on('target-profile-shares.targetProfileId', 'target-profiles.id').on( + 'target-profile-shares.organizationId', + organizationId + ); + }) + .where({ outdated: false }) + .where((qb) => { + qb.orWhere({ isPublic: true }); + qb.orWhere({ ownerOrganizationId: organizationId }); + qb.orWhere((subQb) => { + subQb.whereNotNull('target-profile-shares.id'); + }); + }) + .orderBy('id', 'ASC'); - return results.map((attributes) => new TargetProfileSummaryForAdmin(attributes)); - }, + return results.map((attributes) => new TargetProfileSummaryForAdmin(attributes)); +}; - async findByTraining({ trainingId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction?.knexTransaction || knex; +const findByTraining = async function ({ trainingId, domainTransaction = DomainTransaction.emptyTransaction() }) { + const knexConn = domainTransaction?.knexTransaction || knex; - const results = await knexConn('target-profiles') - .select({ id: 'target-profiles.id', name: 'target-profiles.name', outdated: 'target-profiles.outdated' }) - .innerJoin('target-profile-trainings', 'target-profiles.id', 'target-profile-trainings.targetProfileId') - .where({ trainingId }) - .orderBy('id', 'ASC'); + const results = await knexConn('target-profiles') + .select({ id: 'target-profiles.id', name: 'target-profiles.name', outdated: 'target-profiles.outdated' }) + .innerJoin('target-profile-trainings', 'target-profiles.id', 'target-profile-trainings.targetProfileId') + .where({ trainingId }) + .orderBy('id', 'ASC'); - return results.map((attributes) => new TargetProfileSummaryForAdmin(attributes)); - }, + return results.map((attributes) => new TargetProfileSummaryForAdmin(attributes)); }; +export { findPaginatedFiltered, findByOrganization, findByTraining }; + function _applyFilters(qb, filter) { const { name, id } = filter; if (name) { diff --git a/api/lib/infrastructure/repositories/target-profile-training-repository.js b/api/lib/infrastructure/repositories/target-profile-training-repository.js index 4cae49ca03b..7d2bf958724 100644 --- a/api/lib/infrastructure/repositories/target-profile-training-repository.js +++ b/api/lib/infrastructure/repositories/target-profile-training-repository.js @@ -1,19 +1,23 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; const TABLE_NAME = 'target-profile-trainings'; -module.exports = { - async create({ trainingId, targetProfileIds, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction?.knexTransaction || knex; - const targetProfileTrainingsToInsert = targetProfileIds.map((targetProfileId) => { - return { trainingId, targetProfileId }; - }); - const attachedTargetProfileIds = await knexConn(TABLE_NAME) - .insert(targetProfileTrainingsToInsert) - .onConflict(['targetProfileId', 'trainingId']) - .merge({ updatedAt: new Date() }) - .returning('targetProfileId') - .orderBy('targetProfileId', 'asc'); - return attachedTargetProfileIds.map(({ targetProfileId }) => targetProfileId); - }, +const create = async function ({ + trainingId, + targetProfileIds, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction?.knexTransaction || knex; + const targetProfileTrainingsToInsert = targetProfileIds.map((targetProfileId) => { + return { trainingId, targetProfileId }; + }); + const attachedTargetProfileIds = await knexConn(TABLE_NAME) + .insert(targetProfileTrainingsToInsert) + .onConflict(['targetProfileId', 'trainingId']) + .merge({ updatedAt: new Date() }) + .returning('targetProfileId') + .orderBy('targetProfileId', 'asc'); + return attachedTargetProfileIds.map(({ targetProfileId }) => targetProfileId); }; + +export { create }; diff --git a/api/lib/infrastructure/repositories/thematic-repository.js b/api/lib/infrastructure/repositories/thematic-repository.js index abfdb18ee83..ea59a6b5e5f 100644 --- a/api/lib/infrastructure/repositories/thematic-repository.js +++ b/api/lib/infrastructure/repositories/thematic-repository.js @@ -1,8 +1,10 @@ -const _ = require('lodash'); -const Thematic = require('../../domain/models/Thematic.js'); -const { thematicDatasource } = require('../datasources/learning-content/thematic-datasource.js'); -const { getTranslatedKey } = require('../../domain/services/get-translated-text.js'); -const { FRENCH_FRANCE } = require('../../domain/constants.js').LOCALE; +import _ from 'lodash'; +import { Thematic } from '../../domain/models/Thematic.js'; +import { thematicDatasource } from '../datasources/learning-content/thematic-datasource.js'; +import { getTranslatedKey } from '../../domain/services/get-translated-text.js'; +import { LOCALE } from '../../domain/constants.js'; + +const { FRENCH_FRANCE } = LOCALE; function _toDomain(thematicData, locale) { const translatedName = getTranslatedKey(thematicData.name_i18n, locale); @@ -15,20 +17,20 @@ function _toDomain(thematicData, locale) { }); } -module.exports = { - async list({ locale } = { locale: FRENCH_FRANCE }) { - const thematicDatas = await thematicDatasource.list(); - return thematicDatas.map((thematicData) => _toDomain(thematicData, locale)); - }, +const list = async function ({ locale } = { locale: FRENCH_FRANCE }) { + const thematicDatas = await thematicDatasource.list(); + return thematicDatas.map((thematicData) => _toDomain(thematicData, locale)); +}; - async findByCompetenceIds(competenceIds, locale) { - const thematicDatas = await thematicDatasource.findByCompetenceIds(competenceIds); - return thematicDatas.map((thematicData) => _toDomain(thematicData, locale)); - }, +const findByCompetenceIds = async function (competenceIds, locale) { + const thematicDatas = await thematicDatasource.findByCompetenceIds(competenceIds); + return thematicDatas.map((thematicData) => _toDomain(thematicData, locale)); +}; - async findByRecordIds(thematicIds, locale) { - const thematicDatas = await thematicDatasource.findByRecordIds(thematicIds); - const thematics = thematicDatas.map((thematicData) => _toDomain(thematicData, locale)); - return _.orderBy(thematics, (thematic) => thematic.name.toLowerCase()); - }, +const findByRecordIds = async function (thematicIds, locale) { + const thematicDatas = await thematicDatasource.findByRecordIds(thematicIds); + const thematics = thematicDatas.map((thematicData) => _toDomain(thematicData, locale)); + return _.orderBy(thematics, (thematic) => thematic.name.toLowerCase()); }; + +export { list, findByCompetenceIds, findByRecordIds }; diff --git a/api/lib/infrastructure/repositories/training-repository.js b/api/lib/infrastructure/repositories/training-repository.js index 43c5a8cd1c9..ea28b8d11ac 100644 --- a/api/lib/infrastructure/repositories/training-repository.js +++ b/api/lib/infrastructure/repositories/training-repository.js @@ -1,13 +1,16 @@ -const Training = require('../../domain/models/Training.js'); -const TrainingSummary = require('../../domain/read-models/TrainingSummary.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const UserRecommendedTraining = require('../../domain/read-models/UserRecommendedTraining.js'); -const { fetchPage } = require('../utils/knex-utils.js'); -const pick = require('lodash/pick'); -const trainingTriggerRepository = require('./training-trigger-repository.js'); -const TrainingForAdmin = require('../../domain/read-models/TrainingForAdmin'); +import { Training } from '../../domain/models/Training.js'; +import { TrainingSummary } from '../../domain/read-models/TrainingSummary.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { UserRecommendedTraining } from '../../domain/read-models/UserRecommendedTraining.js'; +import { fetchPage } from '../utils/knex-utils.js'; +import lodash from 'lodash'; + +const { pick } = lodash; + +import * as trainingTriggerRepository from './training-trigger-repository.js'; +import { TrainingForAdmin } from '../../domain/read-models/TrainingForAdmin.js'; const TABLE_NAME = 'trainings'; async function get({ trainingId, domainTransaction = DomainTransaction.emptyTransaction() }) { @@ -167,7 +170,7 @@ async function findPaginatedByUserId({ return { userRecommendedTrainings, pagination }; } -module.exports = { +export { get, getWithTriggersForAdmin, findPaginatedSummaries, diff --git a/api/lib/infrastructure/repositories/training-trigger-repository.js b/api/lib/infrastructure/repositories/training-trigger-repository.js index c9c14b8648a..cbc1a1b8013 100644 --- a/api/lib/infrastructure/repositories/training-trigger-repository.js +++ b/api/lib/infrastructure/repositories/training-trigger-repository.js @@ -1,97 +1,100 @@ -const _ = require('lodash'); -const { knex } = require('../../../db/knex-database-connection.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const TrainingTriggerForAdmin = require('../../domain/read-models/TrainingTriggerForAdmin.js'); -const TrainingTriggerTube = require('../../domain/models/TrainingTriggerTube.js'); -const areaRepository = require('./area-repository'); -const competenceRepository = require('./competence-repository'); -const thematicRepository = require('./thematic-repository'); -const tubeRepository = require('./tube-repository'); -const TrainingTrigger = require('../../domain/models/TrainingTrigger'); -const logger = require('../logger'); +import _ from 'lodash'; +import { knex } from '../../../db/knex-database-connection.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { TrainingTriggerForAdmin } from '../../domain/read-models/TrainingTriggerForAdmin.js'; +import { TrainingTriggerTube } from '../../domain/models/TrainingTriggerTube.js'; +import * as areaRepository from './area-repository.js'; +import * as competenceRepository from './competence-repository.js'; +import * as thematicRepository from './thematic-repository.js'; +import * as tubeRepository from './tube-repository.js'; +import { TrainingTrigger } from '../../domain/models/TrainingTrigger.js'; +import { logger } from '../logger.js'; const TABLE_NAME = 'training-triggers'; -module.exports = { - async createOrUpdate({ - trainingId, - triggerTubesForCreation, - type, - threshold, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knexConn = domainTransaction?.knexTransaction || (await knex.transaction()); - - const [trainingTrigger] = await knexConn(TABLE_NAME) - .insert({ trainingId, type, threshold, updatedAt: new Date() }) - .onConflict(['trainingId', 'type']) - .merge(['threshold', 'updatedAt']) - .returning('*'); - - await knexConn('training-trigger-tubes').where({ trainingTriggerId: trainingTrigger.id }).delete(); - - const trainingTriggerTubesToCreate = triggerTubesForCreation.map(({ tubeId, level }) => { - return { - trainingTriggerId: trainingTrigger.id, - tubeId, - level, - }; - }); +const createOrUpdate = async function ({ + trainingId, + triggerTubesForCreation, + type, + threshold, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction?.knexTransaction || (await knex.transaction()); + + const [trainingTrigger] = await knexConn(TABLE_NAME) + .insert({ trainingId, type, threshold, updatedAt: new Date() }) + .onConflict(['trainingId', 'type']) + .merge(['threshold', 'updatedAt']) + .returning('*'); + + await knexConn('training-trigger-tubes').where({ trainingTriggerId: trainingTrigger.id }).delete(); + + const trainingTriggerTubesToCreate = triggerTubesForCreation.map(({ tubeId, level }) => { + return { + trainingTriggerId: trainingTrigger.id, + tubeId, + level, + }; + }); - const createdTrainingTriggerTubes = await knexConn('training-trigger-tubes') - .insert(trainingTriggerTubesToCreate) - .returning('*'); - - if (!domainTransaction?.knexTransaction) { - await knexConn.commit(); - } - - return _toDomainForAdmin({ trainingTrigger, triggerTubes: createdTrainingTriggerTubes }); - }, - - async findByTrainingIdForAdmin({ trainingId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction?.knexTransaction || knex; - const trainingTriggers = await knexConn(TABLE_NAME).select('*').where({ trainingId }).orderBy('id', 'asc'); - if (!trainingTriggers) { - return []; - } - const trainingTriggerIds = trainingTriggers.map(({ id }) => id); - const trainingTriggerTubes = await knexConn('training-trigger-tubes') - .whereIn('trainingTriggerId', trainingTriggerIds) - .select('*'); - - return Promise.all( - trainingTriggers.map(async (trainingTrigger) => { - const triggerTubes = trainingTriggerTubes.filter( - ({ trainingTriggerId }) => trainingTriggerId === trainingTrigger.id - ); - return await _toDomainForAdmin({ trainingTrigger, triggerTubes }); - }) - ); - }, - - async findByTrainingId({ trainingId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction?.knexTransaction || knex; - const trainingTriggers = await knexConn(TABLE_NAME).select('*').where({ trainingId }).orderBy('id', 'asc'); - if (!trainingTriggers) { - return []; - } - const trainingTriggerIds = trainingTriggers.map(({ id }) => id); - const trainingTriggerTubes = await knexConn('training-trigger-tubes') - .whereIn('trainingTriggerId', trainingTriggerIds) - .select('*'); - - return Promise.all( - trainingTriggers.map(async (trainingTrigger) => { - const triggerTubes = trainingTriggerTubes.filter( - ({ trainingTriggerId }) => trainingTriggerId === trainingTrigger.id - ); - return _toDomain({ trainingTrigger, triggerTubes }); - }) - ); - }, + const createdTrainingTriggerTubes = await knexConn('training-trigger-tubes') + .insert(trainingTriggerTubesToCreate) + .returning('*'); + + if (!domainTransaction?.knexTransaction) { + await knexConn.commit(); + } + + return _toDomainForAdmin({ trainingTrigger, triggerTubes: createdTrainingTriggerTubes }); }; +const findByTrainingIdForAdmin = async function ({ + trainingId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction?.knexTransaction || knex; + const trainingTriggers = await knexConn(TABLE_NAME).select('*').where({ trainingId }).orderBy('id', 'asc'); + if (!trainingTriggers) { + return []; + } + const trainingTriggerIds = trainingTriggers.map(({ id }) => id); + const trainingTriggerTubes = await knexConn('training-trigger-tubes') + .whereIn('trainingTriggerId', trainingTriggerIds) + .select('*'); + + return Promise.all( + trainingTriggers.map(async (trainingTrigger) => { + const triggerTubes = trainingTriggerTubes.filter( + ({ trainingTriggerId }) => trainingTriggerId === trainingTrigger.id + ); + return await _toDomainForAdmin({ trainingTrigger, triggerTubes }); + }) + ); +}; + +const findByTrainingId = async function ({ trainingId, domainTransaction = DomainTransaction.emptyTransaction() }) { + const knexConn = domainTransaction?.knexTransaction || knex; + const trainingTriggers = await knexConn(TABLE_NAME).select('*').where({ trainingId }).orderBy('id', 'asc'); + if (!trainingTriggers) { + return []; + } + const trainingTriggerIds = trainingTriggers.map(({ id }) => id); + const trainingTriggerTubes = await knexConn('training-trigger-tubes') + .whereIn('trainingTriggerId', trainingTriggerIds) + .select('*'); + + return Promise.all( + trainingTriggers.map(async (trainingTrigger) => { + const triggerTubes = trainingTriggerTubes.filter( + ({ trainingTriggerId }) => trainingTriggerId === trainingTrigger.id + ); + return _toDomain({ trainingTrigger, triggerTubes }); + }) + ); +}; + +export { createOrUpdate, findByTrainingIdForAdmin, findByTrainingId }; + async function _toDomain({ trainingTrigger, triggerTubes }) { const triggerTubeIds = triggerTubes.map(({ tubeId }) => tubeId); diff --git a/api/lib/infrastructure/repositories/tube-repository.js b/api/lib/infrastructure/repositories/tube-repository.js index b9bfaa3a040..f67bf931cd6 100644 --- a/api/lib/infrastructure/repositories/tube-repository.js +++ b/api/lib/infrastructure/repositories/tube-repository.js @@ -1,10 +1,9 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const Tube = require('../../domain/models/Tube.js'); -const { tubeDatasource } = require('../datasources/learning-content/tube-datasource.js'); -const { skillDatasource } = require('../datasources/learning-content/skill-datasource.js'); - -const { getTranslatedKey } = require('../../domain/services/get-translated-text.js'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import { Tube } from '../../domain/models/Tube.js'; +import { tubeDatasource } from '../datasources/learning-content/tube-datasource.js'; +import { skillDatasource } from '../datasources/learning-content/skill-datasource.js'; +import { getTranslatedKey } from '../../domain/services/get-translated-text.js'; function _toDomain({ tubeData, locale }) { const translatedPracticalTitle = getTranslatedKey(tubeData.practicalTitle_i18n, locale); @@ -32,34 +31,34 @@ async function _findActive(tubes) { }); } -module.exports = { - async get(id) { - const tubeData = await tubeDatasource.get(id); - return _toDomain({ tubeData }); - }, +const get = async function (id) { + const tubeData = await tubeDatasource.get(id); + return _toDomain({ tubeData }); +}; - async list() { - const tubeDatas = await tubeDatasource.list(); - const tubes = _.map(tubeDatas, (tubeData) => _toDomain({ tubeData })); - return _.orderBy(tubes, (tube) => tube.name.toLowerCase()); - }, +const list = async function () { + const tubeDatas = await tubeDatasource.list(); + const tubes = _.map(tubeDatas, (tubeData) => _toDomain({ tubeData })); + return _.orderBy(tubes, (tube) => tube.name.toLowerCase()); +}; - async findByNames({ tubeNames, locale }) { - const tubeDatas = await tubeDatasource.findByNames(tubeNames); - const tubes = _.map(tubeDatas, (tubeData) => _toDomain({ tubeData, locale })); - return _.orderBy(tubes, (tube) => tube.name.toLowerCase()); - }, +const findByNames = async function ({ tubeNames, locale }) { + const tubeDatas = await tubeDatasource.findByNames(tubeNames); + const tubes = _.map(tubeDatas, (tubeData) => _toDomain({ tubeData, locale })); + return _.orderBy(tubes, (tube) => tube.name.toLowerCase()); +}; - async findByRecordIds(tubeIds, locale) { - const tubeDatas = await tubeDatasource.findByRecordIds(tubeIds); - const tubes = _.map(tubeDatas, (tubeData) => _toDomain({ tubeData, locale })); - return _.orderBy(tubes, (tube) => tube.name.toLowerCase()); - }, +const findByRecordIds = async function (tubeIds, locale) { + const tubeDatas = await tubeDatasource.findByRecordIds(tubeIds); + const tubes = _.map(tubeDatas, (tubeData) => _toDomain({ tubeData, locale })); + return _.orderBy(tubes, (tube) => tube.name.toLowerCase()); +}; - async findActiveByRecordIds(tubeIds, locale) { - const tubeDatas = await tubeDatasource.findByRecordIds(tubeIds); - const activeTubes = await _findActive(tubeDatas); - const tubes = _.map(activeTubes, (tubeData) => _toDomain({ tubeData, locale })); - return _.orderBy(tubes, (tube) => tube.name.toLowerCase()); - }, +const findActiveByRecordIds = async function (tubeIds, locale) { + const tubeDatas = await tubeDatasource.findByRecordIds(tubeIds); + const activeTubes = await _findActive(tubeDatas); + const tubes = _.map(activeTubes, (tubeData) => _toDomain({ tubeData, locale })); + return _.orderBy(tubes, (tube) => tube.name.toLowerCase()); }; + +export { get, list, findByNames, findByRecordIds, findActiveByRecordIds }; diff --git a/api/lib/infrastructure/repositories/tutorial-evaluation-repository.js b/api/lib/infrastructure/repositories/tutorial-evaluation-repository.js index 8acaeb29338..b99a91e50f7 100644 --- a/api/lib/infrastructure/repositories/tutorial-evaluation-repository.js +++ b/api/lib/infrastructure/repositories/tutorial-evaluation-repository.js @@ -1,31 +1,31 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const TutorialEvaluation = require('../../domain/models/TutorialEvaluation.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { TutorialEvaluation } from '../../domain/models/TutorialEvaluation.js'; const TABLE_NAME = 'tutorial-evaluations'; -module.exports = { - async createOrUpdate({ userId, tutorialId, status }) { - const tutorialEvaluation = await knex(TABLE_NAME) - .insert({ - userId, - tutorialId, - status, - }) - .onConflict(['userId', 'tutorialId']) - .merge({ - status, - updatedAt: knex.fn.now(), - }) - .returning('*'); - return _toDomain(tutorialEvaluation[0]); - }, +const createOrUpdate = async function ({ userId, tutorialId, status }) { + const tutorialEvaluation = await knex(TABLE_NAME) + .insert({ + userId, + tutorialId, + status, + }) + .onConflict(['userId', 'tutorialId']) + .merge({ + status, + updatedAt: knex.fn.now(), + }) + .returning('*'); + return _toDomain(tutorialEvaluation[0]); +}; - async find({ userId }) { - const tutorialEvaluation = await knex(TABLE_NAME).where({ userId }); - return tutorialEvaluation.map(_toDomain); - }, +const find = async function ({ userId }) { + const tutorialEvaluation = await knex(TABLE_NAME).where({ userId }); + return tutorialEvaluation.map(_toDomain); }; +export { createOrUpdate, find }; + function _toDomain(tutorialEvaluationData) { return new TutorialEvaluation({ id: tutorialEvaluationData.id, diff --git a/api/lib/infrastructure/repositories/tutorial-repository.js b/api/lib/infrastructure/repositories/tutorial-repository.js index 27396a1ac25..9931264ffb2 100644 --- a/api/lib/infrastructure/repositories/tutorial-repository.js +++ b/api/lib/infrastructure/repositories/tutorial-repository.js @@ -1,102 +1,117 @@ -const _ = require('lodash'); -const Tutorial = require('../../domain/models/Tutorial.js'); -const userSavedTutorialRepository = require('./user-saved-tutorial-repository.js'); -const tutorialEvaluationRepository = require('./tutorial-evaluation-repository.js'); -const { tutorialDatasource } = require('../datasources/learning-content/tutorial-datasource.js'); -const { NotFoundError } = require('../../domain/errors.js'); -const TutorialForUser = require('../../domain/read-models/TutorialForUser.js'); -const { FRENCH_FRANCE } = require('../../domain/constants.js').LOCALE; -const knowledgeElementRepository = require('./knowledge-element-repository.js'); -const skillRepository = require('./skill-repository.js'); -const paginateModule = require('../utils/paginate.js'); - -module.exports = { - async findByRecordIdsForCurrentUser({ ids, userId, locale }) { - const tutorials = await _findByRecordIds({ ids, locale }); - const userSavedTutorials = await userSavedTutorialRepository.find({ userId }); - const tutorialEvaluations = await tutorialEvaluationRepository.find({ userId }); - return _toTutorialsForUser({ tutorials, tutorialEvaluations, userSavedTutorials }); - }, - - async findByRecordIds(ids) { - return _findByRecordIds({ ids }); - }, - - async findPaginatedFilteredForCurrentUser({ userId, filters = {}, page }) { - const userSavedTutorials = await userSavedTutorialRepository.find({ userId }); - const [tutorials, tutorialEvaluations] = await Promise.all([ - tutorialDatasource.findByRecordIds(userSavedTutorials.map(({ tutorialId }) => tutorialId)), - tutorialEvaluationRepository.find({ userId }), - ]); - - let filteredTutorials = [...tutorials]; - if (filters.competences?.length) { - const filteredSkills = await skillRepository.findOperativeByCompetenceIds(filters.competences); - - const filteredTutorialIds = filteredSkills.flatMap(({ tutorialIds }) => tutorialIds); - - filteredTutorials = tutorials.filter(({ id }) => filteredTutorialIds.includes(id)); - } - - const tutorialsForUser = _toTutorialsForUser({ - tutorials: filteredTutorials, - tutorialEvaluations, - userSavedTutorials, - }); +import _ from 'lodash'; +import { Tutorial } from '../../domain/models/Tutorial.js'; +import * as userSavedTutorialRepository from './user-saved-tutorial-repository.js'; +import * as tutorialEvaluationRepository from './tutorial-evaluation-repository.js'; +import { tutorialDatasource } from '../datasources/learning-content/tutorial-datasource.js'; +import { NotFoundError } from '../../domain/errors.js'; +import { TutorialForUser } from '../../domain/read-models/TutorialForUser.js'; +import { LOCALE } from '../../domain/constants.js'; + +const { FRENCH_FRANCE } = LOCALE; + +import * as knowledgeElementRepository from './knowledge-element-repository.js'; +import * as skillRepository from './skill-repository.js'; +import * as paginateModule from '../utils/paginate.js'; + +const findByRecordIdsForCurrentUser = async function ({ ids, userId, locale }) { + const tutorials = await _findByRecordIds({ ids, locale }); + const userSavedTutorials = await userSavedTutorialRepository.find({ userId }); + const tutorialEvaluations = await tutorialEvaluationRepository.find({ userId }); + return _toTutorialsForUser({ tutorials, tutorialEvaluations, userSavedTutorials }); +}; - const sortedTutorialsForUser = _.orderBy(tutorialsForUser, ['userSavedTutorial.createdAt'], ['desc']); - const { results: models, pagination: meta } = paginateModule.paginate(sortedTutorialsForUser, page); +const findByRecordIds = async function (ids) { + return _findByRecordIds({ ids }); +}; - return { models, meta }; - }, +const findPaginatedFilteredForCurrentUser = async function ({ userId, filters = {}, page }) { + const userSavedTutorials = await userSavedTutorialRepository.find({ userId }); + const [tutorials, tutorialEvaluations] = await Promise.all([ + tutorialDatasource.findByRecordIds(userSavedTutorials.map(({ tutorialId }) => tutorialId)), + tutorialEvaluationRepository.find({ userId }), + ]); - async get(id) { - try { - const tutorialData = await tutorialDatasource.get(id); - return _toDomain(tutorialData); - } catch (error) { - throw new NotFoundError('Tutorial not found'); - } - }, + let filteredTutorials = [...tutorials]; + if (filters.competences?.length) { + const filteredSkills = await skillRepository.findOperativeByCompetenceIds(filters.competences); - async list({ locale = FRENCH_FRANCE }) { - let tutorialData = await tutorialDatasource.list(); - const lang = _extractLangFromLocale(locale); - tutorialData = tutorialData.filter((tutorial) => _extractLangFromLocale(tutorial.locale) === lang); - return _.map(tutorialData, _toDomain); - }, - - async findPaginatedFilteredRecommendedByUserId({ userId, filters = {}, page, locale = FRENCH_FRANCE } = {}) { - const invalidatedKnowledgeElements = await knowledgeElementRepository.findInvalidatedAndDirectByUserId(userId); - - const [userSavedTutorials, tutorialEvaluations, skills] = await Promise.all([ - userSavedTutorialRepository.find({ userId }), - tutorialEvaluationRepository.find({ userId }), - skillRepository.findOperativeByIds(invalidatedKnowledgeElements.map(({ skillId }) => skillId)), - ]); - - let filteredSkills = [...skills]; - if (filters.competences?.length) { - filteredSkills = skills.filter(({ competenceId }) => filters.competences.includes(competenceId)); - } - - const tutorialsForUser = []; - - for (const skill of filteredSkills) { - const tutorials = await _findByRecordIds({ ids: skill.tutorialIds, locale }); - - tutorialsForUser.push( - ..._toTutorialsForUserForRecommandation({ - tutorials, - tutorialEvaluations, - userSavedTutorials, - skillId: skill.id, - }) - ); - } - - return paginateModule.paginate(tutorialsForUser, page); - }, + const filteredTutorialIds = filteredSkills.flatMap(({ tutorialIds }) => tutorialIds); + + filteredTutorials = tutorials.filter(({ id }) => filteredTutorialIds.includes(id)); + } + + const tutorialsForUser = _toTutorialsForUser({ + tutorials: filteredTutorials, + tutorialEvaluations, + userSavedTutorials, + }); + + const sortedTutorialsForUser = _.orderBy(tutorialsForUser, ['userSavedTutorial.createdAt'], ['desc']); + const { results: models, pagination: meta } = paginateModule.paginate(sortedTutorialsForUser, page); + + return { models, meta }; +}; + +const get = async function (id) { + try { + const tutorialData = await tutorialDatasource.get(id); + return _toDomain(tutorialData); + } catch (error) { + throw new NotFoundError('Tutorial not found'); + } +}; + +const list = async function ({ locale = FRENCH_FRANCE }) { + let tutorialData = await tutorialDatasource.list(); + const lang = _extractLangFromLocale(locale); + tutorialData = tutorialData.filter((tutorial) => _extractLangFromLocale(tutorial.locale) === lang); + return _.map(tutorialData, _toDomain); +}; + +const findPaginatedFilteredRecommendedByUserId = async function ({ + userId, + filters = {}, + page, + locale = FRENCH_FRANCE, +} = {}) { + const invalidatedKnowledgeElements = await knowledgeElementRepository.findInvalidatedAndDirectByUserId(userId); + + const [userSavedTutorials, tutorialEvaluations, skills] = await Promise.all([ + userSavedTutorialRepository.find({ userId }), + tutorialEvaluationRepository.find({ userId }), + skillRepository.findOperativeByIds(invalidatedKnowledgeElements.map(({ skillId }) => skillId)), + ]); + + let filteredSkills = [...skills]; + if (filters.competences?.length) { + filteredSkills = skills.filter(({ competenceId }) => filters.competences.includes(competenceId)); + } + + const tutorialsForUser = []; + + for (const skill of filteredSkills) { + const tutorials = await _findByRecordIds({ ids: skill.tutorialIds, locale }); + + tutorialsForUser.push( + ..._toTutorialsForUserForRecommandation({ + tutorials, + tutorialEvaluations, + userSavedTutorials, + skillId: skill.id, + }) + ); + } + + return paginateModule.paginate(tutorialsForUser, page); +}; + +export { + findByRecordIdsForCurrentUser, + findByRecordIds, + findPaginatedFilteredForCurrentUser, + get, + list, + findPaginatedFilteredRecommendedByUserId, }; function _toDomain(tutorialData) { diff --git a/api/lib/infrastructure/repositories/user-campaign-results/stage-collection-repository.js b/api/lib/infrastructure/repositories/user-campaign-results/stage-collection-repository.js index 8d8e9020bad..d189a1e1fa1 100644 --- a/api/lib/infrastructure/repositories/user-campaign-results/stage-collection-repository.js +++ b/api/lib/infrastructure/repositories/user-campaign-results/stage-collection-repository.js @@ -1,22 +1,22 @@ -const { knex } = require('../../../../db/knex-database-connection.js'); -const StageCollection = require('../../../domain/models/user-campaign-results/StageCollection.js'); -const skillRepository = require('./../skill-repository.js'); +import { knex } from '../../../../db/knex-database-connection.js'; +import { StageCollection } from '../../../domain/models/user-campaign-results/StageCollection.js'; +import * as skillRepository from './../skill-repository.js'; const MAX_STAGE_THRESHOLD = 100; -module.exports = { - async findStageCollection({ campaignId }) { - const stages = await knex('stages') - .select('stages.*') - .join('campaigns', 'campaigns.targetProfileId', 'stages.targetProfileId') - .where('campaigns.id', campaignId) - .orderBy(['stages.threshold', 'stages.level']); +const findStageCollection = async function ({ campaignId }) { + const stages = await knex('stages') + .select('stages.*') + .join('campaigns', 'campaigns.targetProfileId', 'stages.targetProfileId') + .where('campaigns.id', campaignId) + .orderBy(['stages.threshold', 'stages.level']); - await _computeStagesThresholdForCampaign(stages, campaignId); + await _computeStagesThresholdForCampaign(stages, campaignId); - return new StageCollection({ campaignId, stages }); - }, + return new StageCollection({ campaignId, stages }); }; +export { findStageCollection }; + async function _computeStagesThresholdForCampaign(stages, campaignId) { const stagesWithLevel = stages.filter((stage) => stage.level || stage.level === 0); diff --git a/api/lib/infrastructure/repositories/user-email-repository.js b/api/lib/infrastructure/repositories/user-email-repository.js index f87398b2891..2c563c94e0a 100644 --- a/api/lib/infrastructure/repositories/user-email-repository.js +++ b/api/lib/infrastructure/repositories/user-email-repository.js @@ -1,29 +1,29 @@ -const settings = require('../../config.js'); -const EXPIRATION_DELAY_SECONDS = settings.temporaryStorage.expirationDelaySeconds; -const EmailModificationDemand = require('../../domain/models/EmailModificationDemand.js'); -const { temporaryStorage } = require('../temporary-storage/index.js'); +import { config } from '../../config.js'; +const EXPIRATION_DELAY_SECONDS = config.temporaryStorage.expirationDelaySeconds; +import { EmailModificationDemand } from '../../domain/models/EmailModificationDemand.js'; +import { temporaryStorage } from '../temporary-storage/index.js'; const verifyEmailTemporaryStorage = temporaryStorage.withPrefix('verify-email:'); -module.exports = { - saveEmailModificationDemand({ userId, code, newEmail }) { - const key = userId; +const saveEmailModificationDemand = function ({ userId, code, newEmail }) { + const key = userId; - return verifyEmailTemporaryStorage.save({ - key, - value: { code, newEmail }, - expirationDelaySeconds: EXPIRATION_DELAY_SECONDS, - }); - }, + return verifyEmailTemporaryStorage.save({ + key, + value: { code, newEmail }, + expirationDelaySeconds: EXPIRATION_DELAY_SECONDS, + }); +}; - async getEmailModificationDemandByUserId(userId) { - const key = userId; - const emailModificationDemand = await verifyEmailTemporaryStorage.get(key); +const getEmailModificationDemandByUserId = async function (userId) { + const key = userId; + const emailModificationDemand = await verifyEmailTemporaryStorage.get(key); - if (!emailModificationDemand) return; + if (!emailModificationDemand) return; - return new EmailModificationDemand({ - newEmail: emailModificationDemand.newEmail, - code: emailModificationDemand.code, - }); - }, + return new EmailModificationDemand({ + newEmail: emailModificationDemand.newEmail, + code: emailModificationDemand.code, + }); }; + +export { saveEmailModificationDemand, getEmailModificationDemandByUserId }; diff --git a/api/lib/infrastructure/repositories/user-login-repository.js b/api/lib/infrastructure/repositories/user-login-repository.js index 81477df596d..7bc3081d03f 100644 --- a/api/lib/infrastructure/repositories/user-login-repository.js +++ b/api/lib/infrastructure/repositories/user-login-repository.js @@ -1,5 +1,5 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const UserLogin = require('../../domain/models/UserLogin.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { UserLogin } from '../../domain/models/UserLogin.js'; function _toDomain(userLoginDTO) { return new UserLogin({ @@ -13,32 +13,32 @@ function _toDomain(userLoginDTO) { }); } -module.exports = { - async findByUserId(userId) { - const foundUserLogin = await knex.from('user-logins').where({ userId }).first(); - return foundUserLogin ? _toDomain(foundUserLogin) : null; - }, +const findByUserId = async function (userId) { + const foundUserLogin = await knex.from('user-logins').where({ userId }).first(); + return foundUserLogin ? _toDomain(foundUserLogin) : null; +}; - async create(userLogin) { - const [userLoginDTO] = await knex('user-logins').insert(userLogin).returning('*'); - return _toDomain(userLoginDTO); - }, +const create = async function (userLogin) { + const [userLoginDTO] = await knex('user-logins').insert(userLogin).returning('*'); + return _toDomain(userLoginDTO); +}; - async update(userLogin) { - userLogin.updatedAt = new Date(); - const [userLoginDTO] = await knex('user-logins').where({ id: userLogin.id }).update(userLogin).returning('*'); - return _toDomain(userLoginDTO); - }, +const update = async function (userLogin) { + userLogin.updatedAt = new Date(); + const [userLoginDTO] = await knex('user-logins').where({ id: userLogin.id }).update(userLogin).returning('*'); + return _toDomain(userLoginDTO); +}; - async findByUsername(username) { - const foundUserLogin = await knex - .select('user-logins.*') - .from('user-logins') - .where('users.email', username.toLowerCase()) - .orWhere('users.username', username.toLowerCase()) - .join('users', 'users.id', 'user-logins.userId') - .first(); +const findByUsername = async function (username) { + const foundUserLogin = await knex + .select('user-logins.*') + .from('user-logins') + .where('users.email', username.toLowerCase()) + .orWhere('users.username', username.toLowerCase()) + .join('users', 'users.id', 'user-logins.userId') + .first(); - return foundUserLogin ? _toDomain(foundUserLogin) : null; - }, + return foundUserLogin ? _toDomain(foundUserLogin) : null; }; + +export { findByUserId, create, update, findByUsername }; diff --git a/api/lib/infrastructure/repositories/user-orga-settings-repository.js b/api/lib/infrastructure/repositories/user-orga-settings-repository.js index 31a8855e21b..4b1f5310175 100644 --- a/api/lib/infrastructure/repositories/user-orga-settings-repository.js +++ b/api/lib/infrastructure/repositories/user-orga-settings-repository.js @@ -1,67 +1,67 @@ -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const BookshelfUserOrgaSettings = require('../orm-models/UserOrgaSettings.js'); -const bookshelfUtils = require('../utils/knex-utils.js'); -const { UserOrgaSettingsCreationError } = require('../../domain/errors.js'); -const { knex } = require('../../../db/knex-database-connection.js'); -const UserOrgaSettings = require('../../domain/models/UserOrgaSettings.js'); +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; +import { BookshelfUserOrgaSettings } from '../orm-models/UserOrgaSettings.js'; +import * as knexUtils from '../utils/knex-utils.js'; +import { UserOrgaSettingsCreationError } from '../../domain/errors.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { UserOrgaSettings } from '../../domain/models/UserOrgaSettings.js'; -module.exports = { - findOneByUserId(userId) { - return BookshelfUserOrgaSettings.where({ userId }) - .fetch({ require: true, withRelated: ['user', 'currentOrganization'] }) - .then((userOrgaSettings) => - bookshelfToDomainConverter.buildDomainObject(BookshelfUserOrgaSettings, userOrgaSettings) - ) - .catch((err) => { - if (err instanceof BookshelfUserOrgaSettings.NotFoundError) { - return {}; - } - throw err; - }); - }, +const findOneByUserId = function (userId) { + return BookshelfUserOrgaSettings.where({ userId }) + .fetch({ require: true, withRelated: ['user', 'currentOrganization'] }) + .then((userOrgaSettings) => + bookshelfToDomainConverter.buildDomainObject(BookshelfUserOrgaSettings, userOrgaSettings) + ) + .catch((err) => { + if (err instanceof BookshelfUserOrgaSettings.NotFoundError) { + return {}; + } + throw err; + }); +}; - create(userId, currentOrganizationId) { - return new BookshelfUserOrgaSettings({ userId, currentOrganizationId }) - .save() - .then((bookshelfUserOrgaSettings) => bookshelfUserOrgaSettings.load(['user', 'currentOrganization'])) - .then((userOrgaSettings) => - bookshelfToDomainConverter.buildDomainObject(BookshelfUserOrgaSettings, userOrgaSettings) - ) - .catch((err) => { - if (bookshelfUtils.isUniqConstraintViolated(err)) { - throw new UserOrgaSettingsCreationError(err.message); - } - throw err; - }); - }, +const create = function (userId, currentOrganizationId) { + return new BookshelfUserOrgaSettings({ userId, currentOrganizationId }) + .save() + .then((bookshelfUserOrgaSettings) => bookshelfUserOrgaSettings.load(['user', 'currentOrganization'])) + .then((userOrgaSettings) => + bookshelfToDomainConverter.buildDomainObject(BookshelfUserOrgaSettings, userOrgaSettings) + ) + .catch((err) => { + if (knexUtils.isUniqConstraintViolated(err)) { + throw new UserOrgaSettingsCreationError(err.message); + } + throw err; + }); +}; - async update(userId, organizationId) { - const bookshelfUserOrgaSettings = await BookshelfUserOrgaSettings.where({ userId }).save( - { currentOrganizationId: organizationId }, - { patch: true, method: 'update' } - ); - await bookshelfUserOrgaSettings.related('user').fetch(); - await bookshelfUserOrgaSettings.related('currentOrganization').fetch(); - return bookshelfToDomainConverter.buildDomainObject(BookshelfUserOrgaSettings, bookshelfUserOrgaSettings); - }, +const update = async function (userId, organizationId) { + const bookshelfUserOrgaSettings = await BookshelfUserOrgaSettings.where({ userId }).save( + { currentOrganizationId: organizationId }, + { patch: true, method: 'update' } + ); + await bookshelfUserOrgaSettings.related('user').fetch(); + await bookshelfUserOrgaSettings.related('currentOrganization').fetch(); + return bookshelfToDomainConverter.buildDomainObject(BookshelfUserOrgaSettings, bookshelfUserOrgaSettings); +}; - async createOrUpdate({ userId, organizationId }) { - const knexUserOrgaSetting = ( - await knex('user-orga-settings') - .insert({ userId, currentOrganizationId: organizationId }) - .onConflict('userId') - .merge() - .returning('*') - )[0]; +const createOrUpdate = async function ({ userId, organizationId }) { + const knexUserOrgaSetting = ( + await knex('user-orga-settings') + .insert({ userId, currentOrganizationId: organizationId }) + .onConflict('userId') + .merge() + .returning('*') + )[0]; - const user = await knex('users').where({ id: knexUserOrgaSetting.userId }).first(); + const user = await knex('users').where({ id: knexUserOrgaSetting.userId }).first(); - const organization = await knex('organizations').where({ id: knexUserOrgaSetting.currentOrganizationId }).first(); + const organization = await knex('organizations').where({ id: knexUserOrgaSetting.currentOrganizationId }).first(); - return new UserOrgaSettings({ - id: knexUserOrgaSetting.id, - user, - currentOrganization: organization, - }); - }, + return new UserOrgaSettings({ + id: knexUserOrgaSetting.id, + user, + currentOrganization: organization, + }); }; + +export { findOneByUserId, create, update, createOrUpdate }; diff --git a/api/lib/infrastructure/repositories/user-organizations-for-admin-repository.js b/api/lib/infrastructure/repositories/user-organizations-for-admin-repository.js index df35dbc9550..1d6a249eef9 100644 --- a/api/lib/infrastructure/repositories/user-organizations-for-admin-repository.js +++ b/api/lib/infrastructure/repositories/user-organizations-for-admin-repository.js @@ -1,22 +1,22 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const UserOrganizationForAdmin = require('../../domain/read-models/UserOrganizationForAdmin.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { UserOrganizationForAdmin } from '../../domain/read-models/UserOrganizationForAdmin.js'; -module.exports = { - async findByUserId(userId) { - const organizations = await knex('memberships') - .select({ - id: 'memberships.id', - updatedAt: 'memberships.updatedAt', - organizationRole: 'memberships.organizationRole', - organizationId: 'memberships.organizationId', - organizationName: 'organizations.name', - organizationType: 'organizations.type', - organizationExternalId: 'organizations.externalId', - }) - .innerJoin('organizations', 'organizations.id', 'memberships.organizationId') - .where('memberships.userId', userId) - .whereNull('memberships.disabledAt'); +const findByUserId = async function (userId) { + const organizations = await knex('memberships') + .select({ + id: 'memberships.id', + updatedAt: 'memberships.updatedAt', + organizationRole: 'memberships.organizationRole', + organizationId: 'memberships.organizationId', + organizationName: 'organizations.name', + organizationType: 'organizations.type', + organizationExternalId: 'organizations.externalId', + }) + .innerJoin('organizations', 'organizations.id', 'memberships.organizationId') + .where('memberships.userId', userId) + .whereNull('memberships.disabledAt'); - return organizations.map((attributes) => new UserOrganizationForAdmin(attributes)); - }, + return organizations.map((attributes) => new UserOrganizationForAdmin(attributes)); }; + +export { findByUserId }; diff --git a/api/lib/infrastructure/repositories/user-recommended-training-repository.js b/api/lib/infrastructure/repositories/user-recommended-training-repository.js index 12a133479b2..121c3f8e043 100644 --- a/api/lib/infrastructure/repositories/user-recommended-training-repository.js +++ b/api/lib/infrastructure/repositories/user-recommended-training-repository.js @@ -1,39 +1,44 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const UserRecommendedTraining = require('../../domain/read-models/UserRecommendedTraining.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { UserRecommendedTraining } from '../../domain/read-models/UserRecommendedTraining.js'; const TABLE_NAME = 'user-recommended-trainings'; -module.exports = { - save({ userId, trainingId, campaignParticipationId, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConn = domainTransaction?.knexTransaction || knex; - return knexConn(TABLE_NAME) - .insert({ userId, trainingId, campaignParticipationId }) - .onConflict(['userId', 'trainingId', 'campaignParticipationId']) - .merge({ updatedAt: knexConn.fn.now() }); - }, +const save = function ({ + userId, + trainingId, + campaignParticipationId, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction?.knexTransaction || knex; + return knexConn(TABLE_NAME) + .insert({ userId, trainingId, campaignParticipationId }) + .onConflict(['userId', 'trainingId', 'campaignParticipationId']) + .merge({ updatedAt: knexConn.fn.now() }); +}; - async findByCampaignParticipationId({ - campaignParticipationId, - locale, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - const knexConn = domainTransaction?.knexTransaction || knex; - const trainings = await knexConn(TABLE_NAME) - .select('trainings.*') - .innerJoin('trainings', 'trainings.id', `${TABLE_NAME}.trainingId`) - .where({ campaignParticipationId, locale }) - .orderBy('id', 'asc'); - return trainings.map(_toDomain); - }, +const findByCampaignParticipationId = async function ({ + campaignParticipationId, + locale, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + const knexConn = domainTransaction?.knexTransaction || knex; + const trainings = await knexConn(TABLE_NAME) + .select('trainings.*') + .innerJoin('trainings', 'trainings.id', `${TABLE_NAME}.trainingId`) + .where({ campaignParticipationId, locale }) + .orderBy('id', 'asc'); + return trainings.map(_toDomain); +}; - async hasRecommendedTrainings(userId, domainTransaction = DomainTransaction.emptyTransaction()) { - const knexConn = domainTransaction?.knexTransaction || knex; - const result = await knexConn(TABLE_NAME).select(1).where({ userId }).first(); - return Boolean(result); - }, +const hasRecommendedTrainings = async function (userId, domainTransaction = DomainTransaction.emptyTransaction()) { + const knexConn = domainTransaction?.knexTransaction || knex; + const result = await knexConn(TABLE_NAME).select(1).where({ userId }).first(); + return Boolean(result); }; +export { save, findByCampaignParticipationId, hasRecommendedTrainings }; + function _toDomain(training) { return new UserRecommendedTraining({ ...training }); } diff --git a/api/lib/infrastructure/repositories/user-repository.js b/api/lib/infrastructure/repositories/user-repository.js index 3c13b8063b8..a29b9239956 100644 --- a/api/lib/infrastructure/repositories/user-repository.js +++ b/api/lib/infrastructure/repositories/user-repository.js @@ -1,429 +1,460 @@ -const moment = require('moment'); - -const { knex } = require('../../../db/knex-database-connection.js'); -const DomainTransaction = require('../DomainTransaction.js'); -const BookshelfUser = require('../orm-models/User.js'); -const { isUniqConstraintViolated } = require('../utils/knex-utils.js'); -const bookshelfToDomainConverter = require('../utils/bookshelf-to-domain-converter.js'); -const { +import moment from 'moment'; + +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { BookshelfUser } from '../orm-models/User.js'; +import { isUniqConstraintViolated, fetchPage } from '../utils/knex-utils.js'; +import * as bookshelfToDomainConverter from '../utils/bookshelf-to-domain-converter.js'; + +import { AlreadyExistingEntityError, AlreadyRegisteredEmailError, AlreadyRegisteredUsernameError, UserNotFoundError, -} = require('../../domain/errors.js'); -const User = require('../../domain/models/User.js'); -const UserDetailsForAdmin = require('../../domain/models/UserDetailsForAdmin.js'); -const Membership = require('../../domain/models/Membership.js'); -const CertificationCenter = require('../../domain/models/CertificationCenter.js'); -const CertificationCenterMembership = require('../../domain/models/CertificationCenterMembership.js'); -const Organization = require('../../domain/models/Organization.js'); -const OrganizationLearnerForAdmin = require('../../domain/read-models/OrganizationLearnerForAdmin.js'); -const AuthenticationMethod = require('../../domain/models/AuthenticationMethod.js'); -const OidcIdentityProviders = require('../../domain/constants/oidc-identity-providers.js'); -const UserLogin = require('../../domain/models/UserLogin.js'); -const { fetchPage } = require('../utils/knex-utils.js'); - -module.exports = { - async getByEmail(email) { - const foundUser = await knex.from('users').whereRaw('LOWER("email") = ?', email.toLowerCase()).first(); - if (!foundUser) { - throw new UserNotFoundError(`User not found for email ${email}`); - } - return new User(foundUser); - }, +} from '../../domain/errors.js'; + +import { User } from '../../domain/models/User.js'; +import { UserDetailsForAdmin } from '../../domain/models/UserDetailsForAdmin.js'; +import { Membership } from '../../domain/models/Membership.js'; +import { CertificationCenter } from '../../domain/models/CertificationCenter.js'; +import { CertificationCenterMembership } from '../../domain/models/CertificationCenterMembership.js'; +import { Organization } from '../../domain/models/Organization.js'; +import { OrganizationLearnerForAdmin } from '../../domain/read-models/OrganizationLearnerForAdmin.js'; +import { AuthenticationMethod } from '../../domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../domain/constants/oidc-identity-providers.js'; +import { UserLogin } from '../../domain/models/UserLogin.js'; + +const getByEmail = async function (email) { + const foundUser = await knex.from('users').whereRaw('LOWER("email") = ?', email.toLowerCase()).first(); + if (!foundUser) { + throw new UserNotFoundError(`User not found for email ${email}`); + } + return new User(foundUser); +}; - async getFullById(userId) { - const userDTO = await knex('users').where({ id: userId }).first(); - if (!userDTO) { - throw new UserNotFoundError(); - } +const getFullById = async function (userId) { + const userDTO = await knex('users').where({ id: userId }).first(); + if (!userDTO) { + throw new UserNotFoundError(); + } - const membershipsDTO = await knex('memberships').where({ userId: userDTO.id, disabledAt: null }); - const certificationCenterMembershipsDTO = await knex('certification-center-memberships').where({ - userId: userDTO.id, - disabledAt: null, - }); - const authenticationMethodsDTO = await knex('authentication-methods').where({ - userId: userDTO.id, - identityProvider: 'PIX', - }); + const membershipsDTO = await knex('memberships').where({ userId: userDTO.id, disabledAt: null }); + const certificationCenterMembershipsDTO = await knex('certification-center-memberships').where({ + userId: userDTO.id, + disabledAt: null, + }); + const authenticationMethodsDTO = await knex('authentication-methods').where({ + userId: userDTO.id, + identityProvider: 'PIX', + }); - return _toDomainFromDTO({ userDTO, membershipsDTO, certificationCenterMembershipsDTO, authenticationMethodsDTO }); - }, + return _toDomainFromDTO({ userDTO, membershipsDTO, certificationCenterMembershipsDTO, authenticationMethodsDTO }); +}; - async getByUsernameOrEmailWithRolesAndPassword(username) { - const userDTO = await knex('users') - .where({ email: username.toLowerCase() }) - .orWhere({ username: username.toLowerCase() }) - .first(); +const getByUsernameOrEmailWithRolesAndPassword = async function (username) { + const userDTO = await knex('users') + .where({ email: username.toLowerCase() }) + .orWhere({ username: username.toLowerCase() }) + .first(); - if (!userDTO) { - throw new UserNotFoundError(); - } + if (!userDTO) { + throw new UserNotFoundError(); + } - const membershipsDTO = await knex('memberships').where({ userId: userDTO.id, disabledAt: null }); - const certificationCenterMembershipsDTO = await knex('certification-center-memberships').where({ - userId: userDTO.id, - disabledAt: null, + const membershipsDTO = await knex('memberships').where({ userId: userDTO.id, disabledAt: null }); + const certificationCenterMembershipsDTO = await knex('certification-center-memberships').where({ + userId: userDTO.id, + disabledAt: null, + }); + const authenticationMethodsDTO = await knex('authentication-methods').where({ + userId: userDTO.id, + identityProvider: 'PIX', + }); + + return _toDomainFromDTO({ userDTO, membershipsDTO, certificationCenterMembershipsDTO, authenticationMethodsDTO }); +}; + +const get = function (userId) { + return BookshelfUser.where({ id: userId }) + .fetch() + .then((user) => bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user)) + .catch((err) => { + if (err instanceof BookshelfUser.NotFoundError) { + throw new UserNotFoundError(`User not found for ID ${userId}`); + } + throw err; }); - const authenticationMethodsDTO = await knex('authentication-methods').where({ - userId: userDTO.id, - identityProvider: 'PIX', +}; + +const getById = async function (userId) { + const foundUser = await knex.from('users').where({ id: userId }).first(); + if (!foundUser) { + throw new UserNotFoundError(); + } + return new User(foundUser); +}; + +const getForObfuscation = async function (userId) { + const foundUser = await knex.select('id', 'email', 'username').from('users').where({ id: userId }).first(); + if (!foundUser) { + throw new UserNotFoundError(`User not found for ID ${userId}`); + } + return new User({ id: foundUser.id, email: foundUser.email, username: foundUser.username }); +}; + +const getUserDetailsForAdmin = async function (userId) { + const userDTO = await knex('users') + .leftJoin('user-logins', 'user-logins.userId', 'users.id') + .leftJoin('users AS anonymisedBy', 'anonymisedBy.id', 'users.hasBeenAnonymisedBy') + .select([ + 'users.*', + 'user-logins.id AS userLoginId', + 'user-logins.failureCount', + 'user-logins.temporaryBlockedUntil', + 'user-logins.blockedAt', + 'anonymisedBy.firstName AS anonymisedByFirstName', + 'anonymisedBy.lastName AS anonymisedByLastName', + ]) + .where({ 'users.id': userId }) + .first(); + + if (!userDTO) { + throw new UserNotFoundError(`User not found for ID ${userId}`); + } + + const authenticationMethodsDTO = await knex('authentication-methods') + .select([ + 'authentication-methods.id', + 'authentication-methods.identityProvider', + 'authentication-methods.authenticationComplement', + ]) + .join('users', 'users.id', 'authentication-methods.userId') + .where({ userId }); + + const organizationLearnersDTO = await knex('view-active-organization-learners') + .select([ + 'view-active-organization-learners.*', + 'organizations.name AS organizationName', + 'organizations.isManagingStudents AS organizationIsManagingStudents', + ]) + .join('organizations', 'organizations.id', 'view-active-organization-learners.organizationId') + .where({ userId }) + .orderBy('id'); + + return _fromKnexDTOToUserDetailsForAdmin({ userDTO, organizationLearnersDTO, authenticationMethodsDTO }); +}; + +const findPaginatedFiltered = async function ({ filter, page }) { + const query = knex('users') + .where((qb) => _setSearchFiltersForQueryBuilder(filter, qb)) + .orderBy([{ column: 'firstName', order: 'asc' }, { column: 'lastName', order: 'asc' }, { column: 'id' }]); + const { results, pagination } = await fetchPage(query, page); + + const users = results.map((userDTO) => new User(userDTO)); + return { models: users, pagination }; +}; + +const getWithMemberships = async function (userId) { + const userDTO = await knex('users').where({ id: userId }).first(); + + if (!userDTO) { + throw new UserNotFoundError(); + } + + const membershipsDTO = await knex('memberships') + .select( + 'memberships.*', + 'organizations.name AS organizationName', + 'organizations.type AS organizationType', + 'organizations.externalId AS organizationExternalId', + 'organizations.isManagingStudents AS organizationIsManagingStudents' + ) + .join('organizations', 'organizations.id', 'memberships.organizationId') + .where({ userId: userDTO.id, disabledAt: null }); + + return _toDomainFromDTO({ userDTO, membershipsDTO }); +}; + +const getWithCertificationCenterMemberships = function (userId) { + return BookshelfUser.where({ id: userId }) + .fetch({ + withRelated: [ + { certificationCenterMemberships: (qb) => qb.where({ disabledAt: null }) }, + 'certificationCenterMemberships.certificationCenter', + ], + }) + .then(_toDomain) + .catch((err) => { + if (err instanceof BookshelfUser.NotFoundError) { + throw new UserNotFoundError(`User not found for ID ${userId}`); + } + throw err; }); +}; - return _toDomainFromDTO({ userDTO, membershipsDTO, certificationCenterMembershipsDTO, authenticationMethodsDTO }); - }, - - /** - * @deprecated Use getById instead - */ - get(userId) { - return BookshelfUser.where({ id: userId }) - .fetch() - .then((user) => bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user)) - .catch((err) => { - if (err instanceof BookshelfUser.NotFoundError) { - throw new UserNotFoundError(`User not found for ID ${userId}`); - } - throw err; - }); - }, +const getBySamlId = async function (samlId) { + const bookshelfUser = await BookshelfUser.query((qb) => { + qb.innerJoin('authentication-methods', function () { + this.on('users.id', 'authentication-methods.userId') + .andOnVal('authentication-methods.identityProvider', AuthenticationMethod.identityProviders.GAR) + .andOnVal('authentication-methods.externalIdentifier', samlId); + }); + }).fetch({ require: false, withRelated: 'authenticationMethods' }); + return bookshelfUser ? _toDomain(bookshelfUser) : null; +}; - async getById(userId) { - const foundUser = await knex.from('users').where({ id: userId }).first(); - if (!foundUser) { - throw new UserNotFoundError(); - } - return new User(foundUser); - }, +const update = async function (properties) { + const { id: userId, ...data } = properties; + data.updatedAt = new Date(); + await knex('users').where({ id: userId }).update(data); +}; - async getForObfuscation(userId) { - const foundUser = await knex.select('id', 'email', 'username').from('users').where({ id: userId }).first(); - if (!foundUser) { - throw new UserNotFoundError(`User not found for ID ${userId}`); - } - return new User({ id: foundUser.id, email: foundUser.email, username: foundUser.username }); - }, - - async getUserDetailsForAdmin(userId) { - const userDTO = await knex('users') - .leftJoin('user-logins', 'user-logins.userId', 'users.id') - .leftJoin('users AS anonymisedBy', 'anonymisedBy.id', 'users.hasBeenAnonymisedBy') - .select([ - 'users.*', - 'user-logins.id AS userLoginId', - 'user-logins.failureCount', - 'user-logins.temporaryBlockedUntil', - 'user-logins.blockedAt', - 'anonymisedBy.firstName AS anonymisedByFirstName', - 'anonymisedBy.lastName AS anonymisedByLastName', - ]) - .where({ 'users.id': userId }) - .first(); +const updateWithEmailConfirmed = function ({ + id, + userAttributes, + domainTransaction: { knexTransaction } = DomainTransaction.emptyTransaction(), +}) { + const query = knex('users').where({ id }).update(userAttributes); + if (knexTransaction) query.transacting(knexTransaction); + return query; +}; - if (!userDTO) { - throw new UserNotFoundError(`User not found for ID ${userId}`); - } +const checkIfEmailIsAvailable = function (email) { + return BookshelfUser.query((qb) => qb.whereRaw('LOWER("email") = ?', email.toLowerCase())) + .fetch({ require: false }) + .then((user) => { + if (user) { + return Promise.reject(new AlreadyRegisteredEmailError()); + } - const authenticationMethodsDTO = await knex('authentication-methods') - .select([ - 'authentication-methods.id', - 'authentication-methods.identityProvider', - 'authentication-methods.authenticationComplement', - ]) - .join('users', 'users.id', 'authentication-methods.userId') - .where({ userId }); - - const organizationLearnersDTO = await knex('view-active-organization-learners') - .select([ - 'view-active-organization-learners.*', - 'organizations.name AS organizationName', - 'organizations.isManagingStudents AS organizationIsManagingStudents', - ]) - .join('organizations', 'organizations.id', 'view-active-organization-learners.organizationId') - .where({ userId }) - .orderBy('id'); - - return _fromKnexDTOToUserDetailsForAdmin({ userDTO, organizationLearnersDTO, authenticationMethodsDTO }); - }, - - async findPaginatedFiltered({ filter, page }) { - const query = knex('users') - .where((qb) => _setSearchFiltersForQueryBuilder(filter, qb)) - .orderBy([{ column: 'firstName', order: 'asc' }, { column: 'lastName', order: 'asc' }, { column: 'id' }]); - const { results, pagination } = await fetchPage(query, page); - - const users = results.map((userDTO) => new User(userDTO)); - return { models: users, pagination }; - }, - - async getWithMemberships(userId) { - const userDTO = await knex('users').where({ id: userId }).first(); + return Promise.resolve(email); + }); +}; - if (!userDTO) { +const isUserExistingByEmail = function (email) { + return BookshelfUser.where({ email: email.toLowerCase() }) + .fetch() + .then(() => true) + .catch(() => { throw new UserNotFoundError(); - } + }); +}; - const membershipsDTO = await knex('memberships') - .select( - 'memberships.*', - 'organizations.name AS organizationName', - 'organizations.type AS organizationType', - 'organizations.externalId AS organizationExternalId', - 'organizations.isManagingStudents AS organizationIsManagingStudents' - ) - .join('organizations', 'organizations.id', 'memberships.organizationId') - .where({ userId: userDTO.id, disabledAt: null }); - - return _toDomainFromDTO({ userDTO, membershipsDTO }); - }, - - getWithCertificationCenterMemberships(userId) { - return BookshelfUser.where({ id: userId }) - .fetch({ - withRelated: [ - { certificationCenterMemberships: (qb) => qb.where({ disabledAt: null }) }, - 'certificationCenterMemberships.certificationCenter', - ], - }) - .then(_toDomain) - .catch((err) => { - if (err instanceof BookshelfUser.NotFoundError) { - throw new UserNotFoundError(`User not found for ID ${userId}`); - } - throw err; - }); - }, - - async getBySamlId(samlId) { - const bookshelfUser = await BookshelfUser.query((qb) => { - qb.innerJoin('authentication-methods', function () { - this.on('users.id', 'authentication-methods.userId') - .andOnVal('authentication-methods.identityProvider', AuthenticationMethod.identityProviders.GAR) - .andOnVal('authentication-methods.externalIdentifier', samlId); - }); - }).fetch({ require: false, withRelated: 'authenticationMethods' }); - return bookshelfUser ? _toDomain(bookshelfUser) : null; - }, - - async update(properties) { - const { id: userId, ...data } = properties; - data.updatedAt = new Date(); - await knex('users').where({ id: userId }).update(data); - }, - - updateWithEmailConfirmed({ - id, - userAttributes, - domainTransaction: { knexTransaction } = DomainTransaction.emptyTransaction(), - }) { - const query = knex('users').where({ id }).update(userAttributes); - if (knexTransaction) query.transacting(knexTransaction); - return query; - }, - - checkIfEmailIsAvailable(email) { - return BookshelfUser.query((qb) => qb.whereRaw('LOWER("email") = ?', email.toLowerCase())) - .fetch({ require: false }) - .then((user) => { - if (user) { - return Promise.reject(new AlreadyRegisteredEmailError()); - } - - return Promise.resolve(email); - }); - }, - - isUserExistingByEmail(email) { - return BookshelfUser.where({ email: email.toLowerCase() }) - .fetch() - .then(() => true) - .catch(() => { - throw new UserNotFoundError(); - }); - }, - - updatePassword(id, hashedPassword) { - return BookshelfUser.where({ id }) - .save({ password: hashedPassword }, { patch: true, method: 'update' }) - .then((bookshelfUser) => _toDomain(bookshelfUser)) - .catch((err) => { - if (err instanceof BookshelfUser.NoRowsUpdatedError) { - throw new UserNotFoundError(`User not found for ID ${id}`); - } - throw err; - }); - }, - - updateEmail({ id, email }) { - return BookshelfUser.where({ id }) - .save({ email }, { patch: true, method: 'update' }) - .then((bookshelfUser) => _toDomain(bookshelfUser)) - .catch((err) => { - if (err instanceof BookshelfUser.NoRowsUpdatedError) { - throw new UserNotFoundError(`User not found for ID ${id}`); - } - throw err; - }); - }, - - async updateUserDetailsForAdministration({ - id, - userAttributes, - domainTransaction = DomainTransaction.emptyTransaction(), - }) { - try { - const knexConn = domainTransaction.knexTransaction ?? knex; - const [userDTO] = await knexConn('users').where({ id }).update(userAttributes).returning('*'); - - if (!userDTO) { +const updatePassword = function (id, hashedPassword) { + return BookshelfUser.where({ id }) + .save({ password: hashedPassword }, { patch: true, method: 'update' }) + .then((bookshelfUser) => _toDomain(bookshelfUser)) + .catch((err) => { + if (err instanceof BookshelfUser.NoRowsUpdatedError) { throw new UserNotFoundError(`User not found for ID ${id}`); } - } catch (err) { - if (isUniqConstraintViolated(err)) { - throw new AlreadyExistingEntityError('Cette adresse e-mail ou cet identifiant est déjà utilisé(e).'); + throw err; + }); +}; + +const updateEmail = function ({ id, email }) { + return BookshelfUser.where({ id }) + .save({ email }, { patch: true, method: 'update' }) + .then((bookshelfUser) => _toDomain(bookshelfUser)) + .catch((err) => { + if (err instanceof BookshelfUser.NoRowsUpdatedError) { + throw new UserNotFoundError(`User not found for ID ${id}`); } throw err; + }); +}; + +const updateUserDetailsForAdministration = async function ({ + id, + userAttributes, + domainTransaction = DomainTransaction.emptyTransaction(), +}) { + try { + const knexConn = domainTransaction.knexTransaction ?? knex; + const [userDTO] = await knexConn('users').where({ id }).update(userAttributes).returning('*'); + + if (!userDTO) { + throw new UserNotFoundError(`User not found for ID ${id}`); } - }, - - async updateHasSeenAssessmentInstructionsToTrue(id) { - const user = await BookshelfUser.where({ id }).fetch({ require: false }); - await user.save({ hasSeenAssessmentInstructions: true }, { patch: true, method: 'update' }); - return bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user); - }, - - async updateHasSeenNewDashboardInfoToTrue(id) { - const user = await BookshelfUser.where({ id }).fetch({ require: false }); - await user.save({ hasSeenNewDashboardInfo: true }, { patch: true, method: 'update' }); - return bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user); - }, - - async updateHasSeenChallengeTooltip({ userId, challengeType }) { - const user = await BookshelfUser.where({ id: userId }).fetch({ require: false }); - if (challengeType === 'focused') { - await user.save({ hasSeenFocusedChallengeTooltip: true }, { patch: true, method: 'update' }); - } - if (challengeType === 'other') { - await user.save({ hasSeenOtherChallengesTooltip: true }, { patch: true, method: 'update' }); + } catch (err) { + if (isUniqConstraintViolated(err)) { + throw new AlreadyExistingEntityError('Cette adresse e-mail ou cet identifiant est déjà utilisé(e).'); } - return bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user); - }, + throw err; + } +}; + +const updateHasSeenAssessmentInstructionsToTrue = async function (id) { + const user = await BookshelfUser.where({ id }).fetch({ require: false }); + await user.save({ hasSeenAssessmentInstructions: true }, { patch: true, method: 'update' }); + return bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user); +}; + +const updateHasSeenNewDashboardInfoToTrue = async function (id) { + const user = await BookshelfUser.where({ id }).fetch({ require: false }); + await user.save({ hasSeenNewDashboardInfo: true }, { patch: true, method: 'update' }); + return bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user); +}; + +const updateHasSeenChallengeTooltip = async function ({ userId, challengeType }) { + const user = await BookshelfUser.where({ id: userId }).fetch({ require: false }); + if (challengeType === 'focused') { + await user.save({ hasSeenFocusedChallengeTooltip: true }, { patch: true, method: 'update' }); + } + if (challengeType === 'other') { + await user.save({ hasSeenOtherChallengesTooltip: true }, { patch: true, method: 'update' }); + } + return bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user); +}; + +const acceptPixLastTermsOfService = async function (id) { + const user = await BookshelfUser.where({ id }).fetch({ require: false }); + await user.save( + { + lastTermsOfServiceValidatedAt: moment().toDate(), + mustValidateTermsOfService: false, + }, + { patch: true, method: 'update' } + ); + return bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user); +}; + +const updatePixOrgaTermsOfServiceAcceptedToTrue = async function (id) { + const now = new Date(); + + const [user] = await knex('users') + .where({ id }) + .update({ pixOrgaTermsOfServiceAccepted: true, lastPixOrgaTermsOfServiceValidatedAt: now, updatedAt: now }) + .returning('*'); + + return new User(user); +}; + +const updatePixCertifTermsOfServiceAcceptedToTrue = async function (id) { + const now = new Date(); + + const [user] = await knex('users') + .where({ id }) + .update({ pixCertifTermsOfServiceAccepted: true, lastPixCertifTermsOfServiceValidatedAt: now, updatedAt: now }) + .returning('*'); + + return new User(user); +}; - async acceptPixLastTermsOfService(id) { - const user = await BookshelfUser.where({ id }).fetch({ require: false }); - await user.save( +const isUsernameAvailable = async function (username) { + const foundUser = await BookshelfUser.where({ username }).fetch({ require: false }); + if (foundUser) { + throw new AlreadyRegisteredUsernameError(); + } + return username; +}; + +const updateUsername = function ({ id, username, domainTransaction = DomainTransaction.emptyTransaction() }) { + return BookshelfUser.where({ id }) + .save( + { username }, { - lastTermsOfServiceValidatedAt: moment().toDate(), - mustValidateTermsOfService: false, - }, - { patch: true, method: 'update' } - ); - return bookshelfToDomainConverter.buildDomainObject(BookshelfUser, user); - }, - - async updatePixOrgaTermsOfServiceAcceptedToTrue(id) { - const now = new Date(); - - const [user] = await knex('users') - .where({ id }) - .update({ pixOrgaTermsOfServiceAccepted: true, lastPixOrgaTermsOfServiceValidatedAt: now, updatedAt: now }) - .returning('*'); - - return new User(user); - }, - - async updatePixCertifTermsOfServiceAcceptedToTrue(id) { - const now = new Date(); - - const [user] = await knex('users') - .where({ id }) - .update({ pixCertifTermsOfServiceAccepted: true, lastPixCertifTermsOfServiceValidatedAt: now, updatedAt: now }) - .returning('*'); - - return new User(user); - }, - - async isUsernameAvailable(username) { - const foundUser = await BookshelfUser.where({ username }).fetch({ require: false }); - if (foundUser) { - throw new AlreadyRegisteredUsernameError(); - } - return username; - }, - - updateUsername({ id, username, domainTransaction = DomainTransaction.emptyTransaction() }) { - return BookshelfUser.where({ id }) - .save( - { username }, - { - transacting: domainTransaction.knexTransaction, - patch: true, - method: 'update', - } - ) - .then((bookshelfUser) => _toDomain(bookshelfUser)) - .catch((err) => { - if (err instanceof BookshelfUser.NoRowsUpdatedError) { - throw new UserNotFoundError(`User not found for ID ${id}`); - } - throw err; - }); - }, - - addUsername(id, username) { - return BookshelfUser.where({ id }) - .save({ username }, { patch: true, method: 'update' }) - .then((bookshelfUser) => _toDomain(bookshelfUser)) - .catch((err) => { - if (err instanceof BookshelfUser.NoRowsUpdatedError) { - throw new UserNotFoundError(`User not found for ID ${id}`); - } - throw err; - }); - }, - - async findByExternalIdentifier({ externalIdentityId, identityProvider }) { - const bookshelfUser = await BookshelfUser.query((qb) => { - qb.innerJoin('authentication-methods', function () { - this.on('users.id', 'authentication-methods.userId') - .andOnVal('authentication-methods.identityProvider', identityProvider) - .andOnVal('authentication-methods.externalIdentifier', externalIdentityId); - }); - }).fetch({ require: false, withRelated: 'authenticationMethods' }); - return bookshelfUser ? _toDomain(bookshelfUser) : null; - }, - - async findAnotherUserByEmail(userId, email) { - return BookshelfUser.where('id', '!=', userId) - .where({ email: email.toLowerCase() }) - .fetchAll() - .then((users) => bookshelfToDomainConverter.buildDomainObjects(BookshelfUser, users)); - }, - - async findAnotherUserByUsername(userId, username) { - return BookshelfUser.where('id', '!=', userId) - .where({ username }) - .fetchAll() - .then((users) => bookshelfToDomainConverter.buildDomainObjects(BookshelfUser, users)); - }, - - async updateLastLoggedAt({ userId }) { - const now = new Date(); - - await knex('users').where({ id: userId }).update({ lastLoggedAt: now }); - }, - - async updateLastDataProtectionPolicySeenAt({ userId }) { - const now = new Date(); - - const [user] = await knex('users') - .where({ id: userId }) - .update({ lastDataProtectionPolicySeenAt: now }) - .returning('*'); - - return new User(user); - }, + transacting: domainTransaction.knexTransaction, + patch: true, + method: 'update', + } + ) + .then((bookshelfUser) => _toDomain(bookshelfUser)) + .catch((err) => { + if (err instanceof BookshelfUser.NoRowsUpdatedError) { + throw new UserNotFoundError(`User not found for ID ${id}`); + } + throw err; + }); +}; + +const addUsername = function (id, username) { + return BookshelfUser.where({ id }) + .save({ username }, { patch: true, method: 'update' }) + .then((bookshelfUser) => _toDomain(bookshelfUser)) + .catch((err) => { + if (err instanceof BookshelfUser.NoRowsUpdatedError) { + throw new UserNotFoundError(`User not found for ID ${id}`); + } + throw err; + }); +}; + +const findByExternalIdentifier = async function ({ externalIdentityId, identityProvider }) { + const bookshelfUser = await BookshelfUser.query((qb) => { + qb.innerJoin('authentication-methods', function () { + this.on('users.id', 'authentication-methods.userId') + .andOnVal('authentication-methods.identityProvider', identityProvider) + .andOnVal('authentication-methods.externalIdentifier', externalIdentityId); + }); + }).fetch({ require: false, withRelated: 'authenticationMethods' }); + return bookshelfUser ? _toDomain(bookshelfUser) : null; +}; + +const findAnotherUserByEmail = async function (userId, email) { + return BookshelfUser.where('id', '!=', userId) + .where({ email: email.toLowerCase() }) + .fetchAll() + .then((users) => bookshelfToDomainConverter.buildDomainObjects(BookshelfUser, users)); +}; + +const findAnotherUserByUsername = async function (userId, username) { + return BookshelfUser.where('id', '!=', userId) + .where({ username }) + .fetchAll() + .then((users) => bookshelfToDomainConverter.buildDomainObjects(BookshelfUser, users)); +}; + +const updateLastLoggedAt = async function ({ userId }) { + const now = new Date(); + + await knex('users').where({ id: userId }).update({ lastLoggedAt: now }); +}; + +const updateLastDataProtectionPolicySeenAt = async function ({ userId }) { + const now = new Date(); + + const [user] = await knex('users') + .where({ id: userId }) + .update({ lastDataProtectionPolicySeenAt: now }) + .returning('*'); + + return new User(user); +}; + +export { + getByEmail, + getFullById, + getByUsernameOrEmailWithRolesAndPassword, + get, + getById, + getForObfuscation, + getUserDetailsForAdmin, + findPaginatedFiltered, + getWithMemberships, + getWithCertificationCenterMemberships, + getBySamlId, + update, + updateWithEmailConfirmed, + checkIfEmailIsAvailable, + isUserExistingByEmail, + updatePassword, + updateEmail, + updateUserDetailsForAdministration, + updateHasSeenAssessmentInstructionsToTrue, + updateHasSeenNewDashboardInfoToTrue, + updateHasSeenChallengeTooltip, + acceptPixLastTermsOfService, + updatePixOrgaTermsOfServiceAcceptedToTrue, + updatePixCertifTermsOfServiceAcceptedToTrue, + isUsernameAvailable, + updateUsername, + addUsername, + findByExternalIdentifier, + findAnotherUserByEmail, + findAnotherUserByUsername, + updateLastLoggedAt, + updateLastDataProtectionPolicySeenAt, }; function _fromKnexDTOToUserDetailsForAdmin({ userDTO, organizationLearnersDTO, authenticationMethodsDTO }) { diff --git a/api/lib/infrastructure/repositories/user-saved-tutorial-repository.js b/api/lib/infrastructure/repositories/user-saved-tutorial-repository.js index 738cc8fea71..0a3905ca52b 100644 --- a/api/lib/infrastructure/repositories/user-saved-tutorial-repository.js +++ b/api/lib/infrastructure/repositories/user-saved-tutorial-repository.js @@ -1,28 +1,28 @@ -const { knex } = require('../../../db/knex-database-connection.js'); -const UserSavedTutorial = require('../../domain/models/UserSavedTutorial.js'); +import { knex } from '../../../db/knex-database-connection.js'; +import { UserSavedTutorial } from '../../domain/models/UserSavedTutorial.js'; const TABLE_NAME = 'user-saved-tutorials'; -module.exports = { - async addTutorial({ userId, tutorialId, skillId }) { - const userSavedTutorials = await knex(TABLE_NAME).where({ userId, tutorialId }); - if (userSavedTutorials.length) { - return _toDomain(userSavedTutorials[0]); - } - const savedUserSavedTutorials = await knex(TABLE_NAME).insert({ userId, tutorialId, skillId }).returning('*'); - return _toDomain(savedUserSavedTutorials[0]); - }, +const addTutorial = async function ({ userId, tutorialId, skillId }) { + const userSavedTutorials = await knex(TABLE_NAME).where({ userId, tutorialId }); + if (userSavedTutorials.length) { + return _toDomain(userSavedTutorials[0]); + } + const savedUserSavedTutorials = await knex(TABLE_NAME).insert({ userId, tutorialId, skillId }).returning('*'); + return _toDomain(savedUserSavedTutorials[0]); +}; - async find({ userId }) { - const userSavedTutorials = await knex(TABLE_NAME).where({ userId }).orderBy('createdAt', 'desc'); - return userSavedTutorials.map(_toDomain); - }, +const find = async function ({ userId }) { + const userSavedTutorials = await knex(TABLE_NAME).where({ userId }).orderBy('createdAt', 'desc'); + return userSavedTutorials.map(_toDomain); +}; - async removeFromUser(userSavedTutorial) { - return knex(TABLE_NAME).where(userSavedTutorial).delete(); - }, +const removeFromUser = async function (userSavedTutorial) { + return knex(TABLE_NAME).where(userSavedTutorial).delete(); }; +export { addTutorial, find, removeFromUser }; + function _toDomain(userSavedTutorial) { return new UserSavedTutorial({ id: userSavedTutorial.id, diff --git a/api/lib/infrastructure/repositories/user-to-create-repository.js b/api/lib/infrastructure/repositories/user-to-create-repository.js index cc5c7ddb695..c4e23c4486b 100644 --- a/api/lib/infrastructure/repositories/user-to-create-repository.js +++ b/api/lib/infrastructure/repositories/user-to-create-repository.js @@ -1,25 +1,22 @@ -const { knex } = require('../../../db/knex-database-connection.js'); - -const DomainTransaction = require('../DomainTransaction.js'); - -const { OrganizationLearnerAlreadyLinkedToUserError } = require('../../domain/errors.js'); -const { STUDENT_RECONCILIATION_ERRORS } = require('../../domain/constants.js'); - -const User = require('../../domain/models/User.js'); -const { PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR } = require('../../../db/pgsql-errors.js'); - -module.exports = { - async create({ user, domainTransaction = DomainTransaction.emptyTransaction() }) { - const knexConnection = domainTransaction.knexTransaction || knex; - - if (user.username) { - return await _createWithUsername({ knexConnection, user }); - } else { - return await _createWithoutUsername({ knexConnection, user }); - } - }, +import { knex } from '../../../db/knex-database-connection.js'; +import { DomainTransaction } from '../DomainTransaction.js'; +import { OrganizationLearnerAlreadyLinkedToUserError } from '../../domain/errors.js'; +import { STUDENT_RECONCILIATION_ERRORS } from '../../domain/constants.js'; +import { User } from '../../domain/models/User.js'; +import { PGSQL_UNIQUE_CONSTRAINT_VIOLATION_ERROR } from '../../../db/pgsql-errors.js'; + +const create = async function ({ user, domainTransaction = DomainTransaction.emptyTransaction() }) { + const knexConnection = domainTransaction.knexTransaction || knex; + + if (user.username) { + return await _createWithUsername({ knexConnection, user }); + } else { + return await _createWithoutUsername({ knexConnection, user }); + } }; +export { create }; + async function _createWithUsername({ knexConnection, user }) { const detail = 'Un compte avec cet identifiant existe déjà.'; const error = STUDENT_RECONCILIATION_ERRORS.LOGIN_OR_REGISTER.IN_DB.username; diff --git a/api/lib/infrastructure/saml.js b/api/lib/infrastructure/saml.js index 12a5824849a..bff4b4b89f5 100644 --- a/api/lib/infrastructure/saml.js +++ b/api/lib/infrastructure/saml.js @@ -1,11 +1,13 @@ -const samlify = require('samlify'); +import samlify from 'samlify'; samlify.setSchemaValidator({ validate: () => { return true; }, }); -const logger = require('./logger.js'); -const samlSettings = require('../config.js').saml; +import { logger } from './logger.js'; +import { config } from '../config.js'; + +const samlSettings = config.saml; let _serviceProvider, _identityProvider; @@ -35,23 +37,23 @@ function _getIdentityProvider() { return _identityProvider; } -module.exports = { - getServiceProviderMetadata() { - return _getServiceProvider().getMetadata(); - }, +const getServiceProviderMetadata = function () { + return _getServiceProvider().getMetadata(); +}; - createLoginRequest() { - const { context } = _getServiceProvider().createLoginRequest(_getIdentityProvider(), 'redirect'); - logger.trace({ SAMLRequest: context }, 'Created SAML request'); - return context; - }, +const createLoginRequest = function () { + const { context } = _getServiceProvider().createLoginRequest(_getIdentityProvider(), 'redirect'); + logger.trace({ SAMLRequest: context }, 'Created SAML request'); + return context; +}; - async parsePostResponse(payload) { - logger.trace({ SAMLPayload: payload }, 'Parsing SAML response'); - const { extract } = await _getServiceProvider().parseLoginResponse(_getIdentityProvider(), 'post', { - body: payload, - }); - logger.trace({ parsedSAML: extract }, 'Parsed SAML response'); - return extract.attributes; - }, +const parsePostResponse = async function (payload) { + logger.trace({ SAMLPayload: payload }, 'Parsing SAML response'); + const { extract } = await _getServiceProvider().parseLoginResponse(_getIdentityProvider(), 'post', { + body: payload, + }); + logger.trace({ parsedSAML: extract }, 'Parsed SAML response'); + return extract.attributes; }; + +export { getServiceProviderMetadata, createLoginRequest, parsePostResponse }; diff --git a/api/lib/infrastructure/serializers/csv/campaign-profiles-collection-export.js b/api/lib/infrastructure/serializers/csv/campaign-profiles-collection-export.js index ab77ad22073..2373cb4d10a 100644 --- a/api/lib/infrastructure/serializers/csv/campaign-profiles-collection-export.js +++ b/api/lib/infrastructure/serializers/csv/campaign-profiles-collection-export.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const bluebird = require('bluebird'); -const csvSerializer = require('./csv-serializer.js'); -const { constants } = require('../../constants.js'); -const CampaignProfilesCollectionResultLine = require('../../exports/campaigns/campaign-profiles-collection-result-line.js'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import * as csvSerializer from './csv-serializer.js'; +import { CONCURRENCY_HEAVY_OPERATIONS, CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING } from '../../constants.js'; +import { CampaignProfilesCollectionResultLine } from '../../exports/campaigns/campaign-profiles-collection-result-line.js'; class CampaignProfilesCollectionExport { constructor(outputStream, organization, campaign, competences, translate) { this.stream = outputStream; @@ -21,7 +21,7 @@ class CampaignProfilesCollectionExport { const campaignParticipationResultDataChunks = _.chunk( campaignParticipationResultDatas, - constants.CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING + CHUNK_SIZE_CAMPAIGN_RESULT_PROCESSING ); return bluebird.map( @@ -35,7 +35,7 @@ class CampaignProfilesCollectionExport { this.stream.write(csvLines); }, - { concurrency: constants.CONCURRENCY_HEAVY_OPERATIONS } + { concurrency: CONCURRENCY_HEAVY_OPERATIONS } ); } @@ -106,4 +106,4 @@ class CampaignProfilesCollectionExport { } } -module.exports = CampaignProfilesCollectionExport; +export { CampaignProfilesCollectionExport }; diff --git a/api/lib/infrastructure/serializers/csv/campaigns-administration/campaign-ids-csv-header.js b/api/lib/infrastructure/serializers/csv/campaigns-administration/campaign-ids-csv-header.js index 4fad0dbb694..50ce114ea29 100644 --- a/api/lib/infrastructure/serializers/csv/campaigns-administration/campaign-ids-csv-header.js +++ b/api/lib/infrastructure/serializers/csv/campaigns-administration/campaign-ids-csv-header.js @@ -1,4 +1,4 @@ -const { CsvColumn } = require('../csv-column.js'); +import { CsvColumn } from '../csv-column.js'; class CampaignIdsCsvHeader { constructor() { @@ -16,4 +16,4 @@ class CampaignIdsCsvHeader { } } -module.exports = CampaignIdsCsvHeader; +export { CampaignIdsCsvHeader }; diff --git a/api/lib/infrastructure/serializers/csv/campaigns-administration/csv-campaigns-ids-parser.js b/api/lib/infrastructure/serializers/csv/campaigns-administration/csv-campaigns-ids-parser.js index 63564c8faa3..f7b663da692 100644 --- a/api/lib/infrastructure/serializers/csv/campaigns-administration/csv-campaigns-ids-parser.js +++ b/api/lib/infrastructure/serializers/csv/campaigns-administration/csv-campaigns-ids-parser.js @@ -1,6 +1,7 @@ -const fs = require('fs').promises; -const { CsvParser } = require('../csv-parser.js'); -const ArchiveCampaignColumn = require('./campaign-ids-csv-header.js'); +import * as fs from 'fs/promises'; + +import { CsvParser } from '../csv-parser.js'; +import { CampaignIdsCsvHeader } from './campaign-ids-csv-header.js'; async function extractCampaignsIds(file) { const buffer = await fs.readFile(file); @@ -16,10 +17,8 @@ async function extractCampaignsIds(file) { } function _extractIds(buffer) { - const columns = new ArchiveCampaignColumn(); + const columns = new CampaignIdsCsvHeader(); const campaignIdsCsv = new CsvParser(buffer, columns); return campaignIdsCsv.parse(); } -module.exports = { - extractCampaignsIds, -}; +export { extractCampaignsIds }; diff --git a/api/lib/infrastructure/serializers/csv/csv-column.js b/api/lib/infrastructure/serializers/csv/csv-column.js index b771df1a279..542f1571563 100644 --- a/api/lib/infrastructure/serializers/csv/csv-column.js +++ b/api/lib/infrastructure/serializers/csv/csv-column.js @@ -8,6 +8,4 @@ class CsvColumn { } } -module.exports = { - CsvColumn, -}; +export { CsvColumn }; diff --git a/api/lib/infrastructure/serializers/csv/csv-learner-parser.js b/api/lib/infrastructure/serializers/csv/csv-learner-parser.js index 48236df67a0..7c0f085c518 100644 --- a/api/lib/infrastructure/serializers/csv/csv-learner-parser.js +++ b/api/lib/infrastructure/serializers/csv/csv-learner-parser.js @@ -1,7 +1,7 @@ -const papa = require('papaparse'); -const iconv = require('iconv-lite'); -const { convertDateValue } = require('../../utils/date-utils.js'); -const { CsvImportError } = require('../../../domain/errors.js'); +import papa from 'papaparse'; +import iconv from 'iconv-lite'; +import { convertDateValue } from '../../utils/date-utils.js'; +import { CsvImportError } from '../../../domain/errors.js'; const ERRORS = { ENCODING_NOT_SUPPORTED: 'ENCODING_NOT_SUPPORTED', @@ -184,6 +184,4 @@ function _atLeastOneParsedColumnDoesNotMatchAcceptedColumns(parsedColumns, accep }); } -module.exports = { - CsvOrganizationLearnerParser, -}; +export { CsvOrganizationLearnerParser }; diff --git a/api/lib/infrastructure/serializers/csv/csv-parser.js b/api/lib/infrastructure/serializers/csv/csv-parser.js index 536ad75ec92..54e588f26b1 100644 --- a/api/lib/infrastructure/serializers/csv/csv-parser.js +++ b/api/lib/infrastructure/serializers/csv/csv-parser.js @@ -1,6 +1,6 @@ -const papa = require('papaparse'); -const iconv = require('iconv-lite'); -const { CsvImportError } = require('../../../domain/errors.js'); +import papa from 'papaparse'; +import iconv from 'iconv-lite'; +import { CsvImportError } from '../../../domain/errors.js'; const ERRORS = { ENCODING_NOT_SUPPORTED: 'ENCODING_NOT_SUPPORTED', BAD_CSV_FORMAT: 'BAD_CSV_FORMAT', @@ -119,6 +119,4 @@ function _atLeastOneParsedColumnDoesNotMatchAcceptedColumns(parsedColumns, accep }); } -module.exports = { - CsvParser, -}; +export { CsvParser }; diff --git a/api/lib/infrastructure/serializers/csv/csv-serializer.js b/api/lib/infrastructure/serializers/csv/csv-serializer.js index ebdd0bc01be..beb5eeb6bef 100644 --- a/api/lib/infrastructure/serializers/csv/csv-serializer.js +++ b/api/lib/infrastructure/serializers/csv/csv-serializer.js @@ -1,9 +1,12 @@ -const logger = require('../../logger.js'); -const { FileValidationError } = require('../../../../lib/domain/errors.js'); -const { convertDateValue } = require('../../utils/date-utils.js'); -const { headers, emptySession, COMPLEMENTARY_CERTIFICATION_SUFFIX } = require('../../utils/csv/sessions-import.js'); -const { isEmpty } = require('lodash'); -const { checkCsvHeader, parseCsvWithHeader } = require('../../helpers/csv.js'); +import { logger } from '../../logger.js'; +import { FileValidationError } from '../../../../lib/domain/errors.js'; +import { convertDateValue } from '../../utils/date-utils.js'; +import { headers, emptySession, COMPLEMENTARY_CERTIFICATION_SUFFIX } from '../../utils/csv/sessions-import.js'; +import lodash from 'lodash'; + +const { isEmpty } = lodash; + +import { checkCsvHeader, parseCsvWithHeader } from '../../helpers/csv.js'; function _csvFormulaEscapingPrefix(data) { const mayBeInterpretedAsFormula = /^[-@=+]/.test(data); @@ -337,8 +340,4 @@ function serializeLine(lineArray) { return lineArray.map(_csvSerializeValue).join(';') + '\n'; } -module.exports = { - serializeLine, - deserializeForSessionsImport, - deserializeForOrganizationsImport, -}; +export { serializeLine, deserializeForSessionsImport, deserializeForOrganizationsImport }; diff --git a/api/lib/infrastructure/serializers/csv/organization-learner-import-header.js b/api/lib/infrastructure/serializers/csv/organization-learner-import-header.js index 36a450c5796..aa9d458cc37 100644 --- a/api/lib/infrastructure/serializers/csv/organization-learner-import-header.js +++ b/api/lib/infrastructure/serializers/csv/organization-learner-import-header.js @@ -1,4 +1,4 @@ -const { CsvColumn } = require('./csv-column.js'); +import { CsvColumn } from './csv-column.js'; class OrganizationLearnerImportHeader { constructor(i18n) { @@ -75,4 +75,4 @@ class OrganizationLearnerImportHeader { } } -module.exports = OrganizationLearnerImportHeader; +export { OrganizationLearnerImportHeader }; diff --git a/api/lib/infrastructure/serializers/csv/organization-learner-parser.js b/api/lib/infrastructure/serializers/csv/organization-learner-parser.js index 182317f7527..feb4ffce125 100644 --- a/api/lib/infrastructure/serializers/csv/organization-learner-parser.js +++ b/api/lib/infrastructure/serializers/csv/organization-learner-parser.js @@ -1,9 +1,8 @@ -const OrganizationLearner = require('../../../domain/models/OrganizationLearner.js'); -const { checkValidation } = require('../../../domain/validators/organization-learner-validator.js'); - -const { CsvOrganizationLearnerParser } = require('./csv-learner-parser.js'); -const { CsvImportError, DomainError } = require('../../../domain/errors.js'); -const OrganizationLearnerImportHeader = require('./organization-learner-import-header.js'); +import { OrganizationLearner } from '../../../domain/models/OrganizationLearner.js'; +import { checkValidation } from '../../../domain/validators/organization-learner-validator.js'; +import { CsvOrganizationLearnerParser } from './csv-learner-parser.js'; +import { CsvImportError, DomainError } from '../../../domain/errors.js'; +import { OrganizationLearnerImportHeader } from './organization-learner-import-header.js'; const ERRORS = { IDENTIFIER_UNIQUE: 'IDENTIFIER_UNIQUE', @@ -91,4 +90,4 @@ class OrganizationLearnerParser extends CsvOrganizationLearnerParser { } } -module.exports = OrganizationLearnerParser; +export { OrganizationLearnerParser }; diff --git a/api/lib/infrastructure/serializers/csv/sup-organization-learner-import-header.js b/api/lib/infrastructure/serializers/csv/sup-organization-learner-import-header.js index 9346bacc59d..55965ffd16f 100644 --- a/api/lib/infrastructure/serializers/csv/sup-organization-learner-import-header.js +++ b/api/lib/infrastructure/serializers/csv/sup-organization-learner-import-header.js @@ -1,4 +1,4 @@ -const { CsvColumn } = require('./csv-column.js'); +import { CsvColumn } from './csv-column.js'; class SupOrganizationLearnerImportHeader { constructor(i18n) { @@ -62,4 +62,4 @@ class SupOrganizationLearnerImportHeader { } } -module.exports = SupOrganizationLearnerImportHeader; +export { SupOrganizationLearnerImportHeader }; diff --git a/api/lib/infrastructure/serializers/csv/sup-organization-learner-parser.js b/api/lib/infrastructure/serializers/csv/sup-organization-learner-parser.js index 2638a9962f6..8edb8656309 100644 --- a/api/lib/infrastructure/serializers/csv/sup-organization-learner-parser.js +++ b/api/lib/infrastructure/serializers/csv/sup-organization-learner-parser.js @@ -1,8 +1,7 @@ -const SupOrganizationLearnerSet = require('../../../domain/models/SupOrganizationLearnerSet.js'); -const { CsvImportError } = require('../../../domain/errors.js'); - -const { CsvOrganizationLearnerParser } = require('./csv-learner-parser.js'); -const SupOrganizationLearnerImportHeader = require('./sup-organization-learner-import-header.js'); +import { SupOrganizationLearnerSet } from '../../../domain/models/SupOrganizationLearnerSet.js'; +import { CsvImportError } from '../../../domain/errors.js'; +import { CsvOrganizationLearnerParser } from './csv-learner-parser.js'; +import { SupOrganizationLearnerImportHeader } from './sup-organization-learner-import-header.js'; const ERRORS = { STUDENT_NUMBER_UNIQUE: 'STUDENT_NUMBER_UNIQUE', @@ -32,4 +31,4 @@ class SupOrganizationLearnerParser extends CsvOrganizationLearnerParser { } } -module.exports = SupOrganizationLearnerParser; +export { SupOrganizationLearnerParser }; diff --git a/api/lib/infrastructure/serializers/json/scoring-simulator/scoring-simulation-context-serializer.js b/api/lib/infrastructure/serializers/json/scoring-simulator/scoring-simulation-context-serializer.js index 34c16cb1461..4d2e008ef60 100644 --- a/api/lib/infrastructure/serializers/json/scoring-simulator/scoring-simulation-context-serializer.js +++ b/api/lib/infrastructure/serializers/json/scoring-simulator/scoring-simulation-context-serializer.js @@ -1,7 +1,7 @@ -const ScoringSimulationContext = require('../../../../domain/models/ScoringSimulationContext.js'); +import { ScoringSimulationContext } from '../../../../domain/models/ScoringSimulationContext.js'; -module.exports = { - deserialize(request) { - return new ScoringSimulationContext(request.payload.context); - }, +const deserialize = function (request) { + return new ScoringSimulationContext(request.payload.context); }; + +export { deserialize }; diff --git a/api/lib/infrastructure/serializers/json/scoring-simulator/scoring-simulation-dataset-serializer.js b/api/lib/infrastructure/serializers/json/scoring-simulator/scoring-simulation-dataset-serializer.js index f26a3728719..55e064d8938 100644 --- a/api/lib/infrastructure/serializers/json/scoring-simulator/scoring-simulation-dataset-serializer.js +++ b/api/lib/infrastructure/serializers/json/scoring-simulator/scoring-simulation-dataset-serializer.js @@ -1,20 +1,20 @@ -const ScoringSimulation = require('../../../../domain/models/ScoringSimulation.js'); -const ScoringSimulationDataset = require('../../../../domain/models/ScoringSimulationDataset.js'); -const Answer = require('../../../../domain/models/Answer.js'); +import { ScoringSimulation } from '../../../../domain/models/ScoringSimulation.js'; +import { ScoringSimulationDataset } from '../../../../domain/models/ScoringSimulationDataset.js'; +import { Answer } from '../../../../domain/models/Answer.js'; -module.exports = { - deserialize(request) { - const simulations = request.payload.dataset.simulations.map( - (simulation) => - new ScoringSimulation({ - ...simulation, - answers: simulation.answers?.map((answer) => new Answer(answer)), - }) - ); +const deserialize = function (request) { + const simulations = request.payload.dataset.simulations.map( + (simulation) => + new ScoringSimulation({ + ...simulation, + answers: simulation.answers?.map((answer) => new Answer(answer)), + }) + ); - return new ScoringSimulationDataset({ - ...request.payload.dataset, - simulations, - }); - }, + return new ScoringSimulationDataset({ + ...request.payload.dataset, + simulations, + }); }; + +export { deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/admin-member-serializer.js b/api/lib/infrastructure/serializers/jsonapi/admin-member-serializer.js index 0c3f1dd5acb..a9b24fa2406 100644 --- a/api/lib/infrastructure/serializers/jsonapi/admin-member-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/admin-member-serializer.js @@ -1,25 +1,27 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(adminMembers, meta) { - return new Serializer('admin-member', { - attributes: [ - 'firstName', - 'lastName', - 'email', - 'role', - 'userId', - 'isSuperAdmin', - 'isCertif', - 'isMetier', - 'isSupport', - ], - meta, - }).serialize(adminMembers); - }, +const { Serializer, Deserializer } = jsonapiSerializer; - async deserialize(jsonApiData) { - const deserializer = new Deserializer({ keyForAttribute: 'camelCase' }); - return await deserializer.deserialize(jsonApiData); - }, +const serialize = function (adminMembers, meta) { + return new Serializer('admin-member', { + attributes: [ + 'firstName', + 'lastName', + 'email', + 'role', + 'userId', + 'isSuperAdmin', + 'isCertif', + 'isMetier', + 'isSupport', + ], + meta, + }).serialize(adminMembers); }; + +const deserialize = async function (jsonApiData) { + const deserializer = new Deserializer({ keyForAttribute: 'camelCase' }); + return await deserializer.deserialize(jsonApiData); +}; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/answer-pix1d-serializer.js b/api/lib/infrastructure/serializers/jsonapi/answer-pix1d-serializer.js index 3fa7c1d1cd6..273372e6ab4 100644 --- a/api/lib/infrastructure/serializers/jsonapi/answer-pix1d-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/answer-pix1d-serializer.js @@ -1,55 +1,55 @@ -const Answer = require('../../../domain/models/Answer.js'); -const { Serializer } = require('jsonapi-serializer'); -const answerStatusJSONAPIAdapter = require('../../adapters/answer-status-json-api-adapter.js'); +import { Answer } from '../../../domain/models/Answer.js'; +import { Serializer } from 'jsonapi-serializer'; +import { AnswerStatusJsonApiAdapter as answerStatusJSONAPIAdapter } from '../../adapters/answer-status-json-api-adapter.js'; -module.exports = { - serialize(answer) { - return new Serializer('answer', { - transform: (untouchedAnswer) => { - const answer = Object.assign({}, untouchedAnswer); - answer.assessment = { id: answer.assessmentId }; - answer.challenge = { id: answer.challengeId }; - answer.result = answerStatusJSONAPIAdapter.adapt(untouchedAnswer.result); - return answer; - }, - attributes: ['value', 'timeout', 'result', 'resultDetails', 'assessment', 'challenge', 'correction', 'levelup'], - assessment: { - ref: 'id', - includes: false, - }, - challenge: { - ref: 'id', - includes: false, - }, - correction: { - ref: 'id', - nullIfMissing: true, - ignoreRelationshipData: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/answers/${parent.id}/correction`; - }, +const serialize = function (answer) { + return new Serializer('answer', { + transform: (untouchedAnswer) => { + const answer = Object.assign({}, untouchedAnswer); + answer.assessment = { id: answer.assessmentId }; + answer.challenge = { id: answer.challengeId }; + answer.result = answerStatusJSONAPIAdapter.adapt(untouchedAnswer.result); + return answer; + }, + attributes: ['value', 'timeout', 'result', 'resultDetails', 'assessment', 'challenge', 'correction', 'levelup'], + assessment: { + ref: 'id', + includes: false, + }, + challenge: { + ref: 'id', + includes: false, + }, + correction: { + ref: 'id', + nullIfMissing: true, + ignoreRelationshipData: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/answers/${parent.id}/correction`; }, }, - levelup: { - ref: 'id', - attributes: ['competenceName', 'level'], - }, - }).serialize(answer); - }, + }, + levelup: { + ref: 'id', + attributes: ['competenceName', 'level'], + }, + }).serialize(answer); +}; - deserialize(payload) { - return new Answer({ - value: _cleanValue(payload.data.attributes.value), - result: null, - resultDetails: null, - timeout: payload.data.attributes.timeout, - isFocusedOut: payload.data.attributes['focused-out'], - challengeId: payload.data.relationships.challenge.data.id, - }); - }, +const deserialize = function (payload) { + return new Answer({ + value: _cleanValue(payload.data.attributes.value), + result: null, + resultDetails: null, + timeout: payload.data.attributes.timeout, + isFocusedOut: payload.data.attributes['focused-out'], + challengeId: payload.data.relationships.challenge.data.id, + }); }; +export { serialize, deserialize }; + function _cleanValue(value) { return value.replaceAll('\u0000', ''); } diff --git a/api/lib/infrastructure/serializers/jsonapi/answer-serializer.js b/api/lib/infrastructure/serializers/jsonapi/answer-serializer.js index 86a8cecf27b..b1beca6ea6d 100644 --- a/api/lib/infrastructure/serializers/jsonapi/answer-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/answer-serializer.js @@ -1,56 +1,59 @@ -const Answer = require('../../../domain/models/Answer.js'); -const { Serializer } = require('jsonapi-serializer'); -const answerStatusJSONAPIAdapter = require('../../adapters/answer-status-json-api-adapter.js'); +import { Answer } from '../../../domain/models/Answer.js'; +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(answer) { - return new Serializer('answer', { - transform: (untouchedAnswer) => { - const answer = Object.assign({}, untouchedAnswer); - answer.assessment = { id: answer.assessmentId }; - answer.challenge = { id: answer.challengeId }; - answer.result = answerStatusJSONAPIAdapter.adapt(untouchedAnswer.result); - return answer; - }, - attributes: ['value', 'timeout', 'result', 'resultDetails', 'assessment', 'challenge', 'correction', 'levelup'], - assessment: { - ref: 'id', - includes: false, - }, - challenge: { - ref: 'id', - includes: false, - }, - correction: { - ref: 'id', - nullIfMissing: true, - ignoreRelationshipData: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/answers/${parent.id}/correction`; - }, +const { Serializer } = jsonapiSerializer; + +import { AnswerStatusJsonApiAdapter } from '../../adapters/answer-status-json-api-adapter.js'; + +const serialize = function (answer) { + return new Serializer('answer', { + transform: (untouchedAnswer) => { + const answer = Object.assign({}, untouchedAnswer); + answer.assessment = { id: answer.assessmentId }; + answer.challenge = { id: answer.challengeId }; + answer.result = AnswerStatusJsonApiAdapter.adapt(untouchedAnswer.result); + return answer; + }, + attributes: ['value', 'timeout', 'result', 'resultDetails', 'assessment', 'challenge', 'correction', 'levelup'], + assessment: { + ref: 'id', + includes: false, + }, + challenge: { + ref: 'id', + includes: false, + }, + correction: { + ref: 'id', + nullIfMissing: true, + ignoreRelationshipData: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/answers/${parent.id}/correction`; }, }, - levelup: { - ref: 'id', - attributes: ['competenceName', 'level'], - }, - }).serialize(answer); - }, + }, + levelup: { + ref: 'id', + attributes: ['competenceName', 'level'], + }, + }).serialize(answer); +}; - deserialize(payload) { - return new Answer({ - value: _cleanValue(payload.data.attributes.value), - result: null, - resultDetails: null, - timeout: payload.data.attributes.timeout, - isFocusedOut: payload.data.attributes['focused-out'], - assessmentId: payload.data.relationships.assessment.data.id, - challengeId: payload.data.relationships.challenge.data.id, - }); - }, +const deserialize = function (payload) { + return new Answer({ + value: _cleanValue(payload.data.attributes.value), + result: null, + resultDetails: null, + timeout: payload.data.attributes.timeout, + isFocusedOut: payload.data.attributes['focused-out'], + assessmentId: payload.data.relationships.assessment.data.id, + challengeId: payload.data.relationships.challenge.data.id, + }); }; +export { serialize, deserialize }; + function _cleanValue(value) { return value.replaceAll('\u0000', ''); } diff --git a/api/lib/infrastructure/serializers/jsonapi/assessment-serializer.js b/api/lib/infrastructure/serializers/jsonapi/assessment-serializer.js index b723e2e32e3..8bef05fe1e7 100644 --- a/api/lib/infrastructure/serializers/jsonapi/assessment-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/assessment-serializer.js @@ -1,103 +1,105 @@ -const Assessment = require('../../../domain/models/Assessment.js'); -const Progression = require('../../../domain/models/Progression.js'); -const { Serializer } = require('jsonapi-serializer'); +import { Assessment } from '../../../domain/models/Assessment.js'; +import { Progression } from '../../../domain/models/Progression.js'; +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(assessments) { - return new Serializer('assessment', { - transform(currentAssessment) { - const assessment = Object.assign({}, currentAssessment); +const { Serializer } = jsonapiSerializer; - // TODO: We can't use currentAssessment.isCertification() because - // this serializer is also used by model CampaignAssessment - assessment.certificationNumber = null; - if (currentAssessment.type === Assessment.types.CERTIFICATION) { - assessment.certificationNumber = currentAssessment.certificationCourseId; - assessment.certificationCourse = { id: currentAssessment.certificationCourseId }; - } +const serialize = function (assessments) { + return new Serializer('assessment', { + transform(currentAssessment) { + const assessment = Object.assign({}, currentAssessment); - // Same here for isForCampaign() and isCompetenceEvaluation() - if ([Assessment.types.CAMPAIGN, Assessment.types.COMPETENCE_EVALUATION].includes(currentAssessment.type)) { - assessment.progression = { - id: Progression.generateIdFromAssessmentId(currentAssessment.id), - }; - } + // TODO: We can't use currentAssessment.isCertification() because + // this serializer is also used by model CampaignAssessment + assessment.certificationNumber = null; + if (currentAssessment.type === Assessment.types.CERTIFICATION) { + assessment.certificationNumber = currentAssessment.certificationCourseId; + assessment.certificationCourse = { id: currentAssessment.certificationCourseId }; + } - if (currentAssessment.type === Assessment.types.CAMPAIGN) { - assessment.codeCampaign = currentAssessment.campaignCode; - } + // Same here for isForCampaign() and isCompetenceEvaluation() + if ([Assessment.types.CAMPAIGN, Assessment.types.COMPETENCE_EVALUATION].includes(currentAssessment.type)) { + assessment.progression = { + id: Progression.generateIdFromAssessmentId(currentAssessment.id), + }; + } - if (!currentAssessment.course) { - assessment.course = { id: currentAssessment.courseId }; - } + if (currentAssessment.type === Assessment.types.CAMPAIGN) { + assessment.codeCampaign = currentAssessment.campaignCode; + } - return assessment; - }, - attributes: [ - 'title', - 'type', - 'state', - 'answers', - 'codeCampaign', - 'certificationNumber', - 'course', - 'certificationCourse', - 'progression', - 'competenceId', - 'lastQuestionState', - 'method', - ], - answers: { - ref: 'id', - relationshipLinks: { - related(record) { - return `/api/answers?assessmentId=${record.id}`; - }, + if (!currentAssessment.course) { + assessment.course = { id: currentAssessment.courseId }; + } + + return assessment; + }, + attributes: [ + 'title', + 'type', + 'state', + 'answers', + 'codeCampaign', + 'certificationNumber', + 'course', + 'certificationCourse', + 'progression', + 'competenceId', + 'lastQuestionState', + 'method', + ], + answers: { + ref: 'id', + relationshipLinks: { + related(record) { + return `/api/answers?assessmentId=${record.id}`; }, }, - course: { - ref: 'id', - included: _includeCourse(assessments), - attributes: ['name', 'description', 'nbChallenges'], - }, - certificationCourse: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related(record, current) { - return `/api/certification-courses/${current.id}`; - }, + }, + course: { + ref: 'id', + included: _includeCourse(assessments), + attributes: ['name', 'description', 'nbChallenges'], + }, + certificationCourse: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related(record, current) { + return `/api/certification-courses/${current.id}`; }, }, - progression: { - ref: 'id', - relationshipLinks: { - related(record, current) { - return `/api/progressions/${current.id}`; - }, + }, + progression: { + ref: 'id', + relationshipLinks: { + related(record, current) { + return `/api/progressions/${current.id}`; }, }, - }).serialize(assessments); - }, + }, + }).serialize(assessments); +}; - deserialize(json) { - const type = json.data.attributes.type; - const method = Assessment.computeMethodFromType(type); +const deserialize = function (json) { + const type = json.data.attributes.type; + const method = Assessment.computeMethodFromType(type); - let courseId = null; - if (type !== Assessment.types.CAMPAIGN && type !== Assessment.types.PREVIEW) { - courseId = json.data.relationships.course.data.id; - } + let courseId = null; + if (type !== Assessment.types.CAMPAIGN && type !== Assessment.types.PREVIEW) { + courseId = json.data.relationships.course.data.id; + } - return new Assessment({ - id: json.data.id, - type, - courseId, - method, - }); - }, + return new Assessment({ + id: json.data.id, + type, + courseId, + method, + }); }; +export { serialize, deserialize }; + function _includeCourse(assessments) { if (Array.isArray(assessments)) { return assessments.length && assessments[0].course; diff --git a/api/lib/infrastructure/serializers/jsonapi/authentication-methods-serializer.js b/api/lib/infrastructure/serializers/jsonapi/authentication-methods-serializer.js index e9c0e1c6b3a..323413c3353 100644 --- a/api/lib/infrastructure/serializers/jsonapi/authentication-methods-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/authentication-methods-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(authenticationMethods) { - return new Serializer('authentication-methods', { - attributes: ['identityProvider'], - }).serialize(authenticationMethods); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (authenticationMethods) { + return new Serializer('authentication-methods', { + attributes: ['identityProvider'], + }).serialize(authenticationMethods); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/authentication-serializer.js b/api/lib/infrastructure/serializers/jsonapi/authentication-serializer.js index 38b98f2684e..8e1464b2a1e 100644 --- a/api/lib/infrastructure/serializers/jsonapi/authentication-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/authentication-serializer.js @@ -1,16 +1,18 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(authentications) { - return new Serializer('authentication', { - attributes: ['token', 'user_id', 'password'], - transform(model) { - const authentication = Object.assign({}, model.toJSON()); - authentication.user_id = model.userId.toString(); - authentication.id = model.userId; - authentication.password = ''; - return authentication; - }, - }).serialize(authentications); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (authentications) { + return new Serializer('authentication', { + attributes: ['token', 'user_id', 'password'], + transform(model) { + const authentication = Object.assign({}, model.toJSON()); + authentication.user_id = model.userId.toString(); + authentication.id = model.userId; + authentication.password = ''; + return authentication; + }, + }).serialize(authentications); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/badge-creation-serializer.js b/api/lib/infrastructure/serializers/jsonapi/badge-creation-serializer.js index 81708ffbb2d..c6ec99dd06c 100644 --- a/api/lib/infrastructure/serializers/jsonapi/badge-creation-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/badge-creation-serializer.js @@ -1,7 +1,9 @@ -const { Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Deserializer } = jsonapiSerializer; const deserializer = new Deserializer({ keyForAttribute: 'camelCase', }); -module.exports = deserializer; +export { deserializer }; diff --git a/api/lib/infrastructure/serializers/jsonapi/badge-criteria-serializer.js b/api/lib/infrastructure/serializers/jsonapi/badge-criteria-serializer.js index 8567a73a4d6..1b4e31adbf6 100644 --- a/api/lib/infrastructure/serializers/jsonapi/badge-criteria-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/badge-criteria-serializer.js @@ -1,9 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); -module.exports = { - serialize(badgeCriterion = {}) { - return new Serializer('badge-criteria', { - ref: 'id', - attributes: ['scope', 'threshold'], - }).serialize(badgeCriterion); - }, +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Serializer } = jsonapiSerializer; + +const serialize = function (badgeCriterion = {}) { + return new Serializer('badge-criteria', { + ref: 'id', + attributes: ['scope', 'threshold'], + }).serialize(badgeCriterion); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/badge-serializer.js b/api/lib/infrastructure/serializers/jsonapi/badge-serializer.js index 4c85006de32..df6c11a465a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/badge-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/badge-serializer.js @@ -1,22 +1,24 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(badge = {}) { - return new Serializer('badge', { - ref: 'id', - attributes: ['altMessage', 'imageUrl', 'message', 'key', 'title', 'isCertifiable', 'isAlwaysVisible'], - }).serialize(badge); - }, +const { Serializer } = jsonapiSerializer; - deserialize(json) { - return { - key: json.data.attributes['key'], - altMessage: json.data.attributes['alt-message'], - message: json.data.attributes['message'], - title: json.data.attributes['title'], - isCertifiable: json.data.attributes['is-certifiable'], - isAlwaysVisible: json.data.attributes['is-always-visible'], - imageUrl: json.data.attributes['image-url'], - }; - }, +const serialize = function (badge = {}) { + return new Serializer('badge', { + ref: 'id', + attributes: ['altMessage', 'imageUrl', 'message', 'key', 'title', 'isCertifiable', 'isAlwaysVisible'], + }).serialize(badge); }; + +const deserialize = function (json) { + return { + key: json.data.attributes['key'], + altMessage: json.data.attributes['alt-message'], + message: json.data.attributes['message'], + title: json.data.attributes['title'], + isCertifiable: json.data.attributes['is-certifiable'], + isAlwaysVisible: json.data.attributes['is-always-visible'], + imageUrl: json.data.attributes['image-url'], + }; +}; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-analysis-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-analysis-serializer.js index 83ec76f4b43..51e560fb132 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-analysis-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-analysis-serializer.js @@ -1,25 +1,28 @@ -const { Serializer } = require('jsonapi-serializer'); -const tutorialAttributes = require('./tutorial-attributes.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(results) { - return new Serializer('campaign-analysis', { - attributes: ['campaignTubeRecommendations'], - campaignTubeRecommendations: { - ref: 'id', - includes: true, - attributes: [ - 'tubeId', - 'competenceId', - 'competenceName', - 'tubePracticalTitle', - 'areaColor', - 'averageScore', - 'tutorials', - 'tubeDescription', - ], - tutorials: tutorialAttributes, - }, - }).serialize(results); - }, +const { Serializer } = jsonapiSerializer; + +import { tutorialAttributes } from './tutorial-attributes.js'; + +const serialize = function (results) { + return new Serializer('campaign-analysis', { + attributes: ['campaignTubeRecommendations'], + campaignTubeRecommendations: { + ref: 'id', + includes: true, + attributes: [ + 'tubeId', + 'competenceId', + 'competenceName', + 'tubePracticalTitle', + 'areaColor', + 'averageScore', + 'tutorials', + 'tubeDescription', + ], + tutorials: tutorialAttributes, + }, + }).serialize(results); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer.js index 168f04f641d..77e5911e1da 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer.js @@ -1,17 +1,19 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(campaignAssessmentParticipationResult) { - return new Serializer('campaign-assessment-participation-results', { - id: 'campaignParticipationId', - attributes: ['campaignId', 'competenceResults'], - typeForAttribute: (attribute) => { - if (attribute === 'competenceResults') return 'campaign-assessment-participation-competence-results'; - }, - competenceResults: { - ref: 'id', - attributes: ['name', 'index', 'areaColor', 'competenceMasteryRate'], - }, - }).serialize(campaignAssessmentParticipationResult); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (campaignAssessmentParticipationResult) { + return new Serializer('campaign-assessment-participation-results', { + id: 'campaignParticipationId', + attributes: ['campaignId', 'competenceResults'], + typeForAttribute: (attribute) => { + if (attribute === 'competenceResults') return 'campaign-assessment-participation-competence-results'; + }, + competenceResults: { + ref: 'id', + attributes: ['name', 'index', 'areaColor', 'competenceMasteryRate'], + }, + }).serialize(campaignAssessmentParticipationResult); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer.js index 8b3725e0b48..9c2f8597468 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer.js @@ -1,55 +1,57 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(campaignAssessmentParticipation) { - return new Serializer('campaign-assessment-participations', { - id: 'campaignParticipationId', - attributes: [ - 'firstName', - 'lastName', - 'participantExternalId', - 'createdAt', - 'sharedAt', - 'isShared', - 'campaignId', - 'targetedSkillsCount', - 'validatedSkillsCount', - 'masteryRate', - 'progression', - 'badges', - 'campaignAssessmentParticipationResult', - 'campaignAnalysis', - 'reachedStage', - 'totalStage', - 'prescriberTitle', - 'prescriberDescription', - 'organizationLearnerId', - ], - badges: { - ref: 'id', - included: true, - attributes: ['title', 'altMessage', 'imageUrl'], - }, - campaignAssessmentParticipationResult: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record) { - return `/api/campaigns/${record.campaignId}/assessment-participations/${record.campaignParticipationId}/results`; - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (campaignAssessmentParticipation) { + return new Serializer('campaign-assessment-participations', { + id: 'campaignParticipationId', + attributes: [ + 'firstName', + 'lastName', + 'participantExternalId', + 'createdAt', + 'sharedAt', + 'isShared', + 'campaignId', + 'targetedSkillsCount', + 'validatedSkillsCount', + 'masteryRate', + 'progression', + 'badges', + 'campaignAssessmentParticipationResult', + 'campaignAnalysis', + 'reachedStage', + 'totalStage', + 'prescriberTitle', + 'prescriberDescription', + 'organizationLearnerId', + ], + badges: { + ref: 'id', + included: true, + attributes: ['title', 'altMessage', 'imageUrl'], + }, + campaignAssessmentParticipationResult: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record) { + return `/api/campaigns/${record.campaignId}/assessment-participations/${record.campaignParticipationId}/results`; }, }, - campaignAnalysis: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record) { - return `/api/campaign-participations/${record.campaignParticipationId}/analyses`; - }, + }, + campaignAnalysis: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record) { + return `/api/campaign-participations/${record.campaignParticipationId}/analyses`; }, }, - }).serialize(campaignAssessmentParticipation); - }, + }, + }).serialize(campaignAssessmentParticipation); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer.js index 3309b290e83..88cb87f47a3 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer.js @@ -1,26 +1,28 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize({ participations, pagination }) { - return new Serializer('campaign-assessment-result-minimals', { - id: 'campaignParticipationId', - attributes: [ - 'firstName', - 'lastName', - 'participantExternalId', - 'masteryRate', - 'reachedStage', - 'totalStage', - 'prescriberTitle', - 'prescriberDescription', - 'badges', - ], - badges: { - ref: 'id', - included: true, - attributes: ['title', 'altMessage', 'imageUrl'], - }, - meta: pagination, - }).serialize(participations); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function ({ participations, pagination }) { + return new Serializer('campaign-assessment-result-minimals', { + id: 'campaignParticipationId', + attributes: [ + 'firstName', + 'lastName', + 'participantExternalId', + 'masteryRate', + 'reachedStage', + 'totalStage', + 'prescriberTitle', + 'prescriberDescription', + 'badges', + ], + badges: { + ref: 'id', + included: true, + attributes: ['title', 'altMessage', 'imageUrl'], + }, + meta: pagination, + }).serialize(participations); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-collective-result-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-collective-result-serializer.js index 914e4bf2371..dbb574b2414 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-collective-result-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-collective-result-serializer.js @@ -1,21 +1,23 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(results) { - return new Serializer('campaign-collective-result', { - attributes: ['campaignCompetenceCollectiveResults'], - campaignCompetenceCollectiveResults: { - ref: 'id', - includes: true, - attributes: [ - 'competenceId', - 'competenceName', - 'areaCode', - 'areaColor', - 'targetedSkillsCount', - 'averageValidatedSkills', - ], - }, - }).serialize(results); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (results) { + return new Serializer('campaign-collective-result', { + attributes: ['campaignCompetenceCollectiveResults'], + campaignCompetenceCollectiveResults: { + ref: 'id', + includes: true, + attributes: [ + 'competenceId', + 'competenceName', + 'areaCode', + 'areaColor', + 'targetedSkillsCount', + 'averageValidatedSkills', + ], + }, + }).serialize(results); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-details-management-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-details-management-serializer.js index 89119122a57..555c60e6f0f 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-details-management-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-details-management-serializer.js @@ -1,34 +1,36 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(campaignManagement, meta) { - return new Serializer('campaign', { - attributes: [ - 'name', - 'code', - 'type', - 'title', - 'idPixLabel', - 'createdAt', - 'archivedAt', - 'creatorId', - 'creatorLastName', - 'creatorFirstName', - 'organizationId', - 'organizationName', - 'targetProfileId', - 'targetProfileName', - 'customLandingPageText', - 'customResultPageText', - 'customResultPageButtonText', - 'customResultPageButtonUrl', - 'sharedParticipationsCount', - 'totalParticipationsCount', - 'isTypeProfilesCollection', - 'isTypeAssessment', - 'multipleSendings', - ], - meta, - }).serialize(campaignManagement); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (campaignManagement, meta) { + return new Serializer('campaign', { + attributes: [ + 'name', + 'code', + 'type', + 'title', + 'idPixLabel', + 'createdAt', + 'archivedAt', + 'creatorId', + 'creatorLastName', + 'creatorFirstName', + 'organizationId', + 'organizationName', + 'targetProfileId', + 'targetProfileName', + 'customLandingPageText', + 'customResultPageText', + 'customResultPageButtonText', + 'customResultPageButtonUrl', + 'sharedParticipationsCount', + 'totalParticipationsCount', + 'isTypeProfilesCollection', + 'isTypeAssessment', + 'multipleSendings', + ], + meta, + }).serialize(campaignManagement); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-management-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-management-serializer.js index 5e9b1a2a8c8..166762a7c0a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-management-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-management-serializer.js @@ -1,22 +1,24 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(campaignManagement, meta) { - return new Serializer('campaign', { - attributes: [ - 'name', - 'code', - 'type', - 'createdAt', - 'archivedAt', - 'creatorId', - 'creatorLastName', - 'creatorFirstName', - 'ownerId', - 'ownerLastName', - 'ownerFirstName', - ], - meta, - }).serialize(campaignManagement); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (campaignManagement, meta) { + return new Serializer('campaign', { + attributes: [ + 'name', + 'code', + 'type', + 'createdAt', + 'archivedAt', + 'creatorId', + 'creatorLastName', + 'creatorFirstName', + 'ownerId', + 'ownerLastName', + 'ownerFirstName', + ], + meta, + }).serialize(campaignManagement); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer.js index a0e68bbfde0..cec00326381 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer.js @@ -1,11 +1,13 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize({ campaignParticipantsActivities, pagination }) { - return new Serializer('campaign-participant-activity', { - id: 'campaignParticipationId', - attributes: ['firstName', 'lastName', 'participantExternalId', 'status', 'progression'], - meta: pagination, - }).serialize(campaignParticipantsActivities); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function ({ campaignParticipantsActivities, pagination }) { + return new Serializer('campaign-participant-activity', { + id: 'campaignParticipationId', + attributes: ['firstName', 'lastName', 'participantExternalId', 'status', 'progression'], + meta: pagination, + }).serialize(campaignParticipantsActivities); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer.js index 588c02f0989..99b6d882af9 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer.js @@ -1,20 +1,22 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(campaignParticipation) { - return new Serializer('user-participation', { - attributes: [ - 'participantExternalId', - 'status', - 'campaignId', - 'campaignCode', - 'createdAt', - 'sharedAt', - 'deletedAt', - 'deletedBy', - 'deletedByFullName', - 'organizationLearnerFullName', - ], - }).serialize(campaignParticipation); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (campaignParticipation) { + return new Serializer('user-participation', { + attributes: [ + 'participantExternalId', + 'status', + 'campaignId', + 'campaignCode', + 'createdAt', + 'sharedAt', + 'deletedAt', + 'deletedBy', + 'deletedByFullName', + 'organizationLearnerFullName', + ], + }).serialize(campaignParticipation); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer.js index dae04c08b9e..8bc7f78699a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer.js @@ -1,27 +1,29 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serializeForPaginatedList(userCampaignParticipationOverviewsPaginatedList) { - const { campaignParticipationOverviews, pagination } = userCampaignParticipationOverviewsPaginatedList; - return this.serialize(campaignParticipationOverviews, pagination); - }, +const { Serializer } = jsonapiSerializer; - serialize(campaignParticipationOverview, meta) { - return new Serializer('campaign-participation-overview', { - attributes: [ - 'isShared', - 'sharedAt', - 'createdAt', - 'organizationName', - 'status', - 'campaignCode', - 'campaignTitle', - 'disabledAt', - 'masteryRate', - 'validatedStagesCount', - 'totalStagesCount', - ], - meta, - }).serialize(campaignParticipationOverview); - }, +const serializeForPaginatedList = function (userCampaignParticipationOverviewsPaginatedList) { + const { campaignParticipationOverviews, pagination } = userCampaignParticipationOverviewsPaginatedList; + return this.serialize(campaignParticipationOverviews, pagination); }; + +const serialize = function (campaignParticipationOverview, meta) { + return new Serializer('campaign-participation-overview', { + attributes: [ + 'isShared', + 'sharedAt', + 'createdAt', + 'organizationName', + 'status', + 'campaignCode', + 'campaignTitle', + 'disabledAt', + 'masteryRate', + 'validatedStagesCount', + 'totalStagesCount', + ], + meta, + }).serialize(campaignParticipationOverview); +}; + +export { serializeForPaginatedList, serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-participation-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-participation-serializer.js index b95b52f8226..45d42cb3ba6 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-participation-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-participation-serializer.js @@ -1,63 +1,65 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -const Campaign = require('../../../domain/models/Campaign.js'); -const CampaignParticipation = require('../../../domain/models/CampaignParticipation.js'); +const { Serializer, Deserializer } = jsonapiSerializer; -module.exports = { - serialize(campaignParticipation) { - return new Serializer('campaign-participation', { - transform: (campaignParticipation) => { - const campaignParticipationForSerialization = new CampaignParticipation(campaignParticipation); - if (campaignParticipation.lastAssessment) { - campaignParticipationForSerialization.assessment = { id: campaignParticipation.lastAssessment.id }; - } - campaignParticipationForSerialization.trainings = null; - return campaignParticipationForSerialization; - }, +import { Campaign } from '../../../domain/models/Campaign.js'; +import { CampaignParticipation } from '../../../domain/models/CampaignParticipation.js'; - attributes: [ - 'isShared', - 'sharedAt', - 'createdAt', - 'participantExternalId', - 'campaign', - 'assessment', - 'deletedAt', - 'trainings', - ], - campaign: { - ref: 'id', - attributes: ['code', 'title', 'type'], - }, - assessment: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related(record) { - return `/api/assessments/${record.assessment.id}`; - }, +const serialize = function (campaignParticipation) { + return new Serializer('campaign-participation', { + transform: (campaignParticipation) => { + const campaignParticipationForSerialization = new CampaignParticipation(campaignParticipation); + if (campaignParticipation.lastAssessment) { + campaignParticipationForSerialization.assessment = { id: campaignParticipation.lastAssessment.id }; + } + campaignParticipationForSerialization.trainings = null; + return campaignParticipationForSerialization; + }, + + attributes: [ + 'isShared', + 'sharedAt', + 'createdAt', + 'participantExternalId', + 'campaign', + 'assessment', + 'deletedAt', + 'trainings', + ], + campaign: { + ref: 'id', + attributes: ['code', 'title', 'type'], + }, + assessment: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related(record) { + return `/api/assessments/${record.assessment.id}`; }, }, - trainings: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/campaign-participations/${parent.id}/trainings`; - }, + }, + trainings: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/campaign-participations/${parent.id}/trainings`; }, }, - }).serialize(campaignParticipation); - }, + }, + }).serialize(campaignParticipation); +}; - deserialize(json) { - return new Deserializer({ keyForAttribute: 'camelCase' }).deserialize(json).then((campaignParticipation) => { - let campaign; - if (json.data?.relationships?.campaign) { - campaign = new Campaign({ id: json.data.relationships.campaign.data.id }); - } +const deserialize = function (json) { + return new Deserializer({ keyForAttribute: 'camelCase' }).deserialize(json).then((campaignParticipation) => { + let campaign; + if (json.data?.relationships?.campaign) { + campaign = new Campaign({ id: json.data.relationships.campaign.data.id }); + } - return new CampaignParticipation({ ...campaignParticipation, campaign }); - }); - }, + return new CampaignParticipation({ ...campaignParticipation, campaign }); + }); }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer.js index 1203ff9d4b4..869dd234796 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer.js @@ -1,13 +1,15 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(model) { - return new Serializer('campaign-participations-count-by-stage', { - id: 'campaignId', - attributes: ['data'], - data: { - attributes: ['id', 'value', 'title', 'description', 'reachedStage', 'totalStage'], - }, - }).serialize(model); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (model) { + return new Serializer('campaign-participations-count-by-stage', { + id: 'campaignId', + attributes: ['data'], + data: { + attributes: ['id', 'value', 'title', 'description', 'reachedStage', 'totalStage'], + }, + }).serialize(model); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer.js index 1763a66353a..a94cb37618c 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer.js @@ -1,16 +1,18 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(model) { - return new Serializer('campaign-participations-counts-by-day', { - id: 'campaignId', - attributes: ['startedParticipations', 'sharedParticipations'], - startedParticipations: { - attributes: ['day', 'count'], - }, - sharedParticipations: { - attributes: ['day', 'count'], - }, - }).serialize(model); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (model) { + return new Serializer('campaign-participations-counts-by-day', { + id: 'campaignId', + attributes: ['startedParticipations', 'sharedParticipations'], + startedParticipations: { + attributes: ['day', 'count'], + }, + sharedParticipations: { + attributes: ['day', 'count'], + }, + }).serialize(model); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer.js index 15042889d41..0f0d5bb5d2c 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(model) { - return new Serializer('campaign-participations-counts-by-status', { - id: 'campaignId', - attributes: ['started', 'completed', 'shared'], - }).serialize(model); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (model) { + return new Serializer('campaign-participations-counts-by-status', { + id: 'campaignId', + attributes: ['started', 'completed', 'shared'], + }).serialize(model); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-profile-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-profile-serializer.js index 09a47297624..65701e1e24c 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-profile-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-profile-serializer.js @@ -1,31 +1,33 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(campaignProfile) { - return new Serializer('campaign-profiles', { - id: 'campaignParticipationId', - attributes: [ - 'firstName', - 'lastName', - 'externalId', - 'createdAt', - 'sharedAt', - 'isShared', - 'campaignId', - 'pixScore', - 'competencesCount', - 'certifiableCompetencesCount', - 'isCertifiable', - 'competences', - 'organizationLearnerId', - ], - typeForAttribute: (attribute) => { - if (attribute === 'competences') return 'campaign-profile-competences'; - }, - competences: { - ref: 'id', - attributes: ['name', 'index', 'pixScore', 'estimatedLevel', 'areaColor'], - }, - }).serialize(campaignProfile); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (campaignProfile) { + return new Serializer('campaign-profiles', { + id: 'campaignParticipationId', + attributes: [ + 'firstName', + 'lastName', + 'externalId', + 'createdAt', + 'sharedAt', + 'isShared', + 'campaignId', + 'pixScore', + 'competencesCount', + 'certifiableCompetencesCount', + 'isCertifiable', + 'competences', + 'organizationLearnerId', + ], + typeForAttribute: (attribute) => { + if (attribute === 'competences') return 'campaign-profile-competences'; + }, + competences: { + ref: 'id', + attributes: ['name', 'index', 'pixScore', 'estimatedLevel', 'areaColor'], + }, + }).serialize(campaignProfile); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer.js index c8af266d198..2ccde550087 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer.js @@ -1,19 +1,21 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize({ data, pagination }) { - return new Serializer('CampaignProfilesCollectionParticipationSummary', { - ref: 'id', - attributes: [ - 'firstName', - 'lastName', - 'participantExternalId', - 'sharedAt', - 'pixScore', - 'certifiable', - 'certifiableCompetencesCount', - ], - meta: pagination, - }).serialize(data); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function ({ data, pagination }) { + return new Serializer('CampaignProfilesCollectionParticipationSummary', { + ref: 'id', + attributes: [ + 'firstName', + 'lastName', + 'participantExternalId', + 'sharedAt', + 'pixScore', + 'certifiable', + 'certifiableCompetencesCount', + ], + meta: pagination, + }).serialize(data); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-report-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-report-serializer.js index eb9546fce63..49070de5751 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-report-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-report-serializer.js @@ -1,97 +1,99 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(campaignReports, meta, { tokenForCampaignResults } = {}) { - return new Serializer('campaign', { - transform: (record) => { - const campaign = Object.assign({}, record); - campaign.tokenForCampaignResults = tokenForCampaignResults; - campaign.isArchived = record.isArchived; - return campaign; - }, - attributes: [ - 'name', - 'code', - 'title', - 'type', - 'createdAt', - 'customLandingPageText', - 'isArchived', - 'tokenForCampaignResults', - 'idPixLabel', - 'targetProfileId', - 'targetProfileDescription', - 'targetProfileName', - 'targetProfileTubesCount', - 'targetProfileThematicResultCount', - 'targetProfileHasStage', - 'ownerId', - 'ownerLastName', - 'ownerFirstName', - 'participationsCount', - 'sharedParticipationsCount', - 'averageResult', - 'campaignCollectiveResult', - 'campaignAnalysis', - 'divisions', - 'stages', - 'totalStage', - 'reachedStage', - 'badges', - 'groups', - 'multipleSendings', - ], - stages: { - ref: 'id', - included: true, - attributes: ['prescriberTitle', 'prescriberDescription', 'threshold'], - }, - badges: { - ref: 'id', - included: true, - attributes: ['title'], - }, - campaignCollectiveResult: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/campaigns/${parent.id}/collective-results`; - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (campaignReports, meta, { tokenForCampaignResults } = {}) { + return new Serializer('campaign', { + transform: (record) => { + const campaign = Object.assign({}, record); + campaign.tokenForCampaignResults = tokenForCampaignResults; + campaign.isArchived = record.isArchived; + return campaign; + }, + attributes: [ + 'name', + 'code', + 'title', + 'type', + 'createdAt', + 'customLandingPageText', + 'isArchived', + 'tokenForCampaignResults', + 'idPixLabel', + 'targetProfileId', + 'targetProfileDescription', + 'targetProfileName', + 'targetProfileTubesCount', + 'targetProfileThematicResultCount', + 'targetProfileHasStage', + 'ownerId', + 'ownerLastName', + 'ownerFirstName', + 'participationsCount', + 'sharedParticipationsCount', + 'averageResult', + 'campaignCollectiveResult', + 'campaignAnalysis', + 'divisions', + 'stages', + 'totalStage', + 'reachedStage', + 'badges', + 'groups', + 'multipleSendings', + ], + stages: { + ref: 'id', + included: true, + attributes: ['prescriberTitle', 'prescriberDescription', 'threshold'], + }, + badges: { + ref: 'id', + included: true, + attributes: ['title'], + }, + campaignCollectiveResult: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/campaigns/${parent.id}/collective-results`; }, }, - campaignAnalysis: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/campaigns/${parent.id}/analyses`; - }, + }, + campaignAnalysis: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/campaigns/${parent.id}/analyses`; }, }, - divisions: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/campaigns/${parent.id}/divisions`; - }, + }, + divisions: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/campaigns/${parent.id}/divisions`; }, }, - groups: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/campaigns/${parent.id}/groups`; - }, + }, + groups: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/campaigns/${parent.id}/groups`; }, }, - meta, - }).serialize(campaignReports); - }, + }, + meta, + }).serialize(campaignReports); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign-to-join-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign-to-join-serializer.js index a5c600dd623..8c92421ecae 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign-to-join-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign-to-join-serializer.js @@ -1,34 +1,36 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(campaignsToJoin) { - return new Serializer('campaign', { - attributes: [ - 'code', - 'title', - 'type', - 'idPixLabel', - 'customLandingPageText', - 'externalIdHelpImageUrl', - 'alternativeTextToExternalIdHelpImage', - 'isArchived', - 'isForAbsoluteNovice', - 'isRestricted', - 'isSimplifiedAccess', - 'organizationName', - 'organizationType', - 'organizationLogoUrl', - 'identityProvider', - 'organizationShowNPS', - 'organizationFormNPSUrl', - 'targetProfileName', - 'targetProfileImageUrl', - 'customResultPageText', - 'customResultPageButtonText', - 'customResultPageButtonUrl', - 'multipleSendings', - 'isFlash', - ], - }).serialize(campaignsToJoin); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (campaignsToJoin) { + return new Serializer('campaign', { + attributes: [ + 'code', + 'title', + 'type', + 'idPixLabel', + 'customLandingPageText', + 'externalIdHelpImageUrl', + 'alternativeTextToExternalIdHelpImage', + 'isArchived', + 'isForAbsoluteNovice', + 'isRestricted', + 'isSimplifiedAccess', + 'organizationName', + 'organizationType', + 'organizationLogoUrl', + 'identityProvider', + 'organizationShowNPS', + 'organizationFormNPSUrl', + 'targetProfileName', + 'targetProfileImageUrl', + 'customResultPageText', + 'customResultPageButtonText', + 'customResultPageButtonUrl', + 'multipleSendings', + 'isFlash', + ], + }).serialize(campaignsToJoin); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer.js b/api/lib/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer.js index 8f9e0f5e533..e2762a20e15 100644 --- a/api/lib/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(targetProfiles, meta) { - return new Serializer('target-profile', { - attributes: ['name', 'tubeCount', 'thematicResultCount', 'hasStage', 'description', 'category'], - meta, - }).serialize(targetProfiles); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (targetProfiles, meta) { + return new Serializer('target-profile', { + attributes: ['name', 'tubeCount', 'thematicResultCount', 'hasStage', 'description', 'category'], + meta, + }).serialize(targetProfiles); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-candidate-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-candidate-serializer.js index e6262dfad0f..e9af02ae359 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-candidate-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-candidate-serializer.js @@ -1,55 +1,58 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); -const CertificationCandidate = require('../../../domain/models/CertificationCandidate.js'); -const { WrongDateFormatError } = require('../../../domain/errors.js'); -const { isValidDate } = require('../../utils/date-utils.js'); -const _ = require('lodash'); - -module.exports = { - serialize(certificationCandidates) { - return new Serializer('certification-candidate', { - transform: function (certificationCandidate) { - return { - ...certificationCandidate, - isLinked: !_.isNil(certificationCandidate.userId), - }; - }, - attributes: [ - 'firstName', - 'lastName', - 'birthdate', - 'birthProvinceCode', - 'birthCity', - 'birthCountry', - 'email', - 'resultRecipientEmail', - 'externalId', - 'extraTimePercentage', - 'isLinked', - 'organizationLearnerId', - 'sex', - 'birthINSEECode', - 'birthPostalCode', - 'complementaryCertifications', - 'billingMode', - 'prepaymentCode', - ], - }).serialize(certificationCandidates); - }, - - async deserialize(json) { - if (json.data.attributes.birthdate && !isValidDate(json.data.attributes.birthdate, 'YYYY-MM-DD')) { - throw new WrongDateFormatError( - "La date de naissance du candidate à la certification n'a pas un format valide du type JJ/MM/AAAA" - ); - } - - delete json.data.attributes['is-linked']; - - const deserializer = new Deserializer({ keyForAttribute: 'camelCase' }); - const deserializedCandidate = await deserializer.deserialize(json); - deserializedCandidate.birthINSEECode = deserializedCandidate.birthInseeCode; - delete deserializedCandidate.birthInseeCode; - - return new CertificationCandidate(deserializedCandidate); - }, +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Serializer, Deserializer } = jsonapiSerializer; + +import { CertificationCandidate } from '../../../domain/models/CertificationCandidate.js'; +import { WrongDateFormatError } from '../../../domain/errors.js'; +import { isValidDate } from '../../utils/date-utils.js'; +import _ from 'lodash'; + +const serialize = function (certificationCandidates) { + return new Serializer('certification-candidate', { + transform: function (certificationCandidate) { + return { + ...certificationCandidate, + isLinked: !_.isNil(certificationCandidate.userId), + }; + }, + attributes: [ + 'firstName', + 'lastName', + 'birthdate', + 'birthProvinceCode', + 'birthCity', + 'birthCountry', + 'email', + 'resultRecipientEmail', + 'externalId', + 'extraTimePercentage', + 'isLinked', + 'organizationLearnerId', + 'sex', + 'birthINSEECode', + 'birthPostalCode', + 'complementaryCertifications', + 'billingMode', + 'prepaymentCode', + ], + }).serialize(certificationCandidates); }; + +const deserialize = async function (json) { + if (json.data.attributes.birthdate && !isValidDate(json.data.attributes.birthdate, 'YYYY-MM-DD')) { + throw new WrongDateFormatError( + "La date de naissance du candidate à la certification n'a pas un format valide du type JJ/MM/AAAA" + ); + } + + delete json.data.attributes['is-linked']; + + const deserializer = new Deserializer({ keyForAttribute: 'camelCase' }); + const deserializedCandidate = await deserializer.deserialize(json); + deserializedCandidate.birthINSEECode = deserializedCandidate.birthInseeCode; + delete deserializedCandidate.birthInseeCode; + + return new CertificationCandidate(deserializedCandidate); +}; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer.js index 69cf48e5718..2aa81fb5564 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(certificationCandidateSubscription) { - return new Serializer('certification-candidate-subscription', { - attributes: ['sessionId', 'eligibleSubscriptions', 'nonEligibleSubscriptions'], - }).serialize(certificationCandidateSubscription); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (certificationCandidateSubscription) { + return new Serializer('certification-candidate-subscription', { + attributes: ['sessionId', 'eligibleSubscriptions', 'nonEligibleSubscriptions'], + }).serialize(certificationCandidateSubscription); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer.js index 7bf7b2599b7..354162afb0f 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer.js @@ -1,49 +1,53 @@ -const { Serializer } = require('jsonapi-serializer'); -const CertificationCenterForAdmin = require('../../../domain/models/CertificationCenterForAdmin.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - deserialize({ data }) { - return new CertificationCenterForAdmin({ - createdAt: null, - dataProtectionOfficerFirstName: data.attributes['data-protection-officer-first-name'], - dataProtectionOfficerLastName: data.attributes['data-protection-officer-last-name'], - dataProtectionOfficerEmail: data.attributes['data-protection-officer-email'], - externalId: data.attributes['external-id'], - habilitations: [], - id: data.id, - name: data.attributes.name, - type: data.attributes.type, - }); - }, - serialize(certificationCenters, meta) { - return new Serializer('certification-centers', { - attributes: [ - 'name', - 'type', - 'externalId', - 'createdAt', - 'certificationCenterMemberships', - 'dataProtectionOfficerFirstName', - 'dataProtectionOfficerLastName', - 'dataProtectionOfficerEmail', - 'habilitations', - ], - certificationCenterMemberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/admin/certification-centers/${parent.id}/certification-center-memberships`; - }, +const { Serializer } = jsonapiSerializer; + +import { CertificationCenterForAdmin } from '../../../domain/models/CertificationCenterForAdmin.js'; + +const deserialize = function ({ data }) { + return new CertificationCenterForAdmin({ + createdAt: null, + dataProtectionOfficerFirstName: data.attributes['data-protection-officer-first-name'], + dataProtectionOfficerLastName: data.attributes['data-protection-officer-last-name'], + dataProtectionOfficerEmail: data.attributes['data-protection-officer-email'], + externalId: data.attributes['external-id'], + habilitations: [], + id: data.id, + name: data.attributes.name, + type: data.attributes.type, + }); +}; + +const serialize = function (certificationCenters, meta) { + return new Serializer('certification-centers', { + attributes: [ + 'name', + 'type', + 'externalId', + 'createdAt', + 'certificationCenterMemberships', + 'dataProtectionOfficerFirstName', + 'dataProtectionOfficerLastName', + 'dataProtectionOfficerEmail', + 'habilitations', + ], + certificationCenterMemberships: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/admin/certification-centers/${parent.id}/certification-center-memberships`; }, }, - habilitations: { - include: true, - ref: 'id', - attributes: ['key', 'label'], - }, - meta, - }).serialize(certificationCenters); - }, + }, + habilitations: { + include: true, + ref: 'id', + attributes: ['key', 'label'], + }, + meta, + }).serialize(certificationCenters); }; + +export { deserialize, serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js index b6eac0c9585..109a0859afa 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js @@ -1,24 +1,26 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(invitations) { - return new Serializer('certification-center-invitations', { - attributes: ['certificationCenterId', 'certificationCenterName', 'status'], - }).serialize(invitations); - }, +const { Serializer, Deserializer } = jsonapiSerializer; - serializeForAdmin(invitations) { - return new Serializer('certification-center-invitations', { - attributes: ['email', 'updatedAt'], - }).serialize(invitations); - }, +const serialize = function (invitations) { + return new Serializer('certification-center-invitations', { + attributes: ['certificationCenterId', 'certificationCenterName', 'status'], + }).serialize(invitations); +}; + +const serializeForAdmin = function (invitations) { + return new Serializer('certification-center-invitations', { + attributes: ['email', 'updatedAt'], + }).serialize(invitations); +}; - deserializeForAdmin(payload) { - return new Deserializer().deserialize(payload).then((record) => { - return { - email: record.email, - language: record.language, - }; - }); - }, +const deserializeForAdmin = function (payload) { + return new Deserializer().deserialize(payload).then((record) => { + return { + email: record.email, + language: record.language, + }; + }); }; + +export { serialize, serializeForAdmin, deserializeForAdmin }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-center-membership-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-center-membership-serializer.js index b92a86cf60f..c4b3010665a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-center-membership-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-center-membership-serializer.js @@ -1,59 +1,61 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(certificationCenterMemberships) { - return new Serializer('certificationCenterMemberships', { - transform: function (record) { - record.certificationCenter.sessions = []; - return record; - }, - attributes: ['createdAt', 'certificationCenter', 'user'], - certificationCenter: { +const { Serializer } = jsonapiSerializer; + +const serialize = function (certificationCenterMemberships) { + return new Serializer('certificationCenterMemberships', { + transform: function (record) { + record.certificationCenter.sessions = []; + return record; + }, + attributes: ['createdAt', 'certificationCenter', 'user'], + certificationCenter: { + ref: 'id', + included: true, + attributes: ['name', 'type', 'sessions'], + sessions: { ref: 'id', - included: true, - attributes: ['name', 'type', 'sessions'], - sessions: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/certification-centers/${parent.id}/sessions`; - }, + ignoreRelationshipData: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/certification-centers/${parent.id}/sessions`; }, }, }, - user: { - ref: 'id', - included: true, - attributes: ['firstName', 'lastName', 'email'], - }, - }).serialize(certificationCenterMemberships); - }, - - serializeMembers(certificationCenterMemberships) { - return new Serializer('members', { - transform: function (record) { - const { id, firstName, lastName } = record.user; - return { id, firstName, lastName, isReferer: record.isReferer }; - }, + }, + user: { ref: 'id', - attributes: ['firstName', 'lastName', 'isReferer'], - }).serialize(certificationCenterMemberships); - }, + included: true, + attributes: ['firstName', 'lastName', 'email'], + }, + }).serialize(certificationCenterMemberships); +}; - serializeForAdmin(certificationCenterMemberships) { - return new Serializer('certification-center-memberships', { - attributes: ['createdAt', 'certificationCenter', 'user'], - certificationCenter: { - ref: 'id', - included: true, - attributes: ['name', 'type', 'externalId'], - }, - user: { - ref: 'id', - included: true, - attributes: ['firstName', 'lastName', 'email'], - }, - }).serialize(certificationCenterMemberships); - }, +const serializeMembers = function (certificationCenterMemberships) { + return new Serializer('members', { + transform: function (record) { + const { id, firstName, lastName } = record.user; + return { id, firstName, lastName, isReferer: record.isReferer }; + }, + ref: 'id', + attributes: ['firstName', 'lastName', 'isReferer'], + }).serialize(certificationCenterMemberships); +}; + +const serializeForAdmin = function (certificationCenterMemberships) { + return new Serializer('certification-center-memberships', { + attributes: ['createdAt', 'certificationCenter', 'user'], + certificationCenter: { + ref: 'id', + included: true, + attributes: ['name', 'type', 'externalId'], + }, + user: { + ref: 'id', + included: true, + attributes: ['firstName', 'lastName', 'email'], + }, + }).serialize(certificationCenterMemberships); }; + +export { serialize, serializeMembers, serializeForAdmin }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-center-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-center-serializer.js index 2fa272eb3ed..dfb64561a8a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-center-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-center-serializer.js @@ -1,38 +1,40 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -const CertificationCenter = require('../../../domain/models/CertificationCenter.js'); +const { Serializer } = jsonapiSerializer; -module.exports = { - serialize(certificationCenters, meta) { - return new Serializer('certification-center', { - attributes: ['name', 'type', 'externalId', 'createdAt', 'certificationCenterMemberships', 'habilitations'], - certificationCenterMemberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/certification-centers/${parent.id}/certification-center-memberships`; - }, +import { CertificationCenter } from '../../../domain/models/CertificationCenter.js'; + +const serialize = function (certificationCenters, meta) { + return new Serializer('certification-center', { + attributes: ['name', 'type', 'externalId', 'createdAt', 'certificationCenterMemberships', 'habilitations'], + certificationCenterMemberships: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/certification-centers/${parent.id}/certification-center-memberships`; }, }, - habilitations: { - include: true, - ref: 'id', - attributes: ['key', 'label'], - }, - meta, - }).serialize(certificationCenters); - }, + }, + habilitations: { + include: true, + ref: 'id', + attributes: ['key', 'label'], + }, + meta, + }).serialize(certificationCenters); +}; - deserialize(jsonAPI) { - return new CertificationCenter({ - id: jsonAPI.data.id, - name: jsonAPI.data.attributes.name, - type: jsonAPI.data.attributes.type, - externalId: jsonAPI.data.attributes['external-id'], - createdAt: null, - habilitations: [], - }); - }, +const deserialize = function (jsonAPI) { + return new CertificationCenter({ + id: jsonAPI.data.id, + name: jsonAPI.data.attributes.name, + type: jsonAPI.data.attributes.type, + externalId: jsonAPI.data.attributes['external-id'], + createdAt: null, + habilitations: [], + }); }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-course-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-course-serializer.js index aa6336b393b..5bfbeaf0be0 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-course-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-course-serializer.js @@ -1,24 +1,26 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(certificationCourse) { - return new Serializer('certification-course', { - transform(currentCertificationCourse) { - const certificationCourseDTO = currentCertificationCourse.toDTO(); - certificationCourseDTO.nbChallenges = certificationCourseDTO?.challenges?.length ?? 0; - certificationCourseDTO.examinerComment = certificationCourseDTO.certificationIssueReports?.[0]?.description; - return certificationCourseDTO; - }, - attributes: ['assessment', 'nbChallenges', 'examinerComment', 'hasSeenEndTestScreen', 'firstName', 'lastName'], - assessment: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related(record, current) { - return `/api/assessments/${current.id}`; - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (certificationCourse) { + return new Serializer('certification-course', { + transform(currentCertificationCourse) { + const certificationCourseDTO = currentCertificationCourse.toDTO(); + certificationCourseDTO.nbChallenges = certificationCourseDTO?.challenges?.length ?? 0; + certificationCourseDTO.examinerComment = certificationCourseDTO.certificationIssueReports?.[0]?.description; + return certificationCourseDTO; + }, + attributes: ['assessment', 'nbChallenges', 'examinerComment', 'hasSeenEndTestScreen', 'firstName', 'lastName'], + assessment: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related(record, current) { + return `/api/assessments/${current.id}`; }, }, - }).serialize(certificationCourse); - }, + }, + }).serialize(certificationCourse); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-details-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-details-serializer.js index 9f27525bf0c..ef16380229d 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-details-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-details-serializer.js @@ -1,18 +1,20 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(certificationDetails) { - return new Serializer('certification-details', { - attributes: [ - 'userId', - 'createdAt', - 'completedAt', - 'status', - 'totalScore', - 'percentageCorrectAnswers', - 'competencesWithMark', - 'listChallengesAndAnswers', - ], - }).serialize(certificationDetails); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (certificationDetails) { + return new Serializer('certification-details', { + attributes: [ + 'userId', + 'createdAt', + 'completedAt', + 'status', + 'totalScore', + 'percentageCorrectAnswers', + 'competencesWithMark', + 'listChallengesAndAnswers', + ], + }).serialize(certificationDetails); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-eligibility-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-eligibility-serializer.js index 967a51ca654..fb81bed7c50 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-eligibility-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-eligibility-serializer.js @@ -1,14 +1,16 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(certificationEligibility) { - return new Serializer('isCertifiables', { - transform(certificationEligibility) { - const clone = Object.assign({}, certificationEligibility); - clone.isCertifiable = clone.pixCertificationEligible; - return clone; - }, - attributes: ['isCertifiable', 'eligibleComplementaryCertifications'], - }).serialize(certificationEligibility); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (certificationEligibility) { + return new Serializer('isCertifiables', { + transform(certificationEligibility) { + const clone = Object.assign({}, certificationEligibility); + clone.isCertifiable = clone.pixCertificationEligible; + return clone; + }, + attributes: ['isCertifiable', 'eligibleComplementaryCertifications'], + }).serialize(certificationEligibility); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-issue-report-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-issue-report-serializer.js index e712c59f8de..f2ee9596321 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-issue-report-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-issue-report-serializer.js @@ -1,25 +1,27 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(certificationIssueReports) { - return new Serializer('certification-issue-report', { - attributes: ['category', 'description', 'subcategory', 'questionNumber'], - transform: function (certificationIssueReport) { - return Object.assign({}, certificationIssueReport); - }, - }).serialize(certificationIssueReports); - }, +const { Serializer } = jsonapiSerializer; - deserialize(request) { - const certificationCourseId = parseInt(request.params.id); - const attributes = request.payload.data.attributes; +const serialize = function (certificationIssueReports) { + return new Serializer('certification-issue-report', { + attributes: ['category', 'description', 'subcategory', 'questionNumber'], + transform: function (certificationIssueReport) { + return Object.assign({}, certificationIssueReport); + }, + }).serialize(certificationIssueReports); +}; + +const deserialize = function (request) { + const certificationCourseId = parseInt(request.params.id); + const attributes = request.payload.data.attributes; - return { - certificationCourseId, - category: attributes.category, - description: attributes.description, - subcategory: attributes.subcategory, - questionNumber: attributes['question-number'], - }; - }, + return { + certificationCourseId, + category: attributes.category, + description: attributes.description, + subcategory: attributes.subcategory, + questionNumber: attributes['question-number'], + }; }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer.js index 2bd3939a177..3144d209290 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer.js @@ -1,61 +1,63 @@ -const _ = require('lodash'); -const { Serializer } = require('jsonapi-serializer'); +import _ from 'lodash'; +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(certificationPointOfContact) { - return new Serializer('certification-point-of-contact', { +const { Serializer } = jsonapiSerializer; + +const serialize = function (certificationPointOfContact) { + return new Serializer('certification-point-of-contact', { + attributes: [ + 'firstName', + 'lastName', + 'email', + 'lang', + 'pixCertifTermsOfServiceAccepted', + 'allowedCertificationCenterAccesses', + ], + allowedCertificationCenterAccesses: { + ref: 'id', + included: true, attributes: [ - 'firstName', - 'lastName', - 'email', - 'lang', - 'pixCertifTermsOfServiceAccepted', - 'allowedCertificationCenterAccesses', + 'name', + 'externalId', + 'type', + 'isRelatedToManagingStudentsOrganization', + 'isAccessBlockedCollege', + 'isAccessBlockedLycee', + 'isAccessBlockedAEFE', + 'isAccessBlockedAgri', + 'relatedOrganizationTags', + 'habilitations', + 'pixCertifScoBlockedAccessDateLycee', + 'pixCertifScoBlockedAccessDateCollege', ], - allowedCertificationCenterAccesses: { - ref: 'id', - included: true, - attributes: [ - 'name', - 'externalId', - 'type', - 'isRelatedToManagingStudentsOrganization', - 'isAccessBlockedCollege', - 'isAccessBlockedLycee', - 'isAccessBlockedAEFE', - 'isAccessBlockedAgri', - 'relatedOrganizationTags', - 'habilitations', - 'pixCertifScoBlockedAccessDateLycee', - 'pixCertifScoBlockedAccessDateCollege', - ], - }, - typeForAttribute: function (attribute) { - if (attribute === 'allowedCertificationCenterAccesses') { - return 'allowed-certification-center-access'; + }, + typeForAttribute: function (attribute) { + if (attribute === 'allowedCertificationCenterAccesses') { + return 'allowed-certification-center-access'; + } + return attribute; + }, + transform(certificationPointOfContact) { + const transformedCertificationPointOfContact = _.clone(certificationPointOfContact); + transformedCertificationPointOfContact.allowedCertificationCenterAccesses = _.map( + certificationPointOfContact.allowedCertificationCenterAccesses, + (access) => { + return { + ...access, + habilitations: access.habilitations, + isAccessBlockedCollege: access.isAccessBlockedCollege(), + isAccessBlockedLycee: access.isAccessBlockedLycee(), + isAccessBlockedAEFE: access.isAccessBlockedAEFE(), + isAccessBlockedAgri: access.isAccessBlockedAgri(), + pixCertifScoBlockedAccessDateCollege: access.pixCertifScoBlockedAccessDateCollege, + pixCertifScoBlockedAccessDateLycee: access.pixCertifScoBlockedAccessDateLycee, + }; } - return attribute; - }, - transform(certificationPointOfContact) { - const transformedCertificationPointOfContact = _.clone(certificationPointOfContact); - transformedCertificationPointOfContact.allowedCertificationCenterAccesses = _.map( - certificationPointOfContact.allowedCertificationCenterAccesses, - (access) => { - return { - ...access, - habilitations: access.habilitations, - isAccessBlockedCollege: access.isAccessBlockedCollege(), - isAccessBlockedLycee: access.isAccessBlockedLycee(), - isAccessBlockedAEFE: access.isAccessBlockedAEFE(), - isAccessBlockedAgri: access.isAccessBlockedAgri(), - pixCertifScoBlockedAccessDateCollege: access.pixCertifScoBlockedAccessDateCollege, - pixCertifScoBlockedAccessDateLycee: access.pixCertifScoBlockedAccessDateLycee, - }; - } - ); + ); - return transformedCertificationPointOfContact; - }, - }).serialize(certificationPointOfContact); - }, + return transformedCertificationPointOfContact; + }, + }).serialize(certificationPointOfContact); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-report-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-report-serializer.js index 8d56136d27d..0383ae93984 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-report-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-report-serializer.js @@ -1,30 +1,32 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -const CertificationReport = require('../../../domain/models/CertificationReport.js'); +const { Serializer, Deserializer } = jsonapiSerializer; -module.exports = { - serialize(certificationReports) { - return new Serializer('certification-report', { - attributes: [ - 'certificationCourseId', - 'firstName', - 'lastName', - 'examinerComment', - 'hasSeenEndTestScreen', - 'certificationIssueReports', - 'isCompleted', - 'abortReason', - ], - certificationIssueReports: { - ref: 'id', - attributes: ['category', 'description', 'subcategory', 'questionNumber'], - }, - }).serialize(certificationReports); - }, +import { CertificationReport } from '../../../domain/models/CertificationReport.js'; - async deserialize(jsonApiData) { - const deserializer = new Deserializer({ keyForAttribute: 'camelCase' }); - const deserializedReport = await deserializer.deserialize(jsonApiData); - return new CertificationReport(deserializedReport); - }, +const serialize = function (certificationReports) { + return new Serializer('certification-report', { + attributes: [ + 'certificationCourseId', + 'firstName', + 'lastName', + 'examinerComment', + 'hasSeenEndTestScreen', + 'certificationIssueReports', + 'isCompleted', + 'abortReason', + ], + certificationIssueReports: { + ref: 'id', + attributes: ['category', 'description', 'subcategory', 'questionNumber'], + }, + }).serialize(certificationReports); }; + +const deserialize = async function (jsonApiData) { + const deserializer = new Deserializer({ keyForAttribute: 'camelCase' }); + const deserializedReport = await deserializer.deserialize(jsonApiData); + return new CertificationReport(deserializedReport); +}; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certification-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certification-serializer.js index 06e9d48978f..d329413836d 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certification-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certification-serializer.js @@ -1,77 +1,80 @@ -const _ = require('lodash'); +import _ from 'lodash'; +import jsonapiSerializer from 'jsonapi-serializer'; -const { Serializer, Deserializer } = require('jsonapi-serializer'); +const { Serializer, Deserializer } = jsonapiSerializer; -const { WrongDateFormatError } = require('../../../domain/errors.js'); -const { NO_EXAMINER_COMMENT } = require('../../../domain/models/CertificationReport.js'); -const { isValidDate } = require('../../utils/date-utils.js'); -const CertificationCourse = require('../../../domain/models/CertificationCourse.js'); +import { WrongDateFormatError } from '../../../domain/errors.js'; +import { NO_EXAMINER_COMMENT } from '../../../domain/models/CertificationReport.js'; +import { isValidDate } from '../../utils/date-utils.js'; +import { CertificationCourse } from '../../../domain/models/CertificationCourse.js'; -module.exports = { - serializeFromCertificationCourse(certificationCourse) { - return new Serializer('certifications', { - transform: (certificationCourse) => { - return { - ..._.omit(certificationCourse.toDTO(), 'maxReachableLevelOnCertificationDate'), - }; - }, - attributes: [ - 'firstName', - 'lastName', - 'birthplace', - 'birthdate', - 'sex', - 'externalId', - 'maxReachableLevelOnCertificationDate', - 'birthINSEECode', - 'birthPostalCode', - 'birthCountry', - ], - }).serialize(certificationCourse); - }, - async deserializeCertificationCandidateModificationCommand(json, certificationCourseId, userId) { - const deserializer = new Deserializer({ keyForAttribute: 'camelCase' }); - const deserializedRawCommand = await deserializer.deserialize(json); - if (deserializedRawCommand.birthdate) { - if (!isValidDate(deserializedRawCommand.birthdate, 'YYYY-MM-DD')) { - throw new WrongDateFormatError(); - } +const serializeFromCertificationCourse = function (certificationCourse) { + return new Serializer('certifications', { + transform: (certificationCourse) => { + return { + ..._.omit(certificationCourse.toDTO(), 'maxReachableLevelOnCertificationDate'), + }; + }, + attributes: [ + 'firstName', + 'lastName', + 'birthplace', + 'birthdate', + 'sex', + 'externalId', + 'maxReachableLevelOnCertificationDate', + 'birthINSEECode', + 'birthPostalCode', + 'birthCountry', + ], + }).serialize(certificationCourse); +}; + +const deserializeCertificationCandidateModificationCommand = async function (json, certificationCourseId, userId) { + const deserializer = new Deserializer({ keyForAttribute: 'camelCase' }); + const deserializedRawCommand = await deserializer.deserialize(json); + if (deserializedRawCommand.birthdate) { + if (!isValidDate(deserializedRawCommand.birthdate, 'YYYY-MM-DD')) { + throw new WrongDateFormatError(); } - return { - ..._.pick(deserializedRawCommand, [ - 'firstName', - 'lastName', - 'birthplace', - 'birthdate', - 'birthCountry', - 'birthPostalCode', - 'sex', - ]), - birthINSEECode: deserializedRawCommand.birthInseeCode, - userId, - certificationCourseId, - }; - }, - deserialize(json) { - const birthdate = json.data.attributes.birthdate; + } + return { + ..._.pick(deserializedRawCommand, [ + 'firstName', + 'lastName', + 'birthplace', + 'birthdate', + 'birthCountry', + 'birthPostalCode', + 'sex', + ]), + birthINSEECode: deserializedRawCommand.birthInseeCode, + userId, + certificationCourseId, + }; +}; + +const deserialize = function (json) { + const birthdate = json.data.attributes.birthdate; - return new Deserializer({ keyForAttribute: 'camelCase' }).deserialize(json).then((certification) => { - if (birthdate) { - if (!isValidDate(birthdate, 'YYYY-MM-DD')) { - return Promise.reject(new WrongDateFormatError()); - } + return new Deserializer({ keyForAttribute: 'camelCase' }).deserialize(json).then((certification) => { + if (birthdate) { + if (!isValidDate(birthdate, 'YYYY-MM-DD')) { + return Promise.reject(new WrongDateFormatError()); } + } - const certificationDomainModel = new CertificationCourse(certification); + const certificationDomainModel = new CertificationCourse(certification); - if (!_isOmitted(certification.examinerComment) && _hasNoExaminerComment(certification.examinerComment)) { - certificationDomainModel.examinerComment = NO_EXAMINER_COMMENT; - } - return certificationDomainModel; - }); - }, + if (!_isOmitted(certification.examinerComment) && _hasNoExaminerComment(certification.examinerComment)) { + certificationDomainModel.examinerComment = NO_EXAMINER_COMMENT; + } + return certificationDomainModel; + }); }; +export { serializeFromCertificationCourse, deserializeCertificationCandidateModificationCommand, deserialize }; + function _isOmitted(aString) { return _.isUndefined(aString); } diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/certification-ls-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/certification-ls-serializer.js index 603e683842d..5bd2a34ef99 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/certification-ls-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/certification-ls-serializer.js @@ -1,4 +1,6 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Serializer } = jsonapiSerializer; const attributes = [ 'firstName', @@ -16,24 +18,24 @@ const attributes = [ 'certificationCenter', ]; -module.exports = { - serialize(certificate) { - return new Serializer('certificationsResults', { - attributes: ['certifications', 'competences'], - certifications: { - attributes: [...attributes], - competenceResults: { - attributes: ['competence-id', 'level'], - }, +const serialize = function (certificate) { + return new Serializer('certificationsResults', { + attributes: ['certifications', 'competences'], + certifications: { + attributes: [...attributes], + competenceResults: { + attributes: ['competence-id', 'level'], }, - competences: { + }, + competences: { + ref: 'id', + attributes: ['name', 'area'], + area: { ref: 'id', - attributes: ['name', 'area'], - area: { - ref: 'id', - attributes: ['name'], - }, + attributes: ['name'], }, - }).serialize(certificate); - }, + }, + }).serialize(certificate); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-area-for-ls.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-area-for-ls.js index ab7215b2d2e..aa4a3b645cb 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-area-for-ls.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-area-for-ls.js @@ -1,6 +1,8 @@ -module.exports = function buildArea({ id, name } = {}) { +const buildArea = function ({ id, name } = {}) { return { id, name, }; }; + +export { buildArea }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-certification-result-for-ls.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-certification-result-for-ls.js index ff34fb34099..17f1e873edb 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-certification-result-for-ls.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-certification-result-for-ls.js @@ -1,9 +1,8 @@ -const Certificate = require('../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Certificate.js'); -const CompetenceResults = require('../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CompetenceResults.js'); -const CertificationsResults = require('../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CertificationsResults.js'); - -const buildCompetenceForLS = require('./build-competences-for-ls.js'); -const buildAreaForLS = require('./build-area-for-ls.js'); +import { Certificate } from '../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Certificate.js'; +import { CompetenceResults } from '../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CompetenceResults.js'; +import { CertificationsResults } from '../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CertificationsResults.js'; +import { buildCompetenceForLS } from './build-competences-for-ls.js'; +import { buildArea as buildAreaForLS } from './build-area-for-ls.js'; function buildReferentialOfCompetences() { const area1 = buildAreaForLS({ @@ -99,4 +98,4 @@ function buildCertificationsResults(certifications, competences = buildReferenti return new CertificationsResults({ certifications, competences }); } -module.exports = { buildCertificateForLS, buildReferentialOfCompetences, buildCertificationsResults }; +export { buildCertificateForLS, buildReferentialOfCompetences, buildCertificationsResults }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-competences-for-ls.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-competences-for-ls.js index 553864bd6a8..1fcf01ef48f 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-competences-for-ls.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-competences-for-ls.js @@ -1,12 +1,12 @@ -const Competence = require('../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Competence.js'); -const { - buildAreaForLS, -} = require('../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-area-for-ls.js'); +import { Competence } from '../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Competence.js'; +import { buildArea as buildAreaForLS } from '../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-area-for-ls.js'; -module.exports = function buildCompetenceForLS({ id, name, area = buildAreaForLS() } = {}) { +const buildCompetenceForLS = function ({ id, name, area = buildAreaForLS() } = {}) { return new Competence({ id, name, area, }); }; + +export { buildCompetenceForLS }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Area.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Area.js index 9afd76177e3..da1367e3348 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Area.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Area.js @@ -5,4 +5,4 @@ class Area { } } -module.exports = Area; +export { Area }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Certificate.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Certificate.js index ba8cc64d32b..246f1d89739 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Certificate.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Certificate.js @@ -32,4 +32,4 @@ class Certificate { } } -module.exports = Certificate; +export { Certificate }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CertificationsResults.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CertificationsResults.js index d23780ecc92..c237be0fdf8 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CertificationsResults.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CertificationsResults.js @@ -5,4 +5,4 @@ class CertificationsResults { } } -module.exports = CertificationsResults; +export { CertificationsResults }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Competence.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Competence.js index 6f536548c2b..106332acfd3 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Competence.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/Competence.js @@ -6,4 +6,4 @@ class Competence { } } -module.exports = Competence; +export { Competence }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CompetenceResults.js b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CompetenceResults.js index be66ab45cac..36df026e602 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CompetenceResults.js +++ b/api/lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/response-objects/CompetenceResults.js @@ -4,4 +4,4 @@ class CompetenceResults { } } -module.exports = CompetenceResults; +export { CompetenceResults }; diff --git a/api/lib/infrastructure/serializers/jsonapi/certified-profile-serializer.js b/api/lib/infrastructure/serializers/jsonapi/certified-profile-serializer.js index 65e50753133..a082b6c0ce8 100644 --- a/api/lib/infrastructure/serializers/jsonapi/certified-profile-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/certified-profile-serializer.js @@ -1,35 +1,40 @@ -const { Serializer } = require('jsonapi-serializer'); -const kebabCase = require('lodash/kebabCase'); +import jsonapiSerializer from 'jsonapi-serializer'; + +const { kebabCase } = lodash; + +const { Serializer } = jsonapiSerializer; + +import lodash from 'lodash'; const typeForAttribute = (attribute) => { return kebabCase(attribute); }; -module.exports = { - serialize(certifiedProfile) { - return new Serializer('certified-profiles', { - typeForAttribute, - attributes: ['userId', 'certifiedSkills', 'certifiedTubes', 'certifiedCompetences', 'certifiedAreas'], - certifiedSkills: { - ref: 'id', - included: true, - attributes: ['name', 'tubeId', 'hasBeenAskedInCertif', 'difficulty'], - }, - certifiedTubes: { - ref: 'id', - included: true, - attributes: ['name', 'competenceId'], - }, - certifiedCompetences: { - ref: 'id', - included: true, - attributes: ['name', 'areaId', 'origin'], - }, - certifiedAreas: { - ref: 'id', - included: true, - attributes: ['name', 'color'], - }, - }).serialize(certifiedProfile); - }, +const serialize = function (certifiedProfile) { + return new Serializer('certified-profiles', { + typeForAttribute, + attributes: ['userId', 'certifiedSkills', 'certifiedTubes', 'certifiedCompetences', 'certifiedAreas'], + certifiedSkills: { + ref: 'id', + included: true, + attributes: ['name', 'tubeId', 'hasBeenAskedInCertif', 'difficulty'], + }, + certifiedTubes: { + ref: 'id', + included: true, + attributes: ['name', 'competenceId'], + }, + certifiedCompetences: { + ref: 'id', + included: true, + attributes: ['name', 'areaId', 'origin'], + }, + certifiedAreas: { + ref: 'id', + included: true, + attributes: ['name', 'color'], + }, + }).serialize(certifiedProfile); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/challenge-serializer.js b/api/lib/infrastructure/serializers/jsonapi/challenge-serializer.js index 830ae22909d..465bcd60654 100644 --- a/api/lib/infrastructure/serializers/jsonapi/challenge-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/challenge-serializer.js @@ -1,35 +1,38 @@ -const { Serializer } = require('jsonapi-serializer'); -const _ = require('lodash'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(challenges) { - return new Serializer('challenge', { - attributes: [ - 'type', - 'instruction', - 'competence', - 'proposals', - 'timer', - 'illustrationUrl', - 'attachments', - 'competence', - 'embedUrl', - 'embedTitle', - 'embedHeight', - 'illustrationAlt', - 'format', - 'autoReply', - 'alternativeInstruction', - 'focused', - 'shuffled', - ], - transform: (record) => { - const challenge = _.pickBy(record, (value) => !_.isUndefined(value)); +const { Serializer } = jsonapiSerializer; - challenge.competence = challenge.competenceId || 'N/A'; +import _ from 'lodash'; - return challenge; - }, - }).serialize(challenges); - }, +const serialize = function (challenges) { + return new Serializer('challenge', { + attributes: [ + 'type', + 'instruction', + 'competence', + 'proposals', + 'timer', + 'illustrationUrl', + 'attachments', + 'competence', + 'embedUrl', + 'embedTitle', + 'embedHeight', + 'illustrationAlt', + 'format', + 'autoReply', + 'alternativeInstruction', + 'focused', + 'shuffled', + ], + transform: (record) => { + const challenge = _.pickBy(record, (value) => !_.isUndefined(value)); + + challenge.competence = challenge.competenceId || 'N/A'; + + return challenge; + }, + }).serialize(challenges); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/competence-evaluation-serializer.js b/api/lib/infrastructure/serializers/jsonapi/competence-evaluation-serializer.js index 6d0aa204961..be2012b56b1 100644 --- a/api/lib/infrastructure/serializers/jsonapi/competence-evaluation-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/competence-evaluation-serializer.js @@ -1,27 +1,29 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(competenceEvaluations) { - return new Serializer('competence-evaluations', { - transform(current) { - const competenceEvaluation = Object.assign({}, current); - competenceEvaluation.assessment = { id: current.assessmentId }; - return competenceEvaluation; - }, - attributes: ['createdAt', 'updatedAt', 'userId', 'competenceId', 'assessment', 'scorecard', 'status'], - assessment: { - ref: 'id', - included: false, - }, - scorecard: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related: function (record) { - return `/api/scorecards/${record.userId}_${record.competenceId}`; - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (competenceEvaluations) { + return new Serializer('competence-evaluations', { + transform(current) { + const competenceEvaluation = Object.assign({}, current); + competenceEvaluation.assessment = { id: current.assessmentId }; + return competenceEvaluation; + }, + attributes: ['createdAt', 'updatedAt', 'userId', 'competenceId', 'assessment', 'scorecard', 'status'], + assessment: { + ref: 'id', + included: false, + }, + scorecard: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related: function (record) { + return `/api/scorecards/${record.userId}_${record.competenceId}`; }, }, - }).serialize(competenceEvaluations); - }, + }, + }).serialize(competenceEvaluations); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/complementary-certification-serializer.js b/api/lib/infrastructure/serializers/jsonapi/complementary-certification-serializer.js index 25f58254984..3b8ccf2b691 100644 --- a/api/lib/infrastructure/serializers/jsonapi/complementary-certification-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/complementary-certification-serializer.js @@ -1,18 +1,21 @@ -const { Serializer } = require('jsonapi-serializer'); -const ComplementaryCertification = require('../../../domain/models/ComplementaryCertification.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(habilitation) { - return new Serializer('habilitation', { - attributes: ['label', 'key'], - }).serialize(habilitation); - }, +const { Serializer } = jsonapiSerializer; - deserialize(jsonAPI) { - return new ComplementaryCertification({ - id: jsonAPI.data.id, - label: jsonAPI.data.attributes.label, - key: jsonAPI.data.attributes.key, - }); - }, +import { ComplementaryCertification } from '../../../domain/models/ComplementaryCertification.js'; + +const serialize = function (habilitation) { + return new Serializer('habilitation', { + attributes: ['label', 'key'], + }).serialize(habilitation); +}; + +const deserialize = function (jsonAPI) { + return new ComplementaryCertification({ + id: jsonAPI.data.id, + label: jsonAPI.data.attributes.label, + key: jsonAPI.data.attributes.key, + }); }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/correction-serializer.js b/api/lib/infrastructure/serializers/jsonapi/correction-serializer.js index 0877a37647c..99fb10e5c1c 100644 --- a/api/lib/infrastructure/serializers/jsonapi/correction-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/correction-serializer.js @@ -1,38 +1,41 @@ -const { Serializer } = require('jsonapi-serializer'); -const tutorialAttributes = require('./tutorial-attributes.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(correction) { - return new Serializer('corrections', { - transform: (record) => ({ - ...correction, - hint: record.hint?.value, - tutorials: correction.tutorials.map((tutorial) => ({ - ...tutorial, - userSavedTutorial: { ...tutorial.userSavedTutorial }, - tutorialEvaluation: { ...tutorial.tutorialEvaluation }, - })), - learningMoreTutorials: correction.learningMoreTutorials.map((tutorial) => ({ - ...tutorial, - userSavedTutorial: { ...tutorial.userSavedTutorial }, - tutorialEvaluation: { ...tutorial.tutorialEvaluation }, - })), - }), - attributes: ['solution', 'solutionToDisplay', 'hint', 'tutorials', 'learningMoreTutorials'], - tutorials: tutorialAttributes, - learningMoreTutorials: tutorialAttributes, - typeForAttribute(attribute) { - switch (attribute) { - case 'tutorialEvaluation': - return 'tutorial-evaluation'; - case 'userSavedTutorial': - return 'user-saved-tutorial'; - case 'learningMoreTutorials': - return 'tutorials'; - default: - return attribute; - } - }, - }).serialize(correction); - }, +const { Serializer } = jsonapiSerializer; + +import { tutorialAttributes } from './tutorial-attributes.js'; + +const serialize = function (correction) { + return new Serializer('corrections', { + transform: (record) => ({ + ...correction, + hint: record.hint?.value, + tutorials: correction.tutorials.map((tutorial) => ({ + ...tutorial, + userSavedTutorial: { ...tutorial.userSavedTutorial }, + tutorialEvaluation: { ...tutorial.tutorialEvaluation }, + })), + learningMoreTutorials: correction.learningMoreTutorials.map((tutorial) => ({ + ...tutorial, + userSavedTutorial: { ...tutorial.userSavedTutorial }, + tutorialEvaluation: { ...tutorial.tutorialEvaluation }, + })), + }), + attributes: ['solution', 'solutionToDisplay', 'hint', 'tutorials', 'learningMoreTutorials'], + tutorials: tutorialAttributes, + learningMoreTutorials: tutorialAttributes, + typeForAttribute(attribute) { + switch (attribute) { + case 'tutorialEvaluation': + return 'tutorial-evaluation'; + case 'userSavedTutorial': + return 'user-saved-tutorial'; + case 'learningMoreTutorials': + return 'tutorials'; + default: + return attribute; + } + }, + }).serialize(correction); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/country-serializer.js b/api/lib/infrastructure/serializers/jsonapi/country-serializer.js index 9c70500bb13..952edf84290 100644 --- a/api/lib/infrastructure/serializers/jsonapi/country-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/country-serializer.js @@ -1,12 +1,14 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(country) { - return new Serializer('country', { - attributes: ['code', 'name'], - transform(country) { - return { ...country, id: `${country.code}_${country.matcher}` }; - }, - }).serialize(country); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (country) { + return new Serializer('country', { + attributes: ['code', 'name'], + transform(country) { + return { ...country, id: `${country.code}_${country.matcher}` }; + }, + }).serialize(country); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/course-serializer.js b/api/lib/infrastructure/serializers/jsonapi/course-serializer.js index 1891d6d5188..1e1dd66533a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/course-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/course-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(courses) { - return new Serializer('course', { - attributes: ['name', 'description', 'nbChallenges', 'imageUrl'], - }).serialize(courses); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (courses) { + return new Serializer('course', { + attributes: ['name', 'description', 'nbChallenges', 'imageUrl'], + }).serialize(courses); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/deserializer.js b/api/lib/infrastructure/serializers/jsonapi/deserializer.js index 81708ffbb2d..c6ec99dd06c 100644 --- a/api/lib/infrastructure/serializers/jsonapi/deserializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/deserializer.js @@ -1,7 +1,9 @@ -const { Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Deserializer } = jsonapiSerializer; const deserializer = new Deserializer({ keyForAttribute: 'camelCase', }); -module.exports = deserializer; +export { deserializer }; diff --git a/api/lib/infrastructure/serializers/jsonapi/division-serializer.js b/api/lib/infrastructure/serializers/jsonapi/division-serializer.js index 8287b4e4cd8..10f7706c061 100644 --- a/api/lib/infrastructure/serializers/jsonapi/division-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/division-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(divisions) { - return new Serializer('divisions', { - id: 'name', - attributes: ['name'], - }).serialize(divisions); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (divisions) { + return new Serializer('divisions', { + id: 'name', + attributes: ['name'], + }).serialize(divisions); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/email-verification-serializer.js b/api/lib/infrastructure/serializers/jsonapi/email-verification-serializer.js index 5196b295832..b98d8459a2a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/email-verification-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/email-verification-serializer.js @@ -1,12 +1,14 @@ -const { Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - deserialize(payload) { - return new Deserializer().deserialize(payload).then((record) => { - return { - newEmail: record['new-email'].trim()?.toLowerCase(), - password: record['password'], - }; - }); - }, +const { Deserializer } = jsonapiSerializer; + +const deserialize = function (payload) { + return new Deserializer().deserialize(payload).then((record) => { + return { + newEmail: record['new-email'].trim()?.toLowerCase(), + password: record['password'], + }; + }); }; + +export { deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/error-serializer.js b/api/lib/infrastructure/serializers/jsonapi/error-serializer.js index 889f9a9064e..f93cde47ed7 100644 --- a/api/lib/infrastructure/serializers/jsonapi/error-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/error-serializer.js @@ -1,13 +1,15 @@ -const JSONAPIError = require('jsonapi-serializer').Error; +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(infrastructureError) { - return JSONAPIError({ - status: `${infrastructureError.status}`, - title: infrastructureError.title, - detail: infrastructureError.message, - code: infrastructureError.code, - meta: infrastructureError.meta, - }); - }, +const { Error: JSONAPIError } = jsonapiSerializer; + +const serialize = function (infrastructureError) { + return JSONAPIError({ + status: `${infrastructureError.status}`, + title: infrastructureError.title, + detail: infrastructureError.message, + code: infrastructureError.code, + meta: infrastructureError.meta, + }); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/feature-toggle-serializer.js b/api/lib/infrastructure/serializers/jsonapi/feature-toggle-serializer.js index 403c7607017..0ac7b9cb54d 100644 --- a/api/lib/infrastructure/serializers/jsonapi/feature-toggle-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/feature-toggle-serializer.js @@ -1,12 +1,14 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(features) { - return new Serializer('feature-toggles', { - transform(features) { - return { id: 0, ...features }; - }, - attributes: Object.keys(features), - }).serialize(features); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (features) { + return new Serializer('feature-toggles', { + transform(features) { + return { id: 0, ...features }; + }, + attributes: Object.keys(features), + }).serialize(features); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/feedback-serializer.js b/api/lib/infrastructure/serializers/jsonapi/feedback-serializer.js index 95ca1637eec..c64dd43b5d6 100644 --- a/api/lib/infrastructure/serializers/jsonapi/feedback-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/feedback-serializer.js @@ -1,30 +1,33 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); -const Feedback = require('../../orm-models/Feedback.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(feedbacks) { - return new Serializer('feedbacks', { - attributes: ['createdAt', 'content', 'assessment', 'challenge'], - assessment: { ref: 'id' }, - challenge: { ref: 'id' }, - transform(json) { - const feedback = Object.assign({}, json); - feedback.assessment = { id: json.assessmentId }; - feedback.challenge = { id: json.challengeId }; - return feedback; - }, - }).serialize(feedbacks); - }, +const { Serializer, Deserializer } = jsonapiSerializer; - deserialize(json, userAgent) { - return new Deserializer() - .deserialize(json, function (err, feedback) { - feedback.assessmentId = json.data.relationships.assessment.data.id; - feedback.challengeId = json.data.relationships.challenge.data.id; - feedback.userAgent = userAgent; - }) - .then((deserializedFeedback) => { - return new Feedback(deserializedFeedback); - }); - }, +import { Feedback } from '../../orm-models/Feedback.js'; + +const serialize = function (feedbacks) { + return new Serializer('feedbacks', { + attributes: ['createdAt', 'content', 'assessment', 'challenge'], + assessment: { ref: 'id' }, + challenge: { ref: 'id' }, + transform(json) { + const feedback = Object.assign({}, json); + feedback.assessment = { id: json.assessmentId }; + feedback.challenge = { id: json.challengeId }; + return feedback; + }, + }).serialize(feedbacks); +}; + +const deserialize = function (json, userAgent) { + return new Deserializer() + .deserialize(json, function (err, feedback) { + feedback.assessmentId = json.data.relationships.assessment.data.id; + feedback.challengeId = json.data.relationships.challenge.data.id; + feedback.userAgent = userAgent; + }) + .then((deserializedFeedback) => { + return new Feedback(deserializedFeedback); + }); }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/framework-areas-serializer.js b/api/lib/infrastructure/serializers/jsonapi/framework-areas-serializer.js index f8415e8ffad..b9e66df71b5 100644 --- a/api/lib/infrastructure/serializers/jsonapi/framework-areas-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/framework-areas-serializer.js @@ -1,54 +1,56 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(framework, { withoutThematics = false } = {}) { - return new Serializer('area', { +const { Serializer } = jsonapiSerializer; + +const serialize = function (framework, { withoutThematics = false } = {}) { + return new Serializer('area', { + ref: 'id', + attributes: ['code', 'title', 'color', 'competences'], + + competences: { + include: true, ref: 'id', - attributes: ['code', 'title', 'color', 'competences'], + attributes: ['name', 'index', 'thematics'], - competences: { + thematics: { include: true, ref: 'id', - attributes: ['name', 'index', 'thematics'], + attributes: ['name', 'index', 'tubes'], - thematics: { + tubes: { include: true, ref: 'id', - attributes: ['name', 'index', 'tubes'], - - tubes: { - include: true, - ref: 'id', - attributes: ['name', 'practicalTitle', 'practicalDescription', 'mobile', 'tablet'], - }, + attributes: ['name', 'practicalTitle', 'practicalDescription', 'mobile', 'tablet'], }, }, + }, - transform(area) { - if (withoutThematics) { - return area; - } - area.competences.forEach((competence) => { - competence.thematics = framework.thematics - .filter((thematic) => { - return competence.thematicIds.includes(thematic.id); - }) - .map((thematic) => { - return { - ...thematic, - tubes: framework.tubes - .filter(({ id }) => { - return thematic.tubeIds.includes(id); - }) - .map((tube) => ({ ...tube, mobile: tube.isMobileCompliant, tablet: tube.isTabletCompliant })), - }; - }) - .filter((thematic) => { - return thematic.tubes.length > 0; - }); - }); + transform(area) { + if (withoutThematics) { return area; - }, - }).serialize(framework.areas); - }, + } + area.competences.forEach((competence) => { + competence.thematics = framework.thematics + .filter((thematic) => { + return competence.thematicIds.includes(thematic.id); + }) + .map((thematic) => { + return { + ...thematic, + tubes: framework.tubes + .filter(({ id }) => { + return thematic.tubeIds.includes(id); + }) + .map((tube) => ({ ...tube, mobile: tube.isMobileCompliant, tablet: tube.isTabletCompliant })), + }; + }) + .filter((thematic) => { + return thematic.tubes.length > 0; + }); + }); + return area; + }, + }).serialize(framework.areas); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/framework-serializer.js b/api/lib/infrastructure/serializers/jsonapi/framework-serializer.js index 26ab6a0ca66..d5348dbf314 100644 --- a/api/lib/infrastructure/serializers/jsonapi/framework-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/framework-serializer.js @@ -1,50 +1,52 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(frameworks) { - return new Serializer('framework', { - ref: 'id', - attributes: ['name', 'areas'], - areas: { - ref: true, - ignoreRelationshipData: true, - relationshipLinks: { - related: (framework) => `/api/admin/frameworks/${framework.id}/areas`, - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (frameworks) { + return new Serializer('framework', { + ref: 'id', + attributes: ['name', 'areas'], + areas: { + ref: true, + ignoreRelationshipData: true, + relationshipLinks: { + related: (framework) => `/api/admin/frameworks/${framework.id}/areas`, }, - transform: (framework) => ({ - ...framework, - areas: true, // forces areas relationship - }), - }).serialize(frameworks); - }, + }, + transform: (framework) => ({ + ...framework, + areas: true, // forces areas relationship + }), + }).serialize(frameworks); +}; - serializeDeepWithoutSkills(frameworks) { - return new Serializer('framework', { +const serializeDeepWithoutSkills = function (frameworks) { + return new Serializer('framework', { + ref: 'id', + attributes: ['name', 'areas'], + areas: { + include: true, ref: 'id', - attributes: ['name', 'areas'], - areas: { + attributes: ['code', 'title', 'color', 'competences'], + competences: { include: true, ref: 'id', - attributes: ['code', 'title', 'color', 'competences'], - competences: { + attributes: ['name', 'index', 'thematics'], + + thematics: { include: true, ref: 'id', - attributes: ['name', 'index', 'thematics'], + attributes: ['name', 'index', 'tubes'], - thematics: { + tubes: { include: true, ref: 'id', - attributes: ['name', 'index', 'tubes'], - - tubes: { - include: true, - ref: 'id', - attributes: ['name', 'practicalTitle', 'practicalDescription', 'isMobileCompliant', 'isTabletCompliant'], - }, + attributes: ['name', 'practicalTitle', 'practicalDescription', 'isMobileCompliant', 'isTabletCompliant'], }, }, }, - }).serialize(frameworks); - }, + }, + }).serialize(frameworks); }; + +export { serialize, serializeDeepWithoutSkills }; diff --git a/api/lib/infrastructure/serializers/jsonapi/group-serializer.js b/api/lib/infrastructure/serializers/jsonapi/group-serializer.js index 13d5d7dc5f8..115948b9064 100644 --- a/api/lib/infrastructure/serializers/jsonapi/group-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/group-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(groups) { - return new Serializer('groups', { - id: 'name', - attributes: ['name'], - }).serialize(groups); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (groups) { + return new Serializer('groups', { + id: 'name', + attributes: ['name'], + }).serialize(groups); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/jury-certification-serializer.js b/api/lib/infrastructure/serializers/jsonapi/jury-certification-serializer.js index e37922caceb..ec5630de4fc 100644 --- a/api/lib/infrastructure/serializers/jsonapi/jury-certification-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/jury-certification-serializer.js @@ -1,70 +1,72 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(juryCertification) { - return new Serializer('certifications', { - transform(juryCertification) { - return { - id: juryCertification.certificationCourseId, - ...juryCertification, - competencesWithMark: juryCertification.competenceMarks, - }; - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (juryCertification) { + return new Serializer('certifications', { + transform(juryCertification) { + return { + id: juryCertification.certificationCourseId, + ...juryCertification, + competencesWithMark: juryCertification.competenceMarks, + }; + }, + attributes: [ + 'sessionId', + 'assessmentId', + 'userId', + 'firstName', + 'lastName', + 'birthdate', + 'sex', + 'birthplace', + 'birthCountry', + 'birthINSEECode', + 'birthPostalCode', + 'createdAt', + 'completedAt', + 'status', + 'isCancelled', + 'isPublished', + 'juryId', + 'pixScore', + 'competencesWithMark', + 'commentForCandidate', + 'commentForOrganization', + 'commentForJury', + 'commonComplementaryCertificationCourseResults', + 'complementaryCertificationCourseResultsWithExternal', + 'certificationIssueReports', + ], + + commonComplementaryCertificationCourseResults: { + ref: 'id', + attributes: ['label', 'status'], + }, + complementaryCertificationCourseResultsWithExternal: { + ref: 'complementaryCertificationCourseId', attributes: [ - 'sessionId', - 'assessmentId', - 'userId', - 'firstName', - 'lastName', - 'birthdate', - 'sex', - 'birthplace', - 'birthCountry', - 'birthINSEECode', - 'birthPostalCode', - 'createdAt', - 'completedAt', - 'status', - 'isCancelled', - 'isPublished', - 'juryId', - 'pixScore', - 'competencesWithMark', - 'commentForCandidate', - 'commentForOrganization', - 'commentForJury', - 'commonComplementaryCertificationCourseResults', - 'complementaryCertificationCourseResultsWithExternal', - 'certificationIssueReports', + 'complementaryCertificationCourseId', + 'pixResult', + 'externalResult', + 'finalResult', + 'allowedExternalLevels', ], - - commonComplementaryCertificationCourseResults: { - ref: 'id', - attributes: ['label', 'status'], - }, - complementaryCertificationCourseResultsWithExternal: { - ref: 'complementaryCertificationCourseId', - attributes: [ - 'complementaryCertificationCourseId', - 'pixResult', - 'externalResult', - 'finalResult', - 'allowedExternalLevels', - ], - }, - certificationIssueReports: { - ref: 'id', - attributes: [ - 'category', - 'description', - 'subcategory', - 'questionNumber', - 'isImpactful', - 'resolvedAt', - 'resolution', - 'hasBeenAutomaticallyResolved', - ], - }, - }).serialize(juryCertification); - }, + }, + certificationIssueReports: { + ref: 'id', + attributes: [ + 'category', + 'description', + 'subcategory', + 'questionNumber', + 'isImpactful', + 'resolvedAt', + 'resolution', + 'hasBeenAutomaticallyResolved', + ], + }, + }).serialize(juryCertification); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/jury-certification-summary-serializer.js b/api/lib/infrastructure/serializers/jsonapi/jury-certification-summary-serializer.js index bbbef996aaf..54e67adccf4 100644 --- a/api/lib/infrastructure/serializers/jsonapi/jury-certification-summary-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/jury-certification-summary-serializer.js @@ -1,38 +1,41 @@ -const omit = require('lodash/omit'); -const get = require('lodash/get'); +import lodash from 'lodash'; -const { Serializer } = require('jsonapi-serializer'); +const { Serializer } = jsonapiSerializer; -module.exports = { - serialize(juryCertificationSummary, meta) { - return new Serializer('jury-certification-summary', { - transform(juryCertificationSummary) { - const result = omit(juryCertificationSummary, 'certificationIssueReports'); - result.examinerComment = get(juryCertificationSummary, 'certificationIssueReports[0].description'); - result.numberOfCertificationIssueReports = juryCertificationSummary.certificationIssueReports.length; - result.numberOfCertificationIssueReportsWithRequiredAction = - juryCertificationSummary.certificationIssueReports.filter( - (issueReport) => issueReport.isImpactful && issueReport.resolvedAt === null - ).length; - return result; - }, - attributes: [ - 'firstName', - 'lastName', - 'status', - 'pixScore', - 'createdAt', - 'completedAt', - 'isPublished', - 'isCancelled', - 'examinerComment', - 'numberOfCertificationIssueReports', - 'numberOfCertificationIssueReportsWithRequiredAction', - 'hasSeenEndTestScreen', - 'isFlaggedAborted', - 'complementaryCertificationTakenLabels', - ], - meta, - }).serialize(juryCertificationSummary); - }, +const { omit, get } = lodash; + +import jsonapiSerializer from 'jsonapi-serializer'; + +const serialize = function (juryCertificationSummary, meta) { + return new Serializer('jury-certification-summary', { + transform(juryCertificationSummary) { + const result = omit(juryCertificationSummary, 'certificationIssueReports'); + result.examinerComment = get(juryCertificationSummary, 'certificationIssueReports[0].description'); + result.numberOfCertificationIssueReports = juryCertificationSummary.certificationIssueReports.length; + result.numberOfCertificationIssueReportsWithRequiredAction = + juryCertificationSummary.certificationIssueReports.filter( + (issueReport) => issueReport.isImpactful && issueReport.resolvedAt === null + ).length; + return result; + }, + attributes: [ + 'firstName', + 'lastName', + 'status', + 'pixScore', + 'createdAt', + 'completedAt', + 'isPublished', + 'isCancelled', + 'examinerComment', + 'numberOfCertificationIssueReports', + 'numberOfCertificationIssueReportsWithRequiredAction', + 'hasSeenEndTestScreen', + 'isFlaggedAborted', + 'complementaryCertificationTakenLabels', + ], + meta, + }).serialize(juryCertificationSummary); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/jury-session-serializer.js b/api/lib/infrastructure/serializers/jsonapi/jury-session-serializer.js index 62f24eafd01..87487b433ca 100644 --- a/api/lib/infrastructure/serializers/jsonapi/jury-session-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/jury-session-serializer.js @@ -1,80 +1,82 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serializeForPaginatedList(jurySessionsForPaginatedList) { - const { jurySessions, pagination } = jurySessionsForPaginatedList; - return this.serialize(jurySessions, undefined, pagination); - }, +const { Serializer } = jsonapiSerializer; - serialize(jurySessions, hasSupervisorAccess, meta) { - return new Serializer('sessions', { - attributes: [ - 'certificationCenterName', - 'certificationCenterType', - 'certificationCenterId', - 'certificationCenterExternalId', - 'address', - 'room', - 'examiner', - 'date', - 'time', - 'accessCode', - 'status', - 'description', - 'examinerGlobalComment', - 'finalizedAt', - 'resultsSentToPrescriberAt', - 'publishedAt', - 'juryComment', - 'juryCommentAuthorId', - 'juryCommentedAt', - 'hasSupervisorAccess', - 'hasJoiningIssue', - 'hasIncident', - // included - 'assignedCertificationOfficer', - 'juryCommentAuthor', - // links - 'juryCertificationSummaries', - ], - juryCertificationSummaries: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/admin/sessions/${parent.id}/jury-certification-summaries`; - }, +const serialize = function (jurySessions, hasSupervisorAccess, meta) { + return new Serializer('sessions', { + attributes: [ + 'certificationCenterName', + 'certificationCenterType', + 'certificationCenterId', + 'certificationCenterExternalId', + 'address', + 'room', + 'examiner', + 'date', + 'time', + 'accessCode', + 'status', + 'description', + 'examinerGlobalComment', + 'finalizedAt', + 'resultsSentToPrescriberAt', + 'publishedAt', + 'juryComment', + 'juryCommentAuthorId', + 'juryCommentedAt', + 'hasSupervisorAccess', + 'hasJoiningIssue', + 'hasIncident', + // included + 'assignedCertificationOfficer', + 'juryCommentAuthor', + // links + 'juryCertificationSummaries', + ], + juryCertificationSummaries: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/admin/sessions/${parent.id}/jury-certification-summaries`; }, }, - assignedCertificationOfficer: { - ref: 'id', - included: true, - attributes: ['firstName', 'lastName'], - }, - juryCommentAuthor: { - ref: 'id', - included: true, - attributes: ['firstName', 'lastName'], - }, - transform(jurySession) { - const transformedJurySession = Object.assign({}, jurySession); - transformedJurySession.status = jurySession.status; - if (hasSupervisorAccess !== undefined) { - transformedJurySession.hasSupervisorAccess = hasSupervisorAccess; - } - return transformedJurySession; - }, - typeForAttribute: function (attribute) { - if (attribute === 'assignedCertificationOfficer') { - return 'user'; - } - if (attribute === 'juryCommentAuthor') { - return 'user'; - } - return attribute; - }, - meta, - }).serialize(jurySessions); - }, + }, + assignedCertificationOfficer: { + ref: 'id', + included: true, + attributes: ['firstName', 'lastName'], + }, + juryCommentAuthor: { + ref: 'id', + included: true, + attributes: ['firstName', 'lastName'], + }, + transform(jurySession) { + const transformedJurySession = Object.assign({}, jurySession); + transformedJurySession.status = jurySession.status; + if (hasSupervisorAccess !== undefined) { + transformedJurySession.hasSupervisorAccess = hasSupervisorAccess; + } + return transformedJurySession; + }, + typeForAttribute: function (attribute) { + if (attribute === 'assignedCertificationOfficer') { + return 'user'; + } + if (attribute === 'juryCommentAuthor') { + return 'user'; + } + return attribute; + }, + meta, + }).serialize(jurySessions); }; + +const serializeForPaginatedList = function (jurySessionsForPaginatedList, injectedSerialize = serialize) { + const { jurySessions, pagination } = jurySessionsForPaginatedList; + return injectedSerialize(jurySessions, undefined, pagination); +}; + +export { serializeForPaginatedList, serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/membership-serializer.js b/api/lib/infrastructure/serializers/jsonapi/membership-serializer.js index fab17d8c3c1..0bc3f9be1ee 100644 --- a/api/lib/infrastructure/serializers/jsonapi/membership-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/membership-serializer.js @@ -1,176 +1,179 @@ -const { Serializer } = require('jsonapi-serializer'); -const Membership = require('../../../domain/models/Membership.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(membership, meta) { - return new Serializer('memberships', { - transform(record) { - if (!record.user) { - delete record.user; - } +const { Serializer } = jsonapiSerializer; - if (!record.organization) { - delete record.organization; - } - return record; - }, - attributes: ['organization', 'organizationRole', 'user'], - organization: { +import { Membership } from '../../../domain/models/Membership.js'; + +const serialize = function (membership, meta) { + return new Serializer('memberships', { + transform(record) { + if (!record.user) { + delete record.user; + } + + if (!record.organization) { + delete record.organization; + } + return record; + }, + attributes: ['organization', 'organizationRole', 'user'], + organization: { + ref: 'id', + included: true, + attributes: [ + 'code', + 'name', + 'type', + 'isManagingStudents', + 'externalId', + 'campaigns', + 'targetProfiles', + 'memberships', + 'organizationInvitations', + ], + campaigns: { ref: 'id', - included: true, - attributes: [ - 'code', - 'name', - 'type', - 'isManagingStudents', - 'externalId', - 'campaigns', - 'targetProfiles', - 'memberships', - 'organizationInvitations', - ], - campaigns: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/campaigns`; - }, + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/campaigns`; }, }, - targetProfiles: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/target-profiles`; - }, - }, - }, - memberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/memberships`; - }, + }, + targetProfiles: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/target-profiles`; }, }, - organizationInvitations: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/invitations`; - }, + }, + memberships: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/memberships`; }, }, }, - user: { + organizationInvitations: { ref: 'id', - included: true, - attributes: ['firstName', 'lastName', 'email'], + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/invitations`; + }, + }, }, - meta, - }).serialize(membership); - }, + }, + user: { + ref: 'id', + included: true, + attributes: ['firstName', 'lastName', 'email'], + }, + meta, + }).serialize(membership); +}; - serializeForAdmin(membership, meta) { - return new Serializer('organization-memberships', { - transform(record) { - if (!record.user) { - delete record.user; - } +const serializeForAdmin = function (membership, meta) { + return new Serializer('organization-memberships', { + transform(record) { + if (!record.user) { + delete record.user; + } - if (!record.organization) { - delete record.organization; - } - return record; - }, - attributes: ['organization', 'organizationRole', 'user'], - organization: { + if (!record.organization) { + delete record.organization; + } + return record; + }, + attributes: ['organization', 'organizationRole', 'user'], + organization: { + ref: 'id', + included: true, + attributes: [ + 'code', + 'name', + 'type', + 'isManagingStudents', + 'externalId', + 'campaigns', + 'targetProfiles', + 'organizationMemberships', + 'students', + 'organizationInvitations', + ], + campaigns: { ref: 'id', - included: true, - attributes: [ - 'code', - 'name', - 'type', - 'isManagingStudents', - 'externalId', - 'campaigns', - 'targetProfiles', - 'organizationMemberships', - 'students', - 'organizationInvitations', - ], - campaigns: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/campaigns`; - }, + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/campaigns`; }, }, - targetProfiles: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/target-profiles`; - }, - }, - }, - organizationMemberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/memberships`; - }, + }, + targetProfiles: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/target-profiles`; }, }, - students: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/students`; - }, + }, + organizationMemberships: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/memberships`; }, }, - organizationInvitations: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/invitations`; - }, + }, + students: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/students`; }, }, }, - user: { + organizationInvitations: { ref: 'id', - included: true, - attributes: ['firstName', 'lastName', 'email'], + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/invitations`; + }, + }, }, - meta, - }).serialize(membership); - }, + }, + user: { + ref: 'id', + included: true, + attributes: ['firstName', 'lastName', 'email'], + }, + meta, + }).serialize(membership); +}; - deserialize(json) { - return new Membership({ - id: json.data.id, - organizationRole: json.data.attributes['organization-role'], - }); - }, +const deserialize = function (json) { + return new Membership({ + id: json.data.id, + organizationRole: json.data.attributes['organization-role'], + }); }; + +export { serialize, serializeForAdmin, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer.js b/api/lib/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer.js index 536aecb0f83..f128c2d137a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer.js @@ -1,18 +1,20 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(oidcIdentityProviders) { - return new Serializer('oidc-identity-providers', { - transform(oidcIdentityProvider) { - return { - id: oidcIdentityProvider.slug, - code: oidcIdentityProvider.code, - organizationName: oidcIdentityProvider.organizationName, - hasLogoutUrl: oidcIdentityProvider.hasLogoutUrl, - source: oidcIdentityProvider.source, - }; - }, - attributes: ['code', 'organizationName', 'hasLogoutUrl', 'source'], - }).serialize(oidcIdentityProviders); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (oidcIdentityProviders) { + return new Serializer('oidc-identity-providers', { + transform(oidcIdentityProvider) { + return { + id: oidcIdentityProvider.slug, + code: oidcIdentityProvider.code, + organizationName: oidcIdentityProvider.organizationName, + hasLogoutUrl: oidcIdentityProvider.hasLogoutUrl, + source: oidcIdentityProvider.source, + }; + }, + attributes: ['code', 'organizationName', 'hasLogoutUrl', 'source'], + }).serialize(oidcIdentityProviders); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/oidc-serializer.js b/api/lib/infrastructure/serializers/jsonapi/oidc-serializer.js index e0c1a804001..48d5668c975 100644 --- a/api/lib/infrastructure/serializers/jsonapi/oidc-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/oidc-serializer.js @@ -1,15 +1,17 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(authenticationContent) { - return new Serializer('user-oidc-authentication-requests', { - attributes: [ - 'fullNameFromPix', - 'fullNameFromExternalIdentityProvider', - 'email', - 'username', - 'authenticationMethods', - ], - }).serialize(authenticationContent); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (authenticationContent) { + return new Serializer('user-oidc-authentication-requests', { + attributes: [ + 'fullNameFromPix', + 'fullNameFromExternalIdentityProvider', + 'email', + 'username', + 'authenticationMethods', + ], + }).serialize(authenticationContent); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization-for-admin-serializer.js index db14943d808..f8e27b51751 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization-for-admin-serializer.js @@ -1,95 +1,98 @@ -const { Serializer } = require('jsonapi-serializer'); -const _ = require('lodash'); -const OrganizationForAdmin = require('../../../domain/models/organizations-administration/Organization'); -const Tag = require('../../../domain/models/Tag.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(organizations, meta) { - return new Serializer('organizations', { - attributes: [ - 'name', - 'type', - 'logoUrl', - 'externalId', - 'provinceCode', - 'isManagingStudents', - 'credit', - 'email', - 'documentationUrl', - 'createdBy', - 'createdAt', - 'showNPS', - 'formNPSUrl', - 'showSkills', - 'archivedAt', - 'archivistFullName', - 'dataProtectionOfficerFirstName', - 'dataProtectionOfficerLastName', - 'dataProtectionOfficerEmail', - 'creatorFullName', - 'tags', - 'organizationMemberships', - 'targetProfileSummaries', - 'identityProviderForCampaigns', - ], - organizationMemberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/organizations/${parent.id}/memberships`; - }, +const { Serializer } = jsonapiSerializer; + +import _ from 'lodash'; +import { OrganizationForAdmin } from '../../../domain/models/organizations-administration/Organization.js'; +import { Tag } from '../../../domain/models/Tag.js'; + +const serialize = function (organizations, meta) { + return new Serializer('organizations', { + attributes: [ + 'name', + 'type', + 'logoUrl', + 'externalId', + 'provinceCode', + 'isManagingStudents', + 'credit', + 'email', + 'documentationUrl', + 'createdBy', + 'createdAt', + 'showNPS', + 'formNPSUrl', + 'showSkills', + 'archivedAt', + 'archivistFullName', + 'dataProtectionOfficerFirstName', + 'dataProtectionOfficerLastName', + 'dataProtectionOfficerEmail', + 'creatorFullName', + 'tags', + 'organizationMemberships', + 'targetProfileSummaries', + 'identityProviderForCampaigns', + ], + organizationMemberships: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/organizations/${parent.id}/memberships`; }, }, - targetProfileSummaries: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/admin/organizations/${parent.id}/target-profile-summaries`; - }, + }, + targetProfileSummaries: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/admin/organizations/${parent.id}/target-profile-summaries`; }, }, - tags: { - ref: 'id', - included: true, - attributes: ['id', 'name'], - }, - meta, - }).serialize(organizations); - }, + }, + tags: { + ref: 'id', + included: true, + attributes: ['id', 'name'], + }, + meta, + }).serialize(organizations); +}; - deserialize(json) { - const attributes = json.data.attributes; - const relationships = json.data.relationships; +const deserialize = function (json) { + const attributes = json.data.attributes; + const relationships = json.data.relationships; - let tags = []; - if (relationships && relationships.tags) { - tags = relationships.tags.data.map((tag) => new Tag({ id: parseInt(tag.id) })); - } + let tags = []; + if (relationships && relationships.tags) { + tags = relationships.tags.data.map((tag) => new Tag({ id: parseInt(tag.id) })); + } - const organization = new OrganizationForAdmin({ - id: _.isNil(json.data.id) ? null : parseInt(json.data.id), - name: attributes.name, - type: attributes.type, - email: attributes.email, - credit: attributes.credit, - logoUrl: attributes['logo-url'], - externalId: attributes['external-id'], - provinceCode: attributes['province-code'], - isManagingStudents: attributes['is-managing-students'], - createdBy: attributes['created-by'], - documentationUrl: attributes['documentation-url'], - showSkills: attributes['show-skills'], - identityProviderForCampaigns: attributes['identity-provider-for-campaigns'], - dataProtectionOfficerFirstName: attributes['data-protection-officer-first-name'], - dataProtectionOfficerLastName: attributes['data-protection-officer-last-name'], - dataProtectionOfficerEmail: attributes['data-protection-officer-email'], - tags, - }); + const organization = new OrganizationForAdmin({ + id: _.isNil(json.data.id) ? null : parseInt(json.data.id), + name: attributes.name, + type: attributes.type, + email: attributes.email, + credit: attributes.credit, + logoUrl: attributes['logo-url'], + externalId: attributes['external-id'], + provinceCode: attributes['province-code'], + isManagingStudents: attributes['is-managing-students'], + createdBy: attributes['created-by'], + documentationUrl: attributes['documentation-url'], + showSkills: attributes['show-skills'], + identityProviderForCampaigns: attributes['identity-provider-for-campaigns'], + dataProtectionOfficerFirstName: attributes['data-protection-officer-first-name'], + dataProtectionOfficerLastName: attributes['data-protection-officer-last-name'], + dataProtectionOfficerEmail: attributes['data-protection-officer-email'], + tags, + }); - return organization; - }, + return organization; }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization-invitation-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization-invitation-serializer.js index 72d35d7241c..e3c8e1dcdd2 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization-invitation-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization-invitation-serializer.js @@ -1,19 +1,21 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(invitations) { - return new Serializer('organization-invitations', { - attributes: ['organizationId', 'organizationName', 'email', 'status', 'updatedAt', 'role'], - }).serialize(invitations); - }, +const { Serializer, Deserializer } = jsonapiSerializer; - deserializeForCreateOrganizationInvitationAndSendEmail(payload) { - return new Deserializer().deserialize(payload).then((record) => { - return { - role: record.role, - lang: record.lang, - email: record.email?.trim().toLowerCase(), - }; - }); - }, +const serialize = function (invitations) { + return new Serializer('organization-invitations', { + attributes: ['organizationId', 'organizationName', 'email', 'status', 'updatedAt', 'role'], + }).serialize(invitations); }; + +const deserializeForCreateOrganizationInvitationAndSendEmail = function (payload) { + return new Deserializer().deserialize(payload).then((record) => { + return { + role: record.role, + lang: record.lang, + email: record.email?.trim().toLowerCase(), + }; + }); +}; + +export { serialize, deserializeForCreateOrganizationInvitationAndSendEmail }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization-learner-activity-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization-learner-activity-serializer.js index 41e391e7074..28f371a39ad 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization-learner-activity-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization-learner-activity-serializer.js @@ -1,25 +1,27 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(organizationLearnerActivity) { - return new Serializer('organization-learner-activity', { - transform: (organizationLearnerActivity) => ({ - ...organizationLearnerActivity, - organizationLearnerParticipations: organizationLearnerActivity.participations, - organizationLearnerStatistics: organizationLearnerActivity.statistics, - }), - id: 'organizationLearnerId', - attributes: ['organizationLearnerParticipations', 'organizationLearnerStatistics'], - organizationLearnerParticipations: { - ref: 'id', - includes: true, - attributes: ['campaignType', 'campaignName', 'createdAt', 'sharedAt', 'status', 'campaignId'], - }, - organizationLearnerStatistics: { - ref: 'campaignType', - includes: true, - attributes: ['total', 'shared', 'started', 'to_share'], - }, - }).serialize(organizationLearnerActivity); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (organizationLearnerActivity) { + return new Serializer('organization-learner-activity', { + transform: (organizationLearnerActivity) => ({ + ...organizationLearnerActivity, + organizationLearnerParticipations: organizationLearnerActivity.participations, + organizationLearnerStatistics: organizationLearnerActivity.statistics, + }), + id: 'organizationLearnerId', + attributes: ['organizationLearnerParticipations', 'organizationLearnerStatistics'], + organizationLearnerParticipations: { + ref: 'id', + includes: true, + attributes: ['campaignType', 'campaignName', 'createdAt', 'sharedAt', 'status', 'campaignId'], + }, + organizationLearnerStatistics: { + ref: 'campaignType', + includes: true, + attributes: ['total', 'shared', 'started', 'to_share'], + }, + }).serialize(organizationLearnerActivity); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer.js index 0e6c9f62467..376f6b9a25f 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer.js @@ -1,19 +1,21 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(organizationLearner) { - return new Serializer('organization-learner', { - attributes: [ - 'lastName', - 'firstName', - 'email', - 'username', - 'authenticationMethods', - 'division', - 'group', - 'isCertifiable', - 'certifiableAt', - ], - }).serialize(organizationLearner); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (organizationLearner) { + return new Serializer('organization-learner', { + attributes: [ + 'lastName', + 'firstName', + 'email', + 'username', + 'authenticationMethods', + 'division', + 'group', + 'isCertifiable', + 'certifiableAt', + ], + }).serialize(organizationLearner); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization-learner-identity-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization-learner-identity-serializer.js index 0eea6c12107..24a0211ac29 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization-learner-identity-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization-learner-identity-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(organizationLearnerIdentity) { - return new Serializer('organization-learner-identity', { - attributes: ['lastName', 'firstName'], - }).serialize(organizationLearnerIdentity); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (organizationLearnerIdentity) { + return new Serializer('organization-learner-identity', { + attributes: ['lastName', 'firstName'], + }).serialize(organizationLearnerIdentity); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization-member-identity-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization-member-identity-serializer.js index 0697b7f56dc..13aeb6d762a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization-member-identity-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization-member-identity-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(model) { - return new Serializer('member-identity', { - id: 'id', - attributes: ['firstName', 'lastName'], - }).serialize(model); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (model) { + return new Serializer('member-identity', { + id: 'id', + attributes: ['firstName', 'lastName'], + }).serialize(model); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization-places-capacity-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization-places-capacity-serializer.js index d7253d037bb..ebed8ab09d1 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization-places-capacity-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization-places-capacity-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(places) { - return new Serializer('organization-places-capacity', { - attributes: ['categories'], - }).serialize(places); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (places) { + return new Serializer('organization-places-capacity', { + attributes: ['categories'], + }).serialize(places); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization-serializer.js index 9e76d92d353..40bf7fcf69f 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization-serializer.js @@ -1,82 +1,85 @@ -const { Serializer } = require('jsonapi-serializer'); -const Organization = require('../../../domain/models/Organization.js'); -const Tag = require('../../../domain/models/Tag.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(organizations, meta) { - return new Serializer('organizations', { - attributes: [ - 'name', - 'type', - 'logoUrl', - 'externalId', - 'provinceCode', - 'isManagingStudents', - 'credit', - 'email', - 'memberships', - 'targetProfiles', - 'tags', - 'createdBy', - 'documentationUrl', - 'showNPS', - 'formNPSUrl', - 'showSkills', - ], - memberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/organizations/${parent.id}/memberships`; - }, +const { Serializer } = jsonapiSerializer; + +import { Organization } from '../../../domain/models/Organization.js'; +import { Tag } from '../../../domain/models/Tag.js'; + +const serialize = function (organizations, meta) { + return new Serializer('organizations', { + attributes: [ + 'name', + 'type', + 'logoUrl', + 'externalId', + 'provinceCode', + 'isManagingStudents', + 'credit', + 'email', + 'memberships', + 'targetProfiles', + 'tags', + 'createdBy', + 'documentationUrl', + 'showNPS', + 'formNPSUrl', + 'showSkills', + ], + memberships: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/organizations/${parent.id}/memberships`; }, }, - targetProfiles: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/target-profiles`; - }, + }, + targetProfiles: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/target-profiles`; }, }, - tags: { - ref: 'id', - included: true, - attributes: ['id', 'name'], - }, - meta, - }).serialize(organizations); - }, + }, + tags: { + ref: 'id', + included: true, + attributes: ['id', 'name'], + }, + meta, + }).serialize(organizations); +}; - deserialize(json) { - const attributes = json.data.attributes; - const relationships = json.data.relationships; +const deserialize = function (json) { + const attributes = json.data.attributes; + const relationships = json.data.relationships; - let tags = []; - if (relationships && relationships.tags) { - tags = relationships.tags.data.map((tag) => new Tag({ id: parseInt(tag.id) })); - } + let tags = []; + if (relationships && relationships.tags) { + tags = relationships.tags.data.map((tag) => new Tag({ id: parseInt(tag.id) })); + } - const organization = new Organization({ - id: parseInt(json.data.id), - name: attributes.name, - type: attributes.type, - email: attributes.email, - credit: attributes.credit, - logoUrl: attributes['logo-url'], - externalId: attributes['external-id'], - provinceCode: attributes['province-code'], - isManagingStudents: attributes['is-managing-students'], - createdBy: attributes['created-by'], - documentationUrl: attributes['documentation-url'], - showSkills: attributes['show-skills'], - tags, - }); + const organization = new Organization({ + id: parseInt(json.data.id), + name: attributes.name, + type: attributes.type, + email: attributes.email, + credit: attributes.credit, + logoUrl: attributes['logo-url'], + externalId: attributes['external-id'], + provinceCode: attributes['province-code'], + isManagingStudents: attributes['is-managing-students'], + createdBy: attributes['created-by'], + documentationUrl: attributes['documentation-url'], + showSkills: attributes['show-skills'], + tags, + }); - return organization; - }, + return organization; }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization/organization-participants-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization/organization-participants-serializer.js index b8e5fdd58b2..808fad16f3e 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization/organization-participants-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization/organization-participants-serializer.js @@ -1,21 +1,23 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize({ organizationParticipants, meta }) { - return new Serializer('organization-participants', { - id: 'id', - attributes: [ - 'firstName', - 'lastName', - 'participationCount', - 'lastParticipationDate', - 'campaignName', - 'campaignType', - 'participationStatus', - 'isCertifiable', - 'certifiableAt', - ], - meta, - }).serialize(organizationParticipants); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function ({ organizationParticipants, meta }) { + return new Serializer('organization-participants', { + id: 'id', + attributes: [ + 'firstName', + 'lastName', + 'participationCount', + 'lastParticipationDate', + 'campaignName', + 'campaignType', + 'participationStatus', + 'isCertifiable', + 'certifiableAt', + ], + meta, + }).serialize(organizationParticipants); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization/organization-place-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization/organization-place-serializer.js index 68799aa695d..9364f5b8e5b 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization/organization-place-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization/organization-place-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(places) { - return new Serializer('organization-place', { - attributes: ['count', 'activationDate', 'expirationDate', 'reference', 'category', 'status', 'creatorFullName'], - }).serialize(places); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (places) { + return new Serializer('organization-place', { + attributes: ['count', 'activationDate', 'expirationDate', 'reference', 'category', 'status', 'creatorFullName'], + }).serialize(places); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-management-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-management-serializer.js index 68799aa695d..9364f5b8e5b 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-management-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-management-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(places) { - return new Serializer('organization-place', { - attributes: ['count', 'activationDate', 'expirationDate', 'reference', 'category', 'status', 'creatorFullName'], - }).serialize(places); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (places) { + return new Serializer('organization-place', { + attributes: ['count', 'activationDate', 'expirationDate', 'reference', 'category', 'status', 'creatorFullName'], + }).serialize(places); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer.js index 19943e919fc..e3aed6cc177 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer.js @@ -1,13 +1,13 @@ -module.exports = { - deserialize(json) { - return { - organizationId: json.data.attributes['organization-id'], - count: json.data.attributes['count'], - activationDate: json.data.attributes['activation-date'], - expirationDate: json.data.attributes['expiration-date'], - reference: json.data.attributes['reference'], - category: json.data.attributes['category'], - createdBy: json.data.attributes['created-by'], - }; - }, +const deserialize = function (json) { + return { + organizationId: json.data.attributes['organization-id'], + count: json.data.attributes['count'], + activationDate: json.data.attributes['activation-date'], + expirationDate: json.data.attributes['expiration-date'], + reference: json.data.attributes['reference'], + category: json.data.attributes['category'], + createdBy: json.data.attributes['created-by'], + }; }; + +export { deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer.js index c60f112be75..e55dfa1bc1d 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer.js @@ -1,27 +1,29 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize({ scoOrganizationParticipants, meta }) { - return new Serializer('sco-organization-participants', { - id: 'id', - attributes: [ - 'lastName', - 'firstName', - 'birthdate', - 'username', - 'userId', - 'email', - 'isAuthenticatedFromGAR', - 'division', - 'participationCount', - 'lastParticipationDate', - 'campaignName', - 'campaignType', - 'participationStatus', - 'isCertifiable', - 'certifiableAt', - ], - meta, - }).serialize(scoOrganizationParticipants); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function ({ scoOrganizationParticipants, meta }) { + return new Serializer('sco-organization-participants', { + id: 'id', + attributes: [ + 'lastName', + 'firstName', + 'birthdate', + 'username', + 'userId', + 'email', + 'isAuthenticatedFromGAR', + 'division', + 'participationCount', + 'lastParticipationDate', + 'campaignName', + 'campaignType', + 'participationStatus', + 'isCertifiable', + 'certifiableAt', + ], + meta, + }).serialize(scoOrganizationParticipants); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer.js index 939418d267c..9a795ad9681 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer.js @@ -1,24 +1,26 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize({ supOrganizationParticipants, meta }) { - return new Serializer('sup-organization-participants', { - id: 'id', - attributes: [ - 'lastName', - 'firstName', - 'birthdate', - 'studentNumber', - 'group', - 'participationCount', - 'lastParticipationDate', - 'campaignName', - 'campaignType', - 'participationStatus', - 'isCertifiable', - 'certifiableAt', - ], - meta, - }).serialize(supOrganizationParticipants); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function ({ supOrganizationParticipants, meta }) { + return new Serializer('sup-organization-participants', { + id: 'id', + attributes: [ + 'lastName', + 'firstName', + 'birthdate', + 'studentNumber', + 'group', + 'participationCount', + 'lastParticipationDate', + 'campaignName', + 'campaignType', + 'participationStatus', + 'isCertifiable', + 'certifiableAt', + ], + meta, + }).serialize(supOrganizationParticipants); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/organizations-administration/organization-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/organizations-administration/organization-for-admin-serializer.js index 6cce224685f..3515818250e 100644 --- a/api/lib/infrastructure/serializers/jsonapi/organizations-administration/organization-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/organizations-administration/organization-for-admin-serializer.js @@ -1,97 +1,97 @@ -const { Serializer } = require('jsonapi-serializer'); -const _ = require('lodash'); +import { Serializer } from 'jsonapi-serializer'; +import _ from 'lodash'; -module.exports = { - serialize(organizations, meta) { - return new Serializer('organizations', { - attributes: [ - 'name', - 'type', - 'logoUrl', - 'externalId', - 'provinceCode', - 'isManagingStudents', - 'credit', - 'email', - 'documentationUrl', - 'createdBy', - 'createdAt', - 'showNPS', - 'formNPSUrl', - 'showSkills', - 'archivedAt', - 'archivistFullName', - 'dataProtectionOfficerFirstName', - 'dataProtectionOfficerLastName', - 'dataProtectionOfficerEmail', - 'creatorFullName', - 'tags', - 'organizationMemberships', - 'targetProfileSummaries', - 'identityProviderForCampaigns', - 'enableMultipleSendingAssessment', - ], - organizationMemberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/organizations/${parent.id}/memberships`; - }, +const serialize = function (organizations, meta) { + return new Serializer('organizations', { + attributes: [ + 'name', + 'type', + 'logoUrl', + 'externalId', + 'provinceCode', + 'isManagingStudents', + 'credit', + 'email', + 'documentationUrl', + 'createdBy', + 'createdAt', + 'showNPS', + 'formNPSUrl', + 'showSkills', + 'archivedAt', + 'archivistFullName', + 'dataProtectionOfficerFirstName', + 'dataProtectionOfficerLastName', + 'dataProtectionOfficerEmail', + 'creatorFullName', + 'tags', + 'organizationMemberships', + 'targetProfileSummaries', + 'identityProviderForCampaigns', + 'enableMultipleSendingAssessment', + ], + organizationMemberships: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/organizations/${parent.id}/memberships`; }, }, - targetProfileSummaries: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/admin/organizations/${parent.id}/target-profile-summaries`; - }, + }, + targetProfileSummaries: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/admin/organizations/${parent.id}/target-profile-summaries`; }, }, - tags: { - ref: 'id', - included: true, - attributes: ['id', 'name'], - }, - meta, - }).serialize(organizations); - }, + }, + tags: { + ref: 'id', + included: true, + attributes: ['id', 'name'], + }, + meta, + }).serialize(organizations); +}; - deserialize(json) { - const attributes = json.data.attributes; - const relationships = json.data.relationships; +const deserialize = function (json) { + const attributes = json.data.attributes; + const relationships = json.data.relationships; - let tags = []; - if (relationships && relationships.tags) { - tags = relationships.tags.data.map((tag) => { - return { id: parseInt(tag.id) }; - }); - } + let tags = []; + if (relationships && relationships.tags) { + tags = relationships.tags.data.map((tag) => { + return { id: parseInt(tag.id) }; + }); + } - const organization = { - id: _.isNil(json.data.id) ? null : parseInt(json.data.id), - name: attributes.name, - type: attributes.type, - email: attributes.email, - credit: attributes.credit, - logoUrl: attributes['logo-url'], - externalId: attributes['external-id'], - provinceCode: attributes['province-code'], - isManagingStudents: attributes['is-managing-students'], - createdBy: attributes['created-by'], - documentationUrl: attributes['documentation-url'], - showSkills: attributes['show-skills'], - identityProviderForCampaigns: attributes['identity-provider-for-campaigns'], - dataProtectionOfficerFirstName: attributes['data-protection-officer-first-name'], - dataProtectionOfficerLastName: attributes['data-protection-officer-last-name'], - dataProtectionOfficerEmail: attributes['data-protection-officer-email'], - enableMultipleSendingAssessment: attributes['enable-multiple-sending-assessment'], - tags, - }; + const organization = { + id: _.isNil(json.data.id) ? null : parseInt(json.data.id), + name: attributes.name, + type: attributes.type, + email: attributes.email, + credit: attributes.credit, + logoUrl: attributes['logo-url'], + externalId: attributes['external-id'], + provinceCode: attributes['province-code'], + isManagingStudents: attributes['is-managing-students'], + createdBy: attributes['created-by'], + documentationUrl: attributes['documentation-url'], + showSkills: attributes['show-skills'], + identityProviderForCampaigns: attributes['identity-provider-for-campaigns'], + dataProtectionOfficerFirstName: attributes['data-protection-officer-first-name'], + dataProtectionOfficerLastName: attributes['data-protection-officer-last-name'], + dataProtectionOfficerEmail: attributes['data-protection-officer-email'], + enableMultipleSendingAssessment: attributes['enable-multiple-sending-assessment'], + tags, + }; - return organization; - }, + return organization; }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/participant-result-serializer.js b/api/lib/infrastructure/serializers/jsonapi/participant-result-serializer.js index b68b038e2e5..eeee7fbeb89 100644 --- a/api/lib/infrastructure/serializers/jsonapi/participant-result-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/participant-result-serializer.js @@ -1,94 +1,97 @@ -const { Serializer } = require('jsonapi-serializer'); -module.exports = { - serialize(results) { - return new Serializer('campaign-participation-results', { - transform, +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Serializer } = jsonapiSerializer; + +const serialize = function (results) { + return new Serializer('campaign-participation-results', { + transform, + attributes: [ + 'masteryRate', + 'totalSkillsCount', + 'testedSkillsCount', + 'validatedSkillsCount', + 'isCompleted', + 'isShared', + 'participantExternalId', + 'estimatedFlashLevel', + 'flashPixScore', + 'campaignParticipationBadges', + 'competenceResults', + 'reachedStage', + 'canRetry', + 'canImprove', + 'isDisabled', + ], + campaignParticipationBadges: { + ref: 'id', + included: true, attributes: [ - 'masteryRate', - 'totalSkillsCount', - 'testedSkillsCount', - 'validatedSkillsCount', - 'isCompleted', - 'isShared', - 'participantExternalId', - 'estimatedFlashLevel', - 'flashPixScore', - 'campaignParticipationBadges', - 'competenceResults', - 'reachedStage', - 'canRetry', - 'canImprove', - 'isDisabled', + 'altMessage', + 'message', + 'title', + 'imageUrl', + 'key', + 'isAcquired', + 'skillSetResults', + 'partnerCompetenceResults', + 'isAlwaysVisible', + 'isCertifiable', + 'isValid', ], - campaignParticipationBadges: { + skillSetResults: { ref: 'id', included: true, attributes: [ - 'altMessage', - 'message', - 'title', - 'imageUrl', - 'key', - 'isAcquired', - 'skillSetResults', - 'partnerCompetenceResults', - 'isAlwaysVisible', - 'isCertifiable', - 'isValid', + 'name', + 'index', + 'areaColor', + 'masteryPercentage', + 'totalSkillsCount', + 'testedSkillsCount', + 'validatedSkillsCount', ], - skillSetResults: { - ref: 'id', - included: true, - attributes: [ - 'name', - 'index', - 'areaColor', - 'masteryPercentage', - 'totalSkillsCount', - 'testedSkillsCount', - 'validatedSkillsCount', - ], - }, - partnerCompetenceResults: { - ref: 'id', - included: true, - attributes: [ - 'name', - 'index', - 'areaColor', - 'masteryPercentage', - 'totalSkillsCount', - 'testedSkillsCount', - 'validatedSkillsCount', - ], - }, }, - competenceResults: { + partnerCompetenceResults: { ref: 'id', + included: true, attributes: [ 'name', 'index', 'areaColor', - 'areaTitle', 'masteryPercentage', 'totalSkillsCount', 'testedSkillsCount', 'validatedSkillsCount', - 'flashPixScore', - 'reachedStage', ], }, - reachedStage: { - ref: 'id', - attributes: ['title', 'message', 'totalStage', 'reachedStage'], - }, - typeForAttribute(attribute) { - return attribute === 'reachedStage' ? 'reached-stages' : attribute; - }, - }).serialize(results); - }, + }, + competenceResults: { + ref: 'id', + attributes: [ + 'name', + 'index', + 'areaColor', + 'areaTitle', + 'masteryPercentage', + 'totalSkillsCount', + 'testedSkillsCount', + 'validatedSkillsCount', + 'flashPixScore', + 'reachedStage', + ], + }, + reachedStage: { + ref: 'id', + attributes: ['title', 'message', 'totalStage', 'reachedStage'], + }, + typeForAttribute(attribute) { + return attribute === 'reachedStage' ? 'reached-stages' : attribute; + }, + }).serialize(results); }; +export { serialize }; + function transform(record) { return { ...record, diff --git a/api/lib/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer.js b/api/lib/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer.js index ed33ee4c087..9d76328bd85 100644 --- a/api/lib/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer.js @@ -1,22 +1,24 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(participationsForCampaignManagement, meta) { - return new Serializer('campaign-participation', { - attributes: [ - 'lastName', - 'firstName', - 'userId', - 'userFullName', - 'participantExternalId', - 'status', - 'createdAt', - 'sharedAt', - 'deletedAt', - 'deletedBy', - 'deletedByFullName', - ], - meta, - }).serialize(participationsForCampaignManagement); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (participationsForCampaignManagement, meta) { + return new Serializer('campaign-participation', { + attributes: [ + 'lastName', + 'firstName', + 'userId', + 'userFullName', + 'participantExternalId', + 'status', + 'createdAt', + 'sharedAt', + 'deletedAt', + 'deletedBy', + 'deletedByFullName', + ], + meta, + }).serialize(participationsForCampaignManagement); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate.js b/api/lib/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate.js index 58660de98f4..e1141f4301c 100644 --- a/api/lib/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate.js +++ b/api/lib/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(model) { - return new Serializer('participations-count-by-mastery-rate', { - id: 'campaignId', - attributes: ['resultDistribution'], - }).serialize(model); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (model) { + return new Serializer('participations-count-by-mastery-rate', { + id: 'campaignId', + attributes: ['resultDistribution'], + }).serialize(model); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/password-reset-serializer.js b/api/lib/infrastructure/serializers/jsonapi/password-reset-serializer.js index 35b616427dc..47edf6aeb88 100644 --- a/api/lib/infrastructure/serializers/jsonapi/password-reset-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/password-reset-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(passwordResetDemands) { - return new Serializer('password-reset-demand', { - attributes: ['email'], - }).serialize(passwordResetDemands); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (passwordResetDemands) { + return new Serializer('password-reset-demand', { + attributes: ['email'], + }).serialize(passwordResetDemands); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/prescriber-serializer.js b/api/lib/infrastructure/serializers/jsonapi/prescriber-serializer.js index 16e4adf51a9..fb71220d711 100644 --- a/api/lib/infrastructure/serializers/jsonapi/prescriber-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/prescriber-serializer.js @@ -1,115 +1,117 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(prescriber) { - return new Serializer('prescriber', { - transform: (record) => { - const recordWithoutClass = { ...record }; - recordWithoutClass.memberships.forEach((membership) => { - membership.organization = { ...membership.organization }; - }); - recordWithoutClass.userOrgaSettings = { - ...recordWithoutClass.userOrgaSettings, - organization: { - ...recordWithoutClass.userOrgaSettings.currentOrganization, - isAgriculture: recordWithoutClass.userOrgaSettings.currentOrganization.isAgriculture, - }, - }; - delete recordWithoutClass.userOrgaSettings.currentOrganization; - - return recordWithoutClass; - }, +const { Serializer } = jsonapiSerializer; - attributes: [ - 'firstName', - 'lastName', - 'pixOrgaTermsOfServiceAccepted', - 'areNewYearOrganizationLearnersImported', - 'participantCount', - 'lang', - 'memberships', - 'userOrgaSettings', - 'enableMultipleSendingAssessment', - ], - memberships: { - ref: 'id', - attributes: ['organizationRole', 'organization'], +const serialize = function (prescriber) { + return new Serializer('prescriber', { + transform: (record) => { + const recordWithoutClass = { ...record }; + recordWithoutClass.memberships.forEach((membership) => { + membership.organization = { ...membership.organization }; + }); + recordWithoutClass.userOrgaSettings = { + ...recordWithoutClass.userOrgaSettings, organization: { - ref: 'id', - attributes: ['name', 'externalId'], + ...recordWithoutClass.userOrgaSettings.currentOrganization, + isAgriculture: recordWithoutClass.userOrgaSettings.currentOrganization.isAgriculture, }, + }; + delete recordWithoutClass.userOrgaSettings.currentOrganization; + + return recordWithoutClass; + }, + + attributes: [ + 'firstName', + 'lastName', + 'pixOrgaTermsOfServiceAccepted', + 'areNewYearOrganizationLearnersImported', + 'participantCount', + 'lang', + 'memberships', + 'userOrgaSettings', + 'enableMultipleSendingAssessment', + ], + memberships: { + ref: 'id', + attributes: ['organizationRole', 'organization'], + organization: { + ref: 'id', + attributes: ['name', 'externalId'], }, - userOrgaSettings: { + }, + userOrgaSettings: { + ref: 'id', + attributes: ['organization', 'user'], + organization: { ref: 'id', - attributes: ['organization', 'user'], - organization: { + attributes: [ + 'name', + 'type', + 'credit', + 'isManagingStudents', + 'isAgriculture', + 'identityProviderForCampaigns', + 'targetProfiles', + 'memberships', + 'divisions', + 'organizationInvitations', + 'documentationUrl', + 'groups', + ], + memberships: { ref: 'id', - attributes: [ - 'name', - 'type', - 'credit', - 'isManagingStudents', - 'isAgriculture', - 'identityProviderForCampaigns', - 'targetProfiles', - 'memberships', - 'divisions', - 'organizationInvitations', - 'documentationUrl', - 'groups', - ], - memberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/memberships`; - }, + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/memberships`; }, }, - organizationInvitations: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/invitations`; - }, + }, + organizationInvitations: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/invitations`; }, }, - targetProfiles: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/target-profiles`; - }, + }, + targetProfiles: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/target-profiles`; }, }, - groups: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/groups`; - }, + }, + groups: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/groups`; }, }, - divisions: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/organizations/${parent.id}/divisions`; - }, + }, + divisions: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/organizations/${parent.id}/divisions`; }, }, }, }, - }).serialize(prescriber); - }, + }, + }).serialize(prescriber); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/private-certificate-serializer.js b/api/lib/infrastructure/serializers/jsonapi/private-certificate-serializer.js index 69da096089b..e4c87b42268 100644 --- a/api/lib/infrastructure/serializers/jsonapi/private-certificate-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/private-certificate-serializer.js @@ -1,4 +1,6 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Serializer } = jsonapiSerializer; const typeForAttribute = (attribute) => { if (attribute === 'resultCompetenceTree') { @@ -48,12 +50,12 @@ const attributes = [ 'maxReachableLevelOnCertificationDate', ]; -module.exports = { - serialize(certificate) { - return new Serializer('certifications', { - typeForAttribute, - attributes, - resultCompetenceTree, - }).serialize(certificate); - }, +const serialize = function (certificate) { + return new Serializer('certifications', { + typeForAttribute, + attributes, + resultCompetenceTree, + }).serialize(certificate); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/profile-serializer.js b/api/lib/infrastructure/serializers/jsonapi/profile-serializer.js index 7371720de30..291aa095f24 100644 --- a/api/lib/infrastructure/serializers/jsonapi/profile-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/profile-serializer.js @@ -1,54 +1,56 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(profile = {}) { - return new Serializer('Profile', { - // Transform is necessary due to a bug with 'jsonapi-serializer' - // When a nested object (here: Area) is built with a class constructor - // in a nested object, it will skip the serialization of the area - // But when we use plain object instead of a class then serialization works. - transform: (profile) => ({ - ...profile, - scorecards: profile.scorecards.map((scorecard) => { - scorecard.area = { ...scorecard.area }; - return scorecard; - }), +const { Serializer } = jsonapiSerializer; + +const serialize = function (profile = {}) { + return new Serializer('Profile', { + // Transform is necessary due to a bug with 'jsonapi-serializer' + // When a nested object (here: Area) is built with a class constructor + // in a nested object, it will skip the serialization of the area + // But when we use plain object instead of a class then serialization works. + transform: (profile) => ({ + ...profile, + scorecards: profile.scorecards.map((scorecard) => { + scorecard.area = { ...scorecard.area }; + return scorecard; }), - attributes: ['pixScore', 'maxReachableLevel', 'maxReachablePixScore', 'scorecards'], - scorecards: { + }), + attributes: ['pixScore', 'maxReachableLevel', 'maxReachablePixScore', 'scorecards'], + scorecards: { + ref: 'id', + attributes: [ + 'area', + 'competenceId', + 'description', + 'earnedPix', + 'hasNotEarnedAnything', + 'hasNotReachedLevelOne', + 'hasReachedAtLeastLevelOne', + 'index', + 'isFinished', + 'isFinishedWithMaxLevel', + 'isImprovable', + 'isMaxLevel', + 'isNotStarted', + 'isProgressable', + 'isResettable', + 'isStarted', + 'level', + 'name', + 'percentageAheadOfNextLevel', + 'pixScoreAheadOfNextLevel', + 'remainingDaysBeforeImproving', + 'remainingDaysBeforeReset', + 'remainingPixToNextLevel', + 'shouldWaitBeforeImproving', + 'status', + ], + area: { ref: 'id', - attributes: [ - 'area', - 'competenceId', - 'description', - 'earnedPix', - 'hasNotEarnedAnything', - 'hasNotReachedLevelOne', - 'hasReachedAtLeastLevelOne', - 'index', - 'isFinished', - 'isFinishedWithMaxLevel', - 'isImprovable', - 'isMaxLevel', - 'isNotStarted', - 'isProgressable', - 'isResettable', - 'isStarted', - 'level', - 'name', - 'percentageAheadOfNextLevel', - 'pixScoreAheadOfNextLevel', - 'remainingDaysBeforeImproving', - 'remainingDaysBeforeReset', - 'remainingPixToNextLevel', - 'shouldWaitBeforeImproving', - 'status', - ], - area: { - ref: 'id', - attributes: ['code', 'title', 'color'], - }, + attributes: ['code', 'title', 'color'], }, - }).serialize(profile); - }, + }, + }).serialize(profile); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/progression-serializer.js b/api/lib/infrastructure/serializers/jsonapi/progression-serializer.js index 57ca4397e83..561c77c3ac3 100644 --- a/api/lib/infrastructure/serializers/jsonapi/progression-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/progression-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(progression) { - return new Serializer('progression', { - attributes: ['completionRate'], - }).serialize(progression); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (progression) { + return new Serializer('progression', { + attributes: ['completionRate'], + }).serialize(progression); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer.js b/api/lib/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer.js index 2350dcd0de0..3afa75ed520 100644 --- a/api/lib/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer.js @@ -1,9 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(invitation) { - return new Serializer('sco-organization-invitation', { - attributes: ['uai', 'lastName', 'firstName'], - }).serialize(invitation); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (invitation) { + return new Serializer('sco-organization-invitation', { + attributes: ['uai', 'lastName', 'firstName'], + }).serialize(invitation); }; + +const serializer = { serialize }; +export { serializer, serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/sco-organization-learner-serializer.js b/api/lib/infrastructure/serializers/jsonapi/sco-organization-learner-serializer.js index 52223cba57a..fe682506213 100644 --- a/api/lib/infrastructure/serializers/jsonapi/sco-organization-learner-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/sco-organization-learner-serializer.js @@ -1,27 +1,29 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serializeIdentity(scoOrganizationLearner) { - return new Serializer('sco-organization-learner', { - attributes: ['lastName', 'firstName', 'birthdate'], - }).serialize(scoOrganizationLearner); - }, +const { Serializer } = jsonapiSerializer; - serializeWithUsernameGeneration(scoOrganizationLearner) { - return new Serializer('sco-organization-learner', { - attributes: ['lastName', 'firstName', 'birthdate', 'username'], - }).serialize(scoOrganizationLearner); - }, +const serializeIdentity = function (scoOrganizationLearner) { + return new Serializer('sco-organization-learner', { + attributes: ['lastName', 'firstName', 'birthdate'], + }).serialize(scoOrganizationLearner); +}; - serializeExternal(scoOrganizationLearner) { - return new Serializer('external-users', { - attributes: ['accessToken'], - }).serialize(scoOrganizationLearner); - }, +const serializeWithUsernameGeneration = function (scoOrganizationLearner) { + return new Serializer('sco-organization-learner', { + attributes: ['lastName', 'firstName', 'birthdate', 'username'], + }).serialize(scoOrganizationLearner); +}; - serializeCredentialsForDependent(scoOrganizationLearner) { - return new Serializer('dependent-users', { - attributes: ['username', 'generatedPassword'], - }).serialize(scoOrganizationLearner); - }, +const serializeExternal = function (scoOrganizationLearner) { + return new Serializer('external-users', { + attributes: ['accessToken'], + }).serialize(scoOrganizationLearner); }; + +const serializeCredentialsForDependent = function (scoOrganizationLearner) { + return new Serializer('dependent-users', { + attributes: ['username', 'generatedPassword'], + }).serialize(scoOrganizationLearner); +}; + +export { serializeIdentity, serializeWithUsernameGeneration, serializeExternal, serializeCredentialsForDependent }; diff --git a/api/lib/infrastructure/serializers/jsonapi/scorecard-serializer.js b/api/lib/infrastructure/serializers/jsonapi/scorecard-serializer.js index b0efa548386..ee08cba2155 100644 --- a/api/lib/infrastructure/serializers/jsonapi/scorecard-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/scorecard-serializer.js @@ -1,61 +1,63 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(scorecard = {}) { - return new Serializer('scorecard', { - attributes: [ - 'area', - 'competenceId', - 'description', - 'earnedPix', - 'hasNotEarnedAnything', - 'hasNotReachedLevelOne', - 'hasReachedAtLeastLevelOne', - 'index', - 'isFinished', - 'isFinishedWithMaxLevel', - 'isImprovable', - 'isMaxLevel', - 'isNotStarted', - 'isProgressable', - 'isResettable', - 'isStarted', - 'level', - 'name', - 'percentageAheadOfNextLevel', - 'pixScoreAheadOfNextLevel', - 'remainingDaysBeforeImproving', - 'remainingDaysBeforeReset', - 'remainingPixToNextLevel', - 'shouldWaitBeforeImproving', - 'status', - 'tutorials', - ], +const { Serializer } = jsonapiSerializer; - area: { - ref: ['id'], - attributes: ['code', 'title', 'color'], - }, - tutorials: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/scorecards/${parent.id}/tutorials`; - }, +const serialize = function (scorecard = {}) { + return new Serializer('scorecard', { + attributes: [ + 'area', + 'competenceId', + 'description', + 'earnedPix', + 'hasNotEarnedAnything', + 'hasNotReachedLevelOne', + 'hasReachedAtLeastLevelOne', + 'index', + 'isFinished', + 'isFinishedWithMaxLevel', + 'isImprovable', + 'isMaxLevel', + 'isNotStarted', + 'isProgressable', + 'isResettable', + 'isStarted', + 'level', + 'name', + 'percentageAheadOfNextLevel', + 'pixScoreAheadOfNextLevel', + 'remainingDaysBeforeImproving', + 'remainingDaysBeforeReset', + 'remainingPixToNextLevel', + 'shouldWaitBeforeImproving', + 'status', + 'tutorials', + ], + + area: { + ref: ['id'], + attributes: ['code', 'title', 'color'], + }, + tutorials: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/scorecards/${parent.id}/tutorials`; }, - attributes: [ - 'id', - 'duration', - 'format', - 'link', - 'source', - 'title', - 'tubeName', - 'tubePracticalTitle', - 'tubePracticalDescription', - ], }, - }).serialize(scorecard); - }, + attributes: [ + 'id', + 'duration', + 'format', + 'link', + 'source', + 'title', + 'tubeName', + 'tubePracticalTitle', + 'tubePracticalDescription', + ], + }, + }).serialize(scorecard); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/session-for-supervising-serializer.js b/api/lib/infrastructure/serializers/jsonapi/session-for-supervising-serializer.js index f6f1f2e7e24..581ad42938c 100644 --- a/api/lib/infrastructure/serializers/jsonapi/session-for-supervising-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/session-for-supervising-serializer.js @@ -1,48 +1,49 @@ -const _ = require('lodash'); -const { Serializer } = require('jsonapi-serializer'); +import _ from 'lodash'; +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(sessions) { - return new Serializer('sessionForSupervising', { - transform(currentSessionForSupervising) { - const cloneSession = _.cloneDeep(currentSessionForSupervising); +const { Serializer } = jsonapiSerializer; - cloneSession.certificationCandidates.forEach((candidate) => { - candidate.enrolledComplementaryCertificationLabel = - candidate.enrolledComplementaryCertification?.label ?? null; - }); +const serialize = function (sessions) { + return new Serializer('sessionForSupervising', { + transform(currentSessionForSupervising) { + const cloneSession = _.cloneDeep(currentSessionForSupervising); - return cloneSession; - }, + cloneSession.certificationCandidates.forEach((candidate) => { + candidate.enrolledComplementaryCertificationLabel = candidate.enrolledComplementaryCertification?.label ?? null; + }); + + return cloneSession; + }, + attributes: [ + 'room', + 'examiner', + 'accessCode', + 'date', + 'time', + 'certificationCenterName', + 'certificationCandidates', + ], + typeForAttribute: (attribute) => + attribute === 'certificationCandidates' ? 'certification-candidate-for-supervising' : attribute, + certificationCandidates: { + included: true, + ref: 'id', attributes: [ - 'room', - 'examiner', - 'accessCode', - 'date', - 'time', - 'certificationCenterName', - 'certificationCandidates', + 'id', + 'userId', + 'firstName', + 'lastName', + 'birthdate', + 'extraTimePercentage', + 'authorizedToStart', + 'assessmentStatus', + 'startDateTime', + 'theoricalEndDateTime', + 'enrolledComplementaryCertificationLabel', + 'isStillEligibleToComplementaryCertification', ], - typeForAttribute: (attribute) => - attribute === 'certificationCandidates' ? 'certification-candidate-for-supervising' : attribute, - certificationCandidates: { - included: true, - ref: 'id', - attributes: [ - 'id', - 'userId', - 'firstName', - 'lastName', - 'birthdate', - 'extraTimePercentage', - 'authorizedToStart', - 'assessmentStatus', - 'startDateTime', - 'theoricalEndDateTime', - 'enrolledComplementaryCertificationLabel', - 'isStillEligibleToComplementaryCertification', - ], - }, - }).serialize(sessions); - }, + }, + }).serialize(sessions); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/session-serializer.js b/api/lib/infrastructure/serializers/jsonapi/session-serializer.js index b9bc5489b48..354b625fe06 100644 --- a/api/lib/infrastructure/serializers/jsonapi/session-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/session-serializer.js @@ -1,87 +1,90 @@ -const { Serializer } = require('jsonapi-serializer'); -const _ = require('lodash'); +import jsonapiSerializer from 'jsonapi-serializer'; -const Session = require('../../../domain/models/Session.js'); +const { Serializer } = jsonapiSerializer; -module.exports = { - serialize({ session, hasSupervisorAccess, hasSomeCleaAcquired }) { - const attributes = [ - 'address', - 'room', - 'examiner', - 'date', - 'time', - 'status', - 'description', - 'accessCode', - 'examinerGlobalComment', - 'hasIncident', - 'hasJoiningIssue', - 'finalizedAt', - 'resultsSentToPrescriberAt', - 'publishedAt', - 'certificationCenterId', - 'certificationCandidates', - 'certificationReports', - 'supervisorPassword', - 'hasSupervisorAccess', - 'hasSomeCleaAcquired', - ]; - return new Serializer('session', { - transform(record) { - if (hasSupervisorAccess !== undefined) { - record.hasSupervisorAccess = hasSupervisorAccess; - } - if (hasSomeCleaAcquired !== undefined) { - record.hasSomeCleaAcquired = hasSomeCleaAcquired; - } - return record; - }, - attributes, - certificationCandidates: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/sessions/${parent.id}/certification-candidates`; - }, +import _ from 'lodash'; + +import { Session } from '../../../domain/models/Session.js'; + +const serialize = function ({ session, hasSupervisorAccess, hasSomeCleaAcquired }) { + const attributes = [ + 'address', + 'room', + 'examiner', + 'date', + 'time', + 'status', + 'description', + 'accessCode', + 'examinerGlobalComment', + 'hasIncident', + 'hasJoiningIssue', + 'finalizedAt', + 'resultsSentToPrescriberAt', + 'publishedAt', + 'certificationCenterId', + 'certificationCandidates', + 'certificationReports', + 'supervisorPassword', + 'hasSupervisorAccess', + 'hasSomeCleaAcquired', + ]; + return new Serializer('session', { + transform(record) { + if (hasSupervisorAccess !== undefined) { + record.hasSupervisorAccess = hasSupervisorAccess; + } + if (hasSomeCleaAcquired !== undefined) { + record.hasSomeCleaAcquired = hasSomeCleaAcquired; + } + return record; + }, + attributes, + certificationCandidates: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/sessions/${parent.id}/certification-candidates`; }, }, - certificationReports: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related(record, current, parent) { - return `/api/sessions/${parent.id}/certification-reports`; - }, + }, + certificationReports: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related(record, current, parent) { + return `/api/sessions/${parent.id}/certification-reports`; }, }, - }).serialize(session); - }, + }, + }).serialize(session); +}; - deserialize(json) { - const attributes = json.data.attributes; +const deserialize = function (json) { + const attributes = json.data.attributes; - const result = new Session({ - id: json.data.id, - certificationCenterId: attributes['certification-center-id'], - address: attributes.address, - room: attributes.room, - examiner: attributes.examiner, - date: attributes.date, - time: attributes.time, - status: attributes.status, - description: attributes.description, - examinerGlobalComment: attributes['examiner-global-comment'], - hasIncident: attributes['has-incident'], - hasJoiningIssue: attributes['has-joining-issue'], - }); + const result = new Session({ + id: json.data.id, + certificationCenterId: attributes['certification-center-id'], + address: attributes.address, + room: attributes.room, + examiner: attributes.examiner, + date: attributes.date, + time: attributes.time, + status: attributes.status, + description: attributes.description, + examinerGlobalComment: attributes['examiner-global-comment'], + hasIncident: attributes['has-incident'], + hasJoiningIssue: attributes['has-joining-issue'], + }); - if (_.isEmpty(_.trim(result.examinerGlobalComment))) { - result.examinerGlobalComment = Session.NO_EXAMINER_GLOBAL_COMMENT; - } + if (_.isEmpty(_.trim(result.examinerGlobalComment))) { + result.examinerGlobalComment = Session.NO_EXAMINER_GLOBAL_COMMENT; + } - return result; - }, + return result; }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/session-summary-serializer.js b/api/lib/infrastructure/serializers/jsonapi/session-summary-serializer.js index 45953d4c94f..79248338e65 100644 --- a/api/lib/infrastructure/serializers/jsonapi/session-summary-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/session-summary-serializer.js @@ -1,19 +1,21 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(sessionSummaries, meta) { - return new Serializer('session-summary', { - attributes: [ - 'address', - 'room', - 'date', - 'time', - 'examiner', - 'enrolledCandidatesCount', - 'effectiveCandidatesCount', - 'status', - ], - meta, - }).serialize(sessionSummaries); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (sessionSummaries, meta) { + return new Serializer('session-summary', { + attributes: [ + 'address', + 'room', + 'date', + 'time', + 'examiner', + 'enrolledCandidatesCount', + 'effectiveCandidatesCount', + 'status', + ], + meta, + }).serialize(sessionSummaries); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/shareable-certificate-serializer.js b/api/lib/infrastructure/serializers/jsonapi/shareable-certificate-serializer.js index f7d2aa302a8..282fdc321e1 100644 --- a/api/lib/infrastructure/serializers/jsonapi/shareable-certificate-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/shareable-certificate-serializer.js @@ -1,4 +1,6 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Serializer } = jsonapiSerializer; const typeForAttribute = (attribute) => { if (attribute === 'resultCompetenceTree') { @@ -44,12 +46,12 @@ const attributes = [ 'maxReachableLevelOnCertificationDate', ]; -module.exports = { - serialize(certificate) { - return new Serializer('certifications', { - typeForAttribute, - attributes, - resultCompetenceTree, - }).serialize(certificate); - }, +const serialize = function (certificate) { + return new Serializer('certifications', { + typeForAttribute, + attributes, + resultCompetenceTree, + }).serialize(certificate); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer.js b/api/lib/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer.js index 4b48ad93ac3..26c9cfcc828 100644 --- a/api/lib/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer.js @@ -1,35 +1,37 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(sharedProfileForCampaign = {}) { - return new Serializer('SharedProfileForCampaign', { - // Transform is necessary due to a bug with 'jsonapi-serializer' - // When a nested object (here: Area) is built with a class constructor - // in a nested object, it will skip the serialization of the area - // But when we use plain object instead of a class then serialization works. - transform: (profile) => ({ - ...profile, - scorecards: profile.scorecards.map((scorecard) => ({ ...scorecard, area: { ...scorecard.area } })), - }), - attributes: ['pixScore', 'sharedAt', 'scorecards', 'canRetry', 'maxReachableLevel', 'maxReachablePixScore'], - scorecards: { +const { Serializer } = jsonapiSerializer; + +const serialize = function (sharedProfileForCampaign = {}) { + return new Serializer('SharedProfileForCampaign', { + // Transform is necessary due to a bug with 'jsonapi-serializer' + // When a nested object (here: Area) is built with a class constructor + // in a nested object, it will skip the serialization of the area + // But when we use plain object instead of a class then serialization works. + transform: (profile) => ({ + ...profile, + scorecards: profile.scorecards.map((scorecard) => ({ ...scorecard, area: { ...scorecard.area } })), + }), + attributes: ['pixScore', 'sharedAt', 'scorecards', 'canRetry', 'maxReachableLevel', 'maxReachablePixScore'], + scorecards: { + ref: 'id', + attributes: [ + 'name', + 'description', + 'index', + 'competenceId', + 'earnedPix', + 'level', + 'pixScoreAheadOfNextLevel', + 'status', + 'area', + ], + area: { ref: 'id', - attributes: [ - 'name', - 'description', - 'index', - 'competenceId', - 'earnedPix', - 'level', - 'pixScoreAheadOfNextLevel', - 'status', - 'area', - ], - area: { - ref: 'id', - attributes: ['code', 'title', 'color'], - }, + attributes: ['code', 'title', 'color'], }, - }).serialize(sharedProfileForCampaign); - }, + }, + }).serialize(sharedProfileForCampaign); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/skill-set-serializer.js b/api/lib/infrastructure/serializers/jsonapi/skill-set-serializer.js index 2de054fb2be..47e476e47cd 100644 --- a/api/lib/infrastructure/serializers/jsonapi/skill-set-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/skill-set-serializer.js @@ -1,9 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); -module.exports = { - serialize(skillSet = {}) { - return new Serializer('skill-sets', { - ref: 'id', - attributes: ['name', 'skillIds'], - }).serialize(skillSet); - }, +import jsonapiSerializer from 'jsonapi-serializer'; + +const { Serializer } = jsonapiSerializer; + +const serialize = function (skillSet = {}) { + return new Serializer('skill-sets', { + ref: 'id', + attributes: ['name', 'skillIds'], + }).serialize(skillSet); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/student-certification-serializer.js b/api/lib/infrastructure/serializers/jsonapi/student-certification-serializer.js index 8fbc84e1255..e88c633aca1 100644 --- a/api/lib/infrastructure/serializers/jsonapi/student-certification-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/student-certification-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(students, pagination) { - return new Serializer('students', { - attributes: ['lastName', 'firstName', 'birthdate', 'division', 'isEnrolled'], - meta: pagination, - }).serialize(students); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (students, pagination) { + return new Serializer('students', { + attributes: ['lastName', 'firstName', 'birthdate', 'division', 'isEnrolled'], + meta: pagination, + }).serialize(students); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js b/api/lib/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js index a1e82658df5..9b21b9f5d03 100644 --- a/api/lib/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js @@ -1,30 +1,32 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(studentInformationForAccountRecovery) { - return new Serializer('student-information-for-account-recoveries', { - attributes: ['firstName', 'lastName', 'username', 'email', 'latestOrganizationName'], - }).serialize(studentInformationForAccountRecovery); - }, +const { Serializer, Deserializer } = jsonapiSerializer; - serializeAccountRecovery(accountRecoveryDemand) { - return new Serializer('account-recovery-demand', { - attributes: ['firstName', 'email'], - }).serialize(accountRecoveryDemand); - }, +const serialize = function (studentInformationForAccountRecovery) { + return new Serializer('student-information-for-account-recoveries', { + attributes: ['firstName', 'lastName', 'username', 'email', 'latestOrganizationName'], + }).serialize(studentInformationForAccountRecovery); +}; + +const serializeAccountRecovery = function (accountRecoveryDemand) { + return new Serializer('account-recovery-demand', { + attributes: ['firstName', 'email'], + }).serialize(accountRecoveryDemand); +}; - async deserialize(studentInformationForAccountRecovery) { - function transform(record) { - return { - ineIna: record['ine-ina'], - firstName: record['first-name'], - lastName: record['last-name'], - birthdate: record.birthdate, - ...(record.email && { email: record.email }), - }; - } - return new Deserializer({ transform }) - .deserialize(studentInformationForAccountRecovery) - .then((studentInformation) => studentInformation); - }, +const deserialize = async function (studentInformationForAccountRecovery) { + function transform(record) { + return { + ineIna: record['ine-ina'], + firstName: record['first-name'], + lastName: record['last-name'], + birthdate: record.birthdate, + ...(record.email && { email: record.email }), + }; + } + return new Deserializer({ transform }) + .deserialize(studentInformationForAccountRecovery) + .then((studentInformation) => studentInformation); }; + +export { serialize, serializeAccountRecovery, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer.js b/api/lib/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer.js index 7f6e4f5a105..eac18d53fb3 100644 --- a/api/lib/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(organizations, meta) { - return new Serializer('sup-organization-learner-warnings', { - attributes: ['warnings'], - meta, - }).serialize(organizations); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (organizations, meta) { + return new Serializer('sup-organization-learner-warnings', { + attributes: ['warnings'], + meta, + }).serialize(organizations); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/tag-serializer.js b/api/lib/infrastructure/serializers/jsonapi/tag-serializer.js index 5ca6fd06485..0bc300df8a1 100644 --- a/api/lib/infrastructure/serializers/jsonapi/tag-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/tag-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(tags) { - return new Serializer('tags', { - attributes: ['name'], - }).serialize(tags); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (tags) { + return new Serializer('tags', { + attributes: ['name'], + }).serialize(tags); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer.js b/api/lib/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer.js index b33fe3f9f71..a84c332e37d 100644 --- a/api/lib/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(model) { - return new Serializer('target-profile-attach-organization', { - id: 'targetProfileId', - attributes: ['duplicatedIds', 'attachedIds'], - }).serialize(model); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (model) { + return new Serializer('target-profile-attach-organization', { + id: 'targetProfileId', + attributes: ['duplicatedIds', 'attachedIds'], + }).serialize(model); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer.js index a27193e8cc5..a3c95c076a5 100644 --- a/api/lib/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer.js @@ -1,93 +1,86 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(targetProfiles) { - return new Serializer('target-profile', { - transform(record) { - record.stageCollection = record.stageCollection.toDTO(); - record.badges = record.badges.map((badge) => { - badge.criteria = badge.criteria.map((criteria) => criteria.toDTO()); - return badge; - }); - return record; +const { Serializer } = jsonapiSerializer; + +const serialize = function (targetProfiles) { + return new Serializer('target-profile', { + transform(record) { + record.stageCollection = record.stageCollection.toDTO(); + record.badges = record.badges.map((badge) => { + badge.criteria = badge.criteria.map((criteria) => criteria.toDTO()); + return badge; + }); + return record; + }, + attributes: [ + 'name', + 'outdated', + 'isPublic', + 'createdAt', + 'ownerOrganizationId', + 'description', + 'comment', + 'imageUrl', + 'category', + 'isSimplifiedAccess', + 'badges', + 'stageCollection', + 'areas', + 'maxLevel', + ], + badges: { + ref: 'id', + included: true, + attributes: ['altMessage', 'imageUrl', 'message', 'title', 'key', 'isCertifiable', 'isAlwaysVisible', 'criteria'], + criteria: { + ref: 'id', + included: true, + attributes: ['threshold', 'scope', 'cappedTubes', 'name'], }, - attributes: [ - 'name', - 'outdated', - 'isPublic', - 'createdAt', - 'ownerOrganizationId', - 'description', - 'comment', - 'imageUrl', - 'category', - 'isSimplifiedAccess', - 'badges', - 'stageCollection', - 'areas', - 'maxLevel', - ], - badges: { + }, + stageCollection: { + ref: 'id', + included: true, + attributes: ['targetProfileId', 'stages'], + stages: { ref: 'id', included: true, attributes: [ - 'altMessage', - 'imageUrl', - 'message', + 'threshold', + 'level', + 'isFirstSkill', 'title', - 'key', - 'isCertifiable', - 'isAlwaysVisible', - 'criteria', + 'message', + 'prescriberTitle', + 'prescriberDescription', ], - criteria: { - ref: 'id', - included: true, - attributes: ['threshold', 'scope', 'cappedTubes', 'name'], - }, }, - stageCollection: { + }, + areas: { + ref: 'id', + included: true, + attributes: ['title', 'code', 'color', 'frameworkId', 'competences'], + competences: { ref: 'id', included: true, - attributes: ['targetProfileId', 'stages'], - stages: { + attributes: ['name', 'index', 'thematics'], + thematics: { ref: 'id', included: true, - attributes: [ - 'threshold', - 'level', - 'isFirstSkill', - 'title', - 'message', - 'prescriberTitle', - 'prescriberDescription', - ], - }, - }, - areas: { - ref: 'id', - included: true, - attributes: ['title', 'code', 'color', 'frameworkId', 'competences'], - competences: { - ref: 'id', - included: true, - attributes: ['name', 'index', 'thematics'], - thematics: { + attributes: ['name', 'index', 'tubes'], + tubes: { ref: 'id', included: true, - attributes: ['name', 'index', 'tubes'], - tubes: { - ref: 'id', - included: true, - attributes: ['name', 'practicalTitle', 'level', 'mobile', 'tablet'], - }, + attributes: ['name', 'practicalTitle', 'level', 'mobile', 'tablet'], }, }, }, - typeForAttribute(attribute) { - if (attribute === 'criteria') return 'badge-criteria'; - return undefined; - }, - }).serialize(targetProfiles); - }, + }, + typeForAttribute(attribute) { + if (attribute === 'criteria') return 'badge-criteria'; + return undefined; + }, + }).serialize(targetProfiles); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/target-profile-serializer.js b/api/lib/infrastructure/serializers/jsonapi/target-profile-serializer.js index 521a741d09e..2030b4eba64 100644 --- a/api/lib/infrastructure/serializers/jsonapi/target-profile-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/target-profile-serializer.js @@ -1,27 +1,29 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(targetProfiles, meta) { - return new Serializer('target-profile', { - attributes: ['name', 'outdated', 'isPublic', 'ownerOrganizationId', 'isSimplifiedAccess'], - meta, - }).serialize(targetProfiles); - }, +const { Serializer } = jsonapiSerializer; - serializeId(targetProfileId) { - return new Serializer('target-profile', {}).serialize({ id: targetProfileId }); - }, +const serialize = function (targetProfiles, meta) { + return new Serializer('target-profile', { + attributes: ['name', 'outdated', 'isPublic', 'ownerOrganizationId', 'isSimplifiedAccess'], + meta, + }).serialize(targetProfiles); +}; + +const serializeId = function (targetProfileId) { + return new Serializer('target-profile', {}).serialize({ id: targetProfileId }); +}; - deserializeCreationCommand(json) { - return { - name: json.data.attributes['name'], - category: json.data.attributes['category'], - description: json.data.attributes['description'], - comment: json.data.attributes['comment'], - isPublic: json.data.attributes['is-public'], - imageUrl: json.data.attributes['image-url'], - ownerOrganizationId: json.data.attributes['owner-organization-id'], - tubes: json.data.attributes['tubes'], - }; - }, +const deserializeCreationCommand = function (json) { + return { + name: json.data.attributes['name'], + category: json.data.attributes['category'], + description: json.data.attributes['description'], + comment: json.data.attributes['comment'], + isPublic: json.data.attributes['is-public'], + imageUrl: json.data.attributes['image-url'], + ownerOrganizationId: json.data.attributes['owner-organization-id'], + tubes: json.data.attributes['tubes'], + }; }; + +export { serialize, serializeId, deserializeCreationCommand }; diff --git a/api/lib/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js index 69752834767..3d6993ba220 100644 --- a/api/lib/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(targetProfileSummaries, meta) { - return new Serializer('target-profile-summary', { - attributes: ['name', 'outdated', 'createdAt'], - meta, - }).serialize(targetProfileSummaries); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (targetProfileSummaries, meta) { + return new Serializer('target-profile-summary', { + attributes: ['name', 'outdated', 'createdAt'], + meta, + }).serialize(targetProfileSummaries); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/to-be-published-session-serializer.js b/api/lib/infrastructure/serializers/jsonapi/to-be-published-session-serializer.js index f7deeaab792..013cba68af3 100644 --- a/api/lib/infrastructure/serializers/jsonapi/to-be-published-session-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/to-be-published-session-serializer.js @@ -1,12 +1,14 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(finalizedSessions) { - return new Serializer('to-be-published-session', { - transform(finalizedSession) { - return { ...finalizedSession, id: finalizedSession.sessionId }; - }, - attributes: ['sessionId', 'sessionDate', 'sessionTime', 'finalizedAt', 'certificationCenterName'], - }).serialize(finalizedSessions); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (finalizedSessions) { + return new Serializer('to-be-published-session', { + transform(finalizedSession) { + return { ...finalizedSession, id: finalizedSession.sessionId }; + }, + attributes: ['sessionId', 'sessionDate', 'sessionTime', 'finalizedAt', 'certificationCenterName'], + }).serialize(finalizedSessions); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/training-serializer.js b/api/lib/infrastructure/serializers/jsonapi/training-serializer.js index 4030c55a9fb..14a0a759d55 100644 --- a/api/lib/infrastructure/serializers/jsonapi/training-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/training-serializer.js @@ -1,132 +1,134 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serializeForAdmin(training = {}, meta) { - return new Serializer('trainings', { - transform(record) { - const duration = record.duration; - duration.days = duration.days || 0; - duration.hours = duration.hours || 0; - duration.minutes = duration.minutes || 0; +const { Serializer, Deserializer } = jsonapiSerializer; - return JSON.parse(JSON.stringify({ ...record, isRecommendable: record.isRecommendable })); - }, - attributes: [ - 'id', - 'duration', - 'link', - 'locale', - 'title', - 'type', - 'editorName', - 'editorLogoUrl', - 'trainingTriggers', - 'targetProfileSummaries', - 'isRecommendable', - ], - trainingTriggers: { +const serializeForAdmin = function (training = {}, meta) { + return new Serializer('trainings', { + transform(record) { + const duration = record.duration; + duration.days = duration.days || 0; + duration.hours = duration.hours || 0; + duration.minutes = duration.minutes || 0; + + return JSON.parse(JSON.stringify({ ...record, isRecommendable: record.isRecommendable })); + }, + attributes: [ + 'id', + 'duration', + 'link', + 'locale', + 'title', + 'type', + 'editorName', + 'editorLogoUrl', + 'trainingTriggers', + 'targetProfileSummaries', + 'isRecommendable', + ], + trainingTriggers: { + ref: 'id', + attributes: ['id', 'trainingId', 'type', 'threshold', 'areas', 'tubesCount'], + areas: { ref: 'id', - attributes: ['id', 'trainingId', 'type', 'threshold', 'areas', 'tubesCount'], - areas: { + included: true, + attributes: ['id', 'title', 'code', 'color', 'competences'], + competences: { ref: 'id', included: true, - attributes: ['id', 'title', 'code', 'color', 'competences'], - competences: { + attributes: ['id', 'name', 'index', 'thematics'], + thematics: { ref: 'id', included: true, - attributes: ['id', 'name', 'index', 'thematics'], - thematics: { + attributes: ['id', 'name', 'index', 'triggerTubes'], + triggerTubes: { ref: 'id', included: true, - attributes: ['id', 'name', 'index', 'triggerTubes'], - triggerTubes: { + attributes: ['id', 'level', 'tube'], + tube: { ref: 'id', included: true, - attributes: ['id', 'level', 'tube'], - tube: { - ref: 'id', - included: true, - attributes: ['id', 'name', 'practicalTitle'], - }, + attributes: ['id', 'name', 'practicalTitle'], }, }, }, }, }, - targetProfileSummaries: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/admin/trainings/${parent.id}/target-profile-summaries`; - }, + }, + targetProfileSummaries: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/admin/trainings/${parent.id}/target-profile-summaries`; }, }, - meta, - typeForAttribute(attribute) { - switch (attribute) { - case 'trainingTriggers': - return 'training-triggers'; - case 'triggerTubes': - return 'trigger-tubes'; - case 'tube': - return 'tubes'; - default: - return attribute; - } - }, - }).serialize(training); - }, + }, + meta, + typeForAttribute(attribute) { + switch (attribute) { + case 'trainingTriggers': + return 'training-triggers'; + case 'triggerTubes': + return 'trigger-tubes'; + case 'tube': + return 'tubes'; + default: + return attribute; + } + }, + }).serialize(training); +}; - serialize(training = {}, meta) { - return new Serializer('trainings', { - attributes: [ - 'duration', - 'link', - 'locale', - 'title', - 'type', - 'editorName', - 'editorLogoUrl', - 'targetProfileSummaries', - ], - targetProfileSummaries: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/admin/trainings/${parent.id}/target-profile-summaries`; - }, +const serialize = function (training = {}, meta) { + return new Serializer('trainings', { + attributes: [ + 'duration', + 'link', + 'locale', + 'title', + 'type', + 'editorName', + 'editorLogoUrl', + 'targetProfileSummaries', + ], + targetProfileSummaries: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/admin/trainings/${parent.id}/target-profile-summaries`; }, }, - meta, - transform(training) { - const duration = training.duration; - duration.days = duration.days || 0; - duration.hours = duration.hours || 0; - duration.minutes = duration.minutes || 0; - return training; - }, - }).serialize(training); - }, + }, + meta, + transform(training) { + const duration = training.duration; + duration.days = duration.days || 0; + duration.hours = duration.hours || 0; + duration.minutes = duration.minutes || 0; + return training; + }, + }).serialize(training); +}; - deserialize(payload) { - return new Deserializer({ - keyForAttribute: 'camelCase', - transform(deserializedTraining) { - const duration = deserializedTraining.duration; - if (!duration) return deserializedTraining; +const deserialize = function (payload) { + return new Deserializer({ + keyForAttribute: 'camelCase', + transform(deserializedTraining) { + const duration = deserializedTraining.duration; + if (!duration) return deserializedTraining; - const { days, hours, minutes } = duration; - const formattedDuration = `${days}d${hours}h${minutes}m`; + const { days, hours, minutes } = duration; + const formattedDuration = `${days}d${hours}h${minutes}m`; - return { - ...deserializedTraining, - duration: formattedDuration, - }; - }, - }).deserialize(payload); - }, + return { + ...deserializedTraining, + duration: formattedDuration, + }; + }, + }).deserialize(payload); }; + +export { serializeForAdmin, serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/training-summary-serializer.js b/api/lib/infrastructure/serializers/jsonapi/training-summary-serializer.js index 927f4964767..2cad3b47aee 100644 --- a/api/lib/infrastructure/serializers/jsonapi/training-summary-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/training-summary-serializer.js @@ -1,10 +1,12 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(trainingSummaries, meta) { - return new Serializer('training-summaries', { - attributes: ['title', 'isRecommendable'], - meta, - }).serialize(trainingSummaries); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (trainingSummaries, meta) { + return new Serializer('training-summaries', { + attributes: ['title', 'isRecommendable'], + meta, + }).serialize(trainingSummaries); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/training-trigger-serializer.js b/api/lib/infrastructure/serializers/jsonapi/training-trigger-serializer.js index 6a4e190a45d..2c196f14743 100644 --- a/api/lib/infrastructure/serializers/jsonapi/training-trigger-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/training-trigger-serializer.js @@ -1,54 +1,56 @@ -const { Serializer, Deserializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(trainingTrigger = {}, meta) { - return new Serializer('training-triggers', { - transform(record) { - return JSON.parse(JSON.stringify(record)); - }, - attributes: ['id', 'trainingId', 'type', 'threshold', 'areas', 'tubesCount'], - areas: { +const { Serializer, Deserializer } = jsonapiSerializer; + +const serialize = function (trainingTrigger = {}, meta) { + return new Serializer('training-triggers', { + transform(record) { + return JSON.parse(JSON.stringify(record)); + }, + attributes: ['id', 'trainingId', 'type', 'threshold', 'areas', 'tubesCount'], + areas: { + ref: 'id', + included: true, + attributes: ['title', 'code', 'color', 'competences'], + competences: { ref: 'id', included: true, - attributes: ['title', 'code', 'color', 'competences'], - competences: { + attributes: ['name', 'index', 'thematics'], + thematics: { ref: 'id', included: true, - attributes: ['name', 'index', 'thematics'], - thematics: { + attributes: ['name', 'index', 'triggerTubes'], + triggerTubes: { ref: 'id', included: true, - attributes: ['name', 'index', 'triggerTubes'], - triggerTubes: { + attributes: ['id', 'level', 'tube'], + tube: { ref: 'id', included: true, - attributes: ['id', 'level', 'tube'], - tube: { - ref: 'id', - included: true, - attributes: ['id', 'name', 'practicalTitle'], - }, + attributes: ['id', 'name', 'practicalTitle'], }, }, }, }, - meta, - typeForAttribute(attribute) { - switch (attribute) { - case 'triggerTubes': - return 'trigger-tubes'; - case 'tube': - return 'tubes'; - default: - return attribute; - } - }, - }).serialize(trainingTrigger); - }, + }, + meta, + typeForAttribute(attribute) { + switch (attribute) { + case 'triggerTubes': + return 'trigger-tubes'; + case 'tube': + return 'tubes'; + default: + return attribute; + } + }, + }).serialize(trainingTrigger); +}; - deserialize(payload) { - return new Deserializer({ - keyForAttribute: 'camelCase', - }).deserialize(payload); - }, +const deserialize = function (payload) { + return new Deserializer({ + keyForAttribute: 'camelCase', + }).deserialize(payload); }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/tutorial-attributes.js b/api/lib/infrastructure/serializers/jsonapi/tutorial-attributes.js index f4c6c7b8078..1b16296de61 100644 --- a/api/lib/infrastructure/serializers/jsonapi/tutorial-attributes.js +++ b/api/lib/infrastructure/serializers/jsonapi/tutorial-attributes.js @@ -1,5 +1,5 @@ -const tutorialEvaluationAttributes = require('./tutorial-evaluation-attributes.js'); -const userSavedTutorialAttributes = require('./user-saved-tutorial-attributes.js'); +import { tutorialEvaluationAttributes } from './tutorial-evaluation-attributes.js'; +import { userSavedTutorialAttributes } from './user-saved-tutorial-attributes.js'; const tutorialAttributes = { ref: 'id', includes: true, @@ -18,4 +18,4 @@ const tutorialAttributes = { userSavedTutorial: userSavedTutorialAttributes, }; -module.exports = tutorialAttributes; +export { tutorialAttributes }; diff --git a/api/lib/infrastructure/serializers/jsonapi/tutorial-evaluation-attributes.js b/api/lib/infrastructure/serializers/jsonapi/tutorial-evaluation-attributes.js index 732c67b0bc4..dc5b06b748b 100644 --- a/api/lib/infrastructure/serializers/jsonapi/tutorial-evaluation-attributes.js +++ b/api/lib/infrastructure/serializers/jsonapi/tutorial-evaluation-attributes.js @@ -4,4 +4,4 @@ const tutorialEvaluationAttributes = { attributes: ['id', 'userId', 'tutorialId', 'status'], }; -module.exports = tutorialEvaluationAttributes; +export { tutorialEvaluationAttributes }; diff --git a/api/lib/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer.js b/api/lib/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer.js index d374ec9972c..1cb9d3ad6fe 100644 --- a/api/lib/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer.js @@ -1,21 +1,24 @@ -const { Serializer } = require('jsonapi-serializer'); -const tutorial = require('./tutorial-attributes.js'); -const TutorialEvaluation = require('../../../domain/models/TutorialEvaluation.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(tutorialEvaluation) { - return new Serializer('tutorial-evaluation', { - attributes: ['tutorial', 'userId', 'tutorialId', 'status', 'updatedAt'], - tutorial, - }).serialize(tutorialEvaluation); - }, +const { Serializer } = jsonapiSerializer; - deserialize(json) { - return new TutorialEvaluation({ - id: json?.data.id, - userId: json?.data.attributes['user-id'], - tutorialId: json?.data.attributes['tutorial-id'], - status: json?.data.attributes.status, - }); - }, +import { tutorialAttributes } from './tutorial-attributes.js'; +import { TutorialEvaluation } from '../../../domain/models/TutorialEvaluation.js'; + +const serialize = function (tutorialEvaluation) { + return new Serializer('tutorial-evaluation', { + attributes: ['tutorial', 'userId', 'tutorialId', 'status', 'updatedAt'], + tutorial: tutorialAttributes, + }).serialize(tutorialEvaluation); +}; + +const deserialize = function (json) { + return new TutorialEvaluation({ + id: json?.data.id, + userId: json?.data.attributes['user-id'], + tutorialId: json?.data.attributes['tutorial-id'], + status: json?.data.attributes.status, + }); }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/tutorial-serializer.js b/api/lib/infrastructure/serializers/jsonapi/tutorial-serializer.js index 632faf3b64c..2e7a51a7a29 100644 --- a/api/lib/infrastructure/serializers/jsonapi/tutorial-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/tutorial-serializer.js @@ -1,30 +1,33 @@ -const { Serializer } = require('jsonapi-serializer'); -const tutorialEvaluationAttributes = require('./tutorial-evaluation-attributes.js'); -const userSavedTutorialAttributes = require('./user-saved-tutorial-attributes.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(tutorial = {}, pagination) { - return new Serializer('tutorials', { - attributes: [ - 'duration', - 'format', - 'link', - 'source', - 'title', - 'tubeName', - 'tubePracticalTitle', - 'tubePracticalDescription', - 'tutorialEvaluation', - 'userSavedTutorial', - 'skillId', - ], - tutorialEvaluation: tutorialEvaluationAttributes, - userSavedTutorial: userSavedTutorialAttributes, - typeForAttribute(attribute) { - if (attribute === 'userSavedTutorial') return 'user-saved-tutorial'; - return attribute; - }, - meta: pagination, - }).serialize(tutorial); - }, +const { Serializer } = jsonapiSerializer; + +import { tutorialEvaluationAttributes } from './tutorial-evaluation-attributes.js'; +import { userSavedTutorialAttributes } from './user-saved-tutorial-attributes.js'; + +const serialize = function (tutorial = {}, pagination) { + return new Serializer('tutorials', { + attributes: [ + 'duration', + 'format', + 'link', + 'source', + 'title', + 'tubeName', + 'tubePracticalTitle', + 'tubePracticalDescription', + 'tutorialEvaluation', + 'userSavedTutorial', + 'skillId', + ], + tutorialEvaluation: tutorialEvaluationAttributes, + userSavedTutorial: userSavedTutorialAttributes, + typeForAttribute(attribute) { + if (attribute === 'userSavedTutorial') return 'user-saved-tutorial'; + return attribute; + }, + meta: pagination, + }).serialize(tutorial); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/update-email-serializer.js b/api/lib/infrastructure/serializers/jsonapi/update-email-serializer.js index a10d272f8b4..a4833c7a912 100644 --- a/api/lib/infrastructure/serializers/jsonapi/update-email-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/update-email-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(newEmail) { - return new Serializer('email-verification-codes', { - attributes: ['email'], - }).serialize(newEmail); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (newEmail) { + return new Serializer('email-verification-codes', { + attributes: ['email'], + }).serialize(newEmail); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer.js index 32309b72e26..20f8f5cef51 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer.js @@ -1,26 +1,28 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(usersAnonymizedDetailsForAdmin) { - return new Serializer('user', { - attributes: [ - 'firstName', - 'lastName', - 'email', - 'username', - 'cgu', - 'hasBeenAnonymised', - 'anonymisedByFullName', - 'updatedAt', - 'pixOrgaTermsOfServiceAccepted', - 'pixCertifTermsOfServiceAccepted', - 'authenticationMethods', - ], - authenticationMethods: { - ref: 'id', - includes: true, - attributes: ['identityProvider'], - }, - }).serialize(usersAnonymizedDetailsForAdmin); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (usersAnonymizedDetailsForAdmin) { + return new Serializer('user', { + attributes: [ + 'firstName', + 'lastName', + 'email', + 'username', + 'cgu', + 'hasBeenAnonymised', + 'anonymisedByFullName', + 'updatedAt', + 'pixOrgaTermsOfServiceAccepted', + 'pixCertifTermsOfServiceAccepted', + 'authenticationMethods', + ], + authenticationMethods: { + ref: 'id', + includes: true, + attributes: ['identityProvider'], + }, + }).serialize(usersAnonymizedDetailsForAdmin); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-details-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-details-for-admin-serializer.js index 23a3c77178d..5a4394de4fa 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-details-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-details-for-admin-serializer.js @@ -1,162 +1,165 @@ -const { Serializer } = require('jsonapi-serializer'); -const UserDetailsForAdmin = require('../../../domain/models/UserDetailsForAdmin.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(usersDetailsForAdmin) { - return new Serializer('user', { - transform(record) { - record.profile = null; - record.participations = null; - record.organizationMemberships = null; - record.certificationCenterMemberships = null; - return record; - }, +const { Serializer } = jsonapiSerializer; + +import { UserDetailsForAdmin } from '../../../domain/models/UserDetailsForAdmin.js'; + +const serialize = function (usersDetailsForAdmin) { + return new Serializer('user', { + transform(record) { + record.profile = null; + record.participations = null; + record.organizationMemberships = null; + record.certificationCenterMemberships = null; + return record; + }, + attributes: [ + 'firstName', + 'lastName', + 'email', + 'username', + 'cgu', + 'pixOrgaTermsOfServiceAccepted', + 'pixCertifTermsOfServiceAccepted', + 'createdAt', + 'lang', + 'locale', + 'lastTermsOfServiceValidatedAt', + 'lastPixOrgaTermsOfServiceValidatedAt', + 'lastPixCertifTermsOfServiceValidatedAt', + 'lastLoggedAt', + 'emailConfirmedAt', + 'hasBeenAnonymised', + 'anonymisedByFullName', + 'organizationLearners', + 'authenticationMethods', + 'profile', + 'participations', + 'organizationMemberships', + 'certificationCenterMemberships', + 'userLogin', + ], + organizationLearners: { + ref: 'id', + includes: true, attributes: [ 'firstName', 'lastName', - 'email', - 'username', - 'cgu', - 'pixOrgaTermsOfServiceAccepted', - 'pixCertifTermsOfServiceAccepted', + 'birthdate', + 'division', + 'group', + 'organizationId', + 'organizationName', 'createdAt', - 'lang', - 'locale', - 'lastTermsOfServiceValidatedAt', - 'lastPixOrgaTermsOfServiceValidatedAt', - 'lastPixCertifTermsOfServiceValidatedAt', - 'lastLoggedAt', - 'emailConfirmedAt', - 'hasBeenAnonymised', - 'anonymisedByFullName', - 'organizationLearners', - 'authenticationMethods', - 'profile', - 'participations', - 'organizationMemberships', - 'certificationCenterMemberships', - 'userLogin', + 'updatedAt', + 'isDisabled', + 'canBeDissociated', ], - organizationLearners: { - ref: 'id', - includes: true, - attributes: [ - 'firstName', - 'lastName', - 'birthdate', - 'division', - 'group', - 'organizationId', - 'organizationName', - 'createdAt', - 'updatedAt', - 'isDisabled', - 'canBeDissociated', - ], - }, - authenticationMethods: { - ref: 'id', - includes: true, - attributes: ['identityProvider', 'authenticationComplement'], - }, - userLogin: { - ref: 'id', - includes: true, - attributes: ['blockedAt', 'temporaryBlockedUntil', 'failureCount'], - }, - profile: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/admin/users/${parent.id}/profile`; - }, + }, + authenticationMethods: { + ref: 'id', + includes: true, + attributes: ['identityProvider', 'authenticationComplement'], + }, + userLogin: { + ref: 'id', + includes: true, + attributes: ['blockedAt', 'temporaryBlockedUntil', 'failureCount'], + }, + profile: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/admin/users/${parent.id}/profile`; }, }, - participations: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/admin/users/${parent.id}/participations`; - }, + }, + participations: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/admin/users/${parent.id}/participations`; }, }, - organizationMemberships: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/admin/users/${parent.id}/organizations`; - }, + }, + organizationMemberships: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/admin/users/${parent.id}/organizations`; }, }, - certificationCenterMemberships: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/admin/users/${parent.id}/certification-center-memberships`; - }, + }, + certificationCenterMemberships: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/admin/users/${parent.id}/certification-center-memberships`; }, }, - }).serialize(usersDetailsForAdmin); - }, + }, + }).serialize(usersDetailsForAdmin); +}; - serializeForUpdate(usersDetailsForAdmin) { - return new Serializer('user', { +const serializeForUpdate = function (usersDetailsForAdmin) { + return new Serializer('user', { + attributes: [ + 'firstName', + 'lastName', + 'email', + 'username', + 'lang', + 'locale', + 'cgu', + 'pixOrgaTermsOfServiceAccepted', + 'pixCertifTermsOfServiceAccepted', + 'organizationLearners', + 'authenticationMethods', + ], + organizationLearners: { + ref: 'id', + includes: true, attributes: [ 'firstName', 'lastName', - 'email', - 'username', - 'lang', - 'locale', - 'cgu', - 'pixOrgaTermsOfServiceAccepted', - 'pixCertifTermsOfServiceAccepted', - 'organizationLearners', - 'authenticationMethods', + 'birthdate', + 'division', + 'group', + 'organizationId', + 'organizationName', + 'createdAt', + 'updatedAt', + 'isDisabled', + 'canBeDissociated', ], - organizationLearners: { - ref: 'id', - includes: true, - attributes: [ - 'firstName', - 'lastName', - 'birthdate', - 'division', - 'group', - 'organizationId', - 'organizationName', - 'createdAt', - 'updatedAt', - 'isDisabled', - 'canBeDissociated', - ], - }, - authenticationMethods: { - ref: 'id', - includes: true, - attributes: ['identityProvider'], - }, - userLogin: { - ref: 'id', - includes: true, - attributes: ['blockedAt', 'createdAt', 'updatedAt', 'temporaryBlockedUntil', 'failureCount'], - }, - }).serialize(usersDetailsForAdmin); - }, + }, + authenticationMethods: { + ref: 'id', + includes: true, + attributes: ['identityProvider'], + }, + userLogin: { + ref: 'id', + includes: true, + attributes: ['blockedAt', 'createdAt', 'updatedAt', 'temporaryBlockedUntil', 'failureCount'], + }, + }).serialize(usersDetailsForAdmin); +}; - deserialize(json) { - return new UserDetailsForAdmin({ - id: json.data.id, - firstName: json.data.attributes['first-name'], - lastName: json.data.attributes['last-name'], - email: json.data.attributes.email, - username: json.data.attributes.username, - lang: json.data.attributes.lang, - locale: json.data.attributes.locale, - }); - }, +const deserialize = function (json) { + return new UserDetailsForAdmin({ + id: json.data.id, + firstName: json.data.attributes['first-name'], + lastName: json.data.attributes['last-name'], + email: json.data.attributes.email, + username: json.data.attributes.username, + lang: json.data.attributes.lang, + locale: json.data.attributes.locale, + }); }; + +export { serialize, serializeForUpdate, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-for-admin-serializer.js index ef020173563..2a96302da4b 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-for-admin-serializer.js @@ -1,71 +1,73 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(users, meta) { - return new Serializer('user', { - transform(record) { - record.profile = null; - return record; - }, - attributes: [ - 'firstName', - 'lastName', - 'email', - 'username', - 'cgu', - 'lastTermsOfServiceValidatedAt', - 'mustValidateTermsOfService', - 'pixOrgaTermsOfServiceAccepted', - 'pixCertifTermsOfServiceAccepted', - 'lang', - 'isAnonymous', - 'memberships', - 'certificationCenterMemberships', - 'pixScore', - 'scorecards', - 'profile', - 'campaignParticipations', - 'hasSeenAssessmentInstructions', - 'isCertifiable', - 'hasSeenNewDashboardInfo', - 'hasSeenFocusedChallengeTooltip', - 'hasSeenOtherChallengesTooltip', - ], - memberships: { - ref: 'id', - ignoreRelationshipData: true, - }, - certificationCenterMemberships: { - ref: 'id', - ignoreRelationshipData: true, - }, - pixScore: { - ref: 'id', - ignoreRelationshipData: true, - }, - scorecards: { - ref: 'id', - ignoreRelationshipData: true, - }, - profile: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/admin/users/${parent.id}/profile`; - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (users, meta) { + return new Serializer('user', { + transform(record) { + record.profile = null; + return record; + }, + attributes: [ + 'firstName', + 'lastName', + 'email', + 'username', + 'cgu', + 'lastTermsOfServiceValidatedAt', + 'mustValidateTermsOfService', + 'pixOrgaTermsOfServiceAccepted', + 'pixCertifTermsOfServiceAccepted', + 'lang', + 'isAnonymous', + 'memberships', + 'certificationCenterMemberships', + 'pixScore', + 'scorecards', + 'profile', + 'campaignParticipations', + 'hasSeenAssessmentInstructions', + 'isCertifiable', + 'hasSeenNewDashboardInfo', + 'hasSeenFocusedChallengeTooltip', + 'hasSeenOtherChallengesTooltip', + ], + memberships: { + ref: 'id', + ignoreRelationshipData: true, + }, + certificationCenterMemberships: { + ref: 'id', + ignoreRelationshipData: true, + }, + pixScore: { + ref: 'id', + ignoreRelationshipData: true, + }, + scorecards: { + ref: 'id', + ignoreRelationshipData: true, + }, + profile: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/admin/users/${parent.id}/profile`; }, }, - campaignParticipations: { - ref: 'id', - ignoreRelationshipData: true, - }, - isCertifiable: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - }, - meta, - }).serialize(users); - }, + }, + campaignParticipations: { + ref: 'id', + ignoreRelationshipData: true, + }, + isCertifiable: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + }, + meta, + }).serialize(users); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-login-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-login-serializer.js index a8c8097a5ec..959d7fd9be3 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-login-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-login-serializer.js @@ -1,9 +1,11 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(usersAnonymizedDetailsForAdmin) { - return new Serializer('user-login', { - attributes: ['userId', 'failureCount', 'temporaryBlockedUntil', 'blockedAt'], - }).serialize(usersAnonymizedDetailsForAdmin); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (usersAnonymizedDetailsForAdmin) { + return new Serializer('user-login', { + attributes: ['userId', 'failureCount', 'temporaryBlockedUntil', 'blockedAt'], + }).serialize(usersAnonymizedDetailsForAdmin); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-orga-settings-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-orga-settings-serializer.js index 156faab91df..1e115ce7b4d 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-orga-settings-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-orga-settings-serializer.js @@ -1,77 +1,79 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(userOrgaSettings) { - return new Serializer('user-orga-settings', { - transform(record) { - if (!record.user) { - delete record.user; - } +const { Serializer } = jsonapiSerializer; - record.organization = record.currentOrganization; - return record; - }, - attributes: ['organization', 'user'], - organization: { +const serialize = function (userOrgaSettings) { + return new Serializer('user-orga-settings', { + transform(record) { + if (!record.user) { + delete record.user; + } + + record.organization = record.currentOrganization; + return record; + }, + attributes: ['organization', 'user'], + organization: { + ref: 'id', + included: true, + attributes: [ + 'code', + 'name', + 'type', + 'isManagingStudents', + 'externalId', + 'campaigns', + 'targetProfiles', + 'memberships', + 'organizationInvitations', + ], + campaigns: { ref: 'id', - included: true, - attributes: [ - 'code', - 'name', - 'type', - 'isManagingStudents', - 'externalId', - 'campaigns', - 'targetProfiles', - 'memberships', - 'organizationInvitations', - ], - campaigns: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/campaigns`; - }, - }, - }, - targetProfiles: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/target-profiles`; - }, + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/campaigns`; }, }, - memberships: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/memberships`; - }, + }, + targetProfiles: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/target-profiles`; }, }, - organizationInvitations: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/organizations/${parent.id}/invitations`; - }, + }, + memberships: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/memberships`; }, }, }, - user: { + organizationInvitations: { ref: 'id', - included: true, - attributes: ['firstName', 'lastName', 'email'], + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/organizations/${parent.id}/invitations`; + }, + }, }, - }).serialize(userOrgaSettings); - }, + }, + user: { + ref: 'id', + included: true, + attributes: ['firstName', 'lastName', 'email'], + }, + }).serialize(userOrgaSettings); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer.js index dfe2b0a9cd5..9245a832ece 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer.js @@ -1,16 +1,18 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(organization) { - return new Serializer('organization-membership', { - attributes: [ - 'updatedAt', - 'organizationRole', - 'organizationId', - 'organizationName', - 'organizationType', - 'organizationExternalId', - ], - }).serialize(organization); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (organization) { + return new Serializer('organization-membership', { + attributes: [ + 'updatedAt', + 'organizationRole', + 'organizationId', + 'organizationName', + 'organizationType', + 'organizationExternalId', + ], + }).serialize(organization); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-saved-tutorial-attributes.js b/api/lib/infrastructure/serializers/jsonapi/user-saved-tutorial-attributes.js index eceb5cef649..80065ce2821 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-saved-tutorial-attributes.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-saved-tutorial-attributes.js @@ -4,4 +4,4 @@ const userSavedTutorialAttributes = { attributes: ['id', 'userId', 'tutorialId'], }; -module.exports = userSavedTutorialAttributes; +export { userSavedTutorialAttributes }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer.js index d2a283fcd68..8b2ffc05a1a 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer.js @@ -1,19 +1,22 @@ -const { Serializer } = require('jsonapi-serializer'); -const tutorial = require('./tutorial-attributes.js'); -const UserSavedTutorial = require('../../../domain/models/UserSavedTutorial.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(userTutorial) { - return new Serializer('user-saved-tutorial', { - attributes: ['tutorial', 'userId', 'tutorialId', 'skillId', 'updatedAt'], - tutorial, - }).serialize(userTutorial); - }, +const { Serializer } = jsonapiSerializer; - deserialize(json) { - return new UserSavedTutorial({ - id: json?.data.id, - skillId: json?.data.attributes['skill-id'], - }); - }, +import { tutorialAttributes } from './tutorial-attributes.js'; +import { UserSavedTutorial } from '../../../domain/models/UserSavedTutorial.js'; + +const serialize = function (userTutorial) { + return new Serializer('user-saved-tutorial', { + attributes: ['tutorial', 'userId', 'tutorialId', 'skillId', 'updatedAt'], + tutorial: tutorialAttributes, + }).serialize(userTutorial); +}; + +const deserialize = function (json) { + return new UserSavedTutorial({ + id: json?.data.id, + skillId: json?.data.attributes['skill-id'], + }); }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-serializer.js index 152440b6e7f..0d057df3276 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-serializer.js @@ -1,89 +1,92 @@ -const { Serializer } = require('jsonapi-serializer'); -const User = require('../../../domain/models/User.js'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(users, meta) { - return new Serializer('user', { - attributes: [ - 'firstName', - 'lastName', - 'email', - 'username', - 'cgu', - 'lastTermsOfServiceValidatedAt', - 'mustValidateTermsOfService', - 'pixOrgaTermsOfServiceAccepted', - 'pixCertifTermsOfServiceAccepted', - 'lang', - 'locale', - 'isAnonymous', - 'profile', - 'campaignParticipations', - 'hasSeenAssessmentInstructions', - 'isCertifiable', - 'hasSeenNewDashboardInfo', - 'hasSeenFocusedChallengeTooltip', - 'hasSeenOtherChallengesTooltip', - 'trainings', - 'lastDataProtectionPolicySeenAt', - 'shouldSeeDataProtectionPolicyInformationBanner', - ], - profile: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/users/${parent.id}/profile`; - }, +const { Serializer } = jsonapiSerializer; + +import { User } from '../../../domain/models/User.js'; + +const serialize = function (users, meta) { + return new Serializer('user', { + attributes: [ + 'firstName', + 'lastName', + 'email', + 'username', + 'cgu', + 'lastTermsOfServiceValidatedAt', + 'mustValidateTermsOfService', + 'pixOrgaTermsOfServiceAccepted', + 'pixCertifTermsOfServiceAccepted', + 'lang', + 'locale', + 'isAnonymous', + 'profile', + 'campaignParticipations', + 'hasSeenAssessmentInstructions', + 'isCertifiable', + 'hasSeenNewDashboardInfo', + 'hasSeenFocusedChallengeTooltip', + 'hasSeenOtherChallengesTooltip', + 'trainings', + 'lastDataProtectionPolicySeenAt', + 'shouldSeeDataProtectionPolicyInformationBanner', + ], + profile: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/users/${parent.id}/profile`; }, }, - campaignParticipations: { - ref: 'id', - ignoreRelationshipData: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/users/${parent.id}/campaign-participations`; - }, + }, + campaignParticipations: { + ref: 'id', + ignoreRelationshipData: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/users/${parent.id}/campaign-participations`; }, }, - isCertifiable: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/users/${parent.id}/is-certifiable`; - }, + }, + isCertifiable: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/users/${parent.id}/is-certifiable`; }, }, - trainings: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/users/${parent.id}/trainings`; - }, + }, + trainings: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/users/${parent.id}/trainings`; }, }, - meta, - }).serialize(users); - }, + }, + meta, + }).serialize(users); +}; - deserialize(json) { - return new User({ - id: json.data.id, - firstName: json.data.attributes['first-name'], - lastName: json.data.attributes['last-name'], - email: json.data.attributes.email, - cgu: json.data.attributes.cgu, - lang: json.data.attributes.lang, - locale: json.data.attributes.locale, - lastTermsOfServiceValidatedAt: json.data.attributes['lastTermsOfServiceValidatedAt'], - mustValidateTermsOfService: json.data.attributes['must-validate-terms-of-service'], - pixOrgaTermsOfServiceAccepted: json.data.attributes['pix-orga-terms-of-service-accepted'], - pixCertifTermsOfServiceAccepted: json.data.attributes['pix-certif-terms-of-service-accepted'], - }); - }, +const deserialize = function (json) { + return new User({ + id: json.data.id, + firstName: json.data.attributes['first-name'], + lastName: json.data.attributes['last-name'], + email: json.data.attributes.email, + cgu: json.data.attributes.cgu, + lang: json.data.attributes.lang, + locale: json.data.attributes.locale, + lastTermsOfServiceValidatedAt: json.data.attributes['lastTermsOfServiceValidatedAt'], + mustValidateTermsOfService: json.data.attributes['must-validate-terms-of-service'], + pixOrgaTermsOfServiceAccepted: json.data.attributes['pix-orga-terms-of-service-accepted'], + pixCertifTermsOfServiceAccepted: json.data.attributes['pix-certif-terms-of-service-accepted'], + }); }; + +export { serialize, deserialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/user-with-activity-serializer.js b/api/lib/infrastructure/serializers/jsonapi/user-with-activity-serializer.js index 463ea5741e2..a6accb61339 100644 --- a/api/lib/infrastructure/serializers/jsonapi/user-with-activity-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/user-with-activity-serializer.js @@ -1,64 +1,66 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(users, meta) { - return new Serializer('user', { - attributes: [ - 'firstName', - 'lastName', - 'email', - 'username', - 'cgu', - 'lastTermsOfServiceValidatedAt', - 'lastDataProtectionPolicySeenAt', - 'mustValidateTermsOfService', - 'pixOrgaTermsOfServiceAccepted', - 'pixCertifTermsOfServiceAccepted', - 'lang', - 'isAnonymous', - 'profile', - 'hasSeenAssessmentInstructions', - 'isCertifiable', - 'hasSeenNewDashboardInfo', - 'hasSeenFocusedChallengeTooltip', - 'hasSeenOtherChallengesTooltip', - 'hasAssessmentParticipations', - 'hasRecommendedTrainings', - 'codeForLastProfileToShare', - 'trainings', - 'shouldSeeDataProtectionPolicyInformationBanner', - ], - profile: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/users/${parent.id}/profile`; - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (users, meta) { + return new Serializer('user', { + attributes: [ + 'firstName', + 'lastName', + 'email', + 'username', + 'cgu', + 'lastTermsOfServiceValidatedAt', + 'lastDataProtectionPolicySeenAt', + 'mustValidateTermsOfService', + 'pixOrgaTermsOfServiceAccepted', + 'pixCertifTermsOfServiceAccepted', + 'lang', + 'isAnonymous', + 'profile', + 'hasSeenAssessmentInstructions', + 'isCertifiable', + 'hasSeenNewDashboardInfo', + 'hasSeenFocusedChallengeTooltip', + 'hasSeenOtherChallengesTooltip', + 'hasAssessmentParticipations', + 'hasRecommendedTrainings', + 'codeForLastProfileToShare', + 'trainings', + 'shouldSeeDataProtectionPolicyInformationBanner', + ], + profile: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/users/${parent.id}/profile`; }, }, - isCertifiable: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/users/${parent.id}/is-certifiable`; - }, + }, + isCertifiable: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/users/${parent.id}/is-certifiable`; }, }, - trainings: { - ref: 'id', - ignoreRelationshipData: true, - nullIfMissing: true, - relationshipLinks: { - related: function (record, current, parent) { - return `/api/users/${parent.id}/trainings`; - }, + }, + trainings: { + ref: 'id', + ignoreRelationshipData: true, + nullIfMissing: true, + relationshipLinks: { + related: function (record, current, parent) { + return `/api/users/${parent.id}/trainings`; }, }, - meta, - }).serialize(users); - }, + }, + meta, + }).serialize(users); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/validation-error-serializer.js b/api/lib/infrastructure/serializers/jsonapi/validation-error-serializer.js index 5ac0956d8b6..fd2ed0f4c3e 100644 --- a/api/lib/infrastructure/serializers/jsonapi/validation-error-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/validation-error-serializer.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; function _buildError(field, message) { return { @@ -37,4 +37,4 @@ function serialize(validationErrors) { }; } -module.exports = { serialize }; +export { serialize }; diff --git a/api/lib/infrastructure/serializers/jsonapi/with-required-action-session-serializer.js b/api/lib/infrastructure/serializers/jsonapi/with-required-action-session-serializer.js index 80418bf34b5..67b24293831 100644 --- a/api/lib/infrastructure/serializers/jsonapi/with-required-action-session-serializer.js +++ b/api/lib/infrastructure/serializers/jsonapi/with-required-action-session-serializer.js @@ -1,19 +1,21 @@ -const { Serializer } = require('jsonapi-serializer'); +import jsonapiSerializer from 'jsonapi-serializer'; -module.exports = { - serialize(finalizedSessions) { - return new Serializer('with-required-action-session', { - transform(finalizedSession) { - return { ...finalizedSession, id: finalizedSession.sessionId }; - }, - attributes: [ - 'sessionId', - 'sessionDate', - 'sessionTime', - 'finalizedAt', - 'certificationCenterName', - 'assignedCertificationOfficerName', - ], - }).serialize(finalizedSessions); - }, +const { Serializer } = jsonapiSerializer; + +const serialize = function (finalizedSessions) { + return new Serializer('with-required-action-session', { + transform(finalizedSession) { + return { ...finalizedSession, id: finalizedSession.sessionId }; + }, + attributes: [ + 'sessionId', + 'sessionDate', + 'sessionTime', + 'finalizedAt', + 'certificationCenterName', + 'assignedCertificationOfficerName', + ], + }).serialize(finalizedSessions); }; + +export { serialize }; diff --git a/api/lib/infrastructure/serializers/xml/siecle-parser.js b/api/lib/infrastructure/serializers/xml/siecle-parser.js index 1dad8ff07fc..21c93ea1b16 100644 --- a/api/lib/infrastructure/serializers/xml/siecle-parser.js +++ b/api/lib/infrastructure/serializers/xml/siecle-parser.js @@ -1,9 +1,12 @@ -const { SiecleXmlImportError } = require('../../../domain/errors.js'); -const xml2js = require('xml2js'); -const saxPath = require('saxpath'); -const { isEmpty, isUndefined } = require('lodash'); -const SiecleFileStreamer = require('../../utils/xml/siecle-file-streamer.js'); -const XMLOrganizationLearnerSet = require('./xml-organization-learner-set.js'); +import { SiecleXmlImportError } from '../../../domain/errors.js'; +import xml2js from 'xml2js'; +import saxPath from 'saxpath'; +import lodash from 'lodash'; + +const { isEmpty, isUndefined } = lodash; + +import { SiecleFileStreamer } from '../../utils/xml/siecle-file-streamer.js'; +import { XMLOrganizationLearnersSet } from './xml-organization-learner-set.js'; const ERRORS = { UAI_MISMATCHED: 'UAI_MISMATCHED', @@ -18,7 +21,7 @@ class SiecleParser { constructor(organization, path) { this.organization = organization; this.path = path; - this.organizationLearnersSet = new XMLOrganizationLearnerSet(); + this.organizationLearnersSet = new XMLOrganizationLearnersSet(); } async parse() { @@ -107,4 +110,4 @@ function _isImportable(studentData) { return isStudentNotLeftOrganizationLearner && isStudentNotYetArrivedOrganizationLearner; } -module.exports = SiecleParser; +export { SiecleParser }; diff --git a/api/lib/infrastructure/serializers/xml/xml-organization-learner-set.js b/api/lib/infrastructure/serializers/xml/xml-organization-learner-set.js index f4ed73a49f1..508c205d922 100644 --- a/api/lib/infrastructure/serializers/xml/xml-organization-learner-set.js +++ b/api/lib/infrastructure/serializers/xml/xml-organization-learner-set.js @@ -1,6 +1,9 @@ -const moment = require('moment'); -const { isEmpty, isNil, each } = require('lodash'); -const { SiecleXmlImportError } = require('../../../domain/errors.js'); +import moment from 'moment'; +import lodash from 'lodash'; + +const { isEmpty, isNil, each } = lodash; + +import { SiecleXmlImportError } from '../../../domain/errors.js'; const ERRORS = { INE_REQUIRED: 'INE_REQUIRED', @@ -102,4 +105,4 @@ function _frenchBornHasEmptyCityCode({ birthCountryCode, birthCityCode }) { return birthCountryCode === FRANCE_COUNTRY_CODE && isEmpty(birthCityCode); } -module.exports = XMLOrganizationLearnersSet; +export { XMLOrganizationLearnersSet }; diff --git a/api/lib/infrastructure/temporary-storage/InMemoryTemporaryStorage.js b/api/lib/infrastructure/temporary-storage/InMemoryTemporaryStorage.js index 7c46855b843..1b1198159ee 100644 --- a/api/lib/infrastructure/temporary-storage/InMemoryTemporaryStorage.js +++ b/api/lib/infrastructure/temporary-storage/InMemoryTemporaryStorage.js @@ -1,7 +1,9 @@ -const NodeCache = require('node-cache'); -const trim = require('lodash/trim'); -const TemporaryStorage = require('./TemporaryStorage.js'); -const { noop } = require('lodash'); +import NodeCache from 'node-cache'; +import lodash from 'lodash'; + +const { trim, noop } = lodash; + +import { TemporaryStorage } from './TemporaryStorage.js'; class InMemoryTemporaryStorage extends TemporaryStorage { constructor() { @@ -62,4 +64,4 @@ class InMemoryTemporaryStorage extends TemporaryStorage { } } -module.exports = InMemoryTemporaryStorage; +export { InMemoryTemporaryStorage }; diff --git a/api/lib/infrastructure/temporary-storage/RedisTemporaryStorage.js b/api/lib/infrastructure/temporary-storage/RedisTemporaryStorage.js index 348badb07de..9afcc6ba291 100644 --- a/api/lib/infrastructure/temporary-storage/RedisTemporaryStorage.js +++ b/api/lib/infrastructure/temporary-storage/RedisTemporaryStorage.js @@ -1,7 +1,9 @@ -const trim = require('lodash/trim'); +import lodash from 'lodash'; -const TemporaryStorage = require('./TemporaryStorage.js'); -const RedisClient = require('../utils/RedisClient.js'); +const { trim } = lodash; + +import { TemporaryStorage } from './TemporaryStorage.js'; +import { RedisClient } from '../utils/RedisClient.js'; const EXPIRATION_PARAMETER = 'ex'; const KEEPTTL_PARAMETER = 'keepttl'; @@ -65,4 +67,4 @@ class RedisTemporaryStorage extends TemporaryStorage { } } -module.exports = RedisTemporaryStorage; +export { RedisTemporaryStorage }; diff --git a/api/lib/infrastructure/temporary-storage/TemporaryStorage.js b/api/lib/infrastructure/temporary-storage/TemporaryStorage.js index b74e38ab54b..50bd4903ed3 100644 --- a/api/lib/infrastructure/temporary-storage/TemporaryStorage.js +++ b/api/lib/infrastructure/temporary-storage/TemporaryStorage.js @@ -1,4 +1,4 @@ -const { v4: uuidv4 } = require('uuid'); +import { v4 as uuidv4 } from 'uuid'; class TemporaryStorage { static generateKey() { @@ -89,4 +89,4 @@ class TemporaryStorage { } } -module.exports = TemporaryStorage; +export { TemporaryStorage }; diff --git a/api/lib/infrastructure/temporary-storage/index.js b/api/lib/infrastructure/temporary-storage/index.js index 8c06ed7c81c..4e479367a6f 100644 --- a/api/lib/infrastructure/temporary-storage/index.js +++ b/api/lib/infrastructure/temporary-storage/index.js @@ -1,8 +1,8 @@ -const settings = require('../../config.js'); -const REDIS_URL = settings.temporaryStorage.redisUrl; +import { config } from '../../config.js'; +const REDIS_URL = config.temporaryStorage.redisUrl; -const InMemoryTemporaryStorage = require('./InMemoryTemporaryStorage.js'); -const RedisTemporaryStorage = require('./RedisTemporaryStorage.js'); +import { InMemoryTemporaryStorage } from './InMemoryTemporaryStorage.js'; +import { RedisTemporaryStorage } from './RedisTemporaryStorage.js'; function _createTemporaryStorage() { if (REDIS_URL) { @@ -14,4 +14,4 @@ function _createTemporaryStorage() { const temporaryStorage = _createTemporaryStorage(); -module.exports = { temporaryStorage }; +export { temporaryStorage }; diff --git a/api/lib/infrastructure/utils/CampaignAssessmentCsvLine.js b/api/lib/infrastructure/utils/CampaignAssessmentCsvLine.js index 6dfdf208f07..6e628293344 100644 --- a/api/lib/infrastructure/utils/CampaignAssessmentCsvLine.js +++ b/api/lib/infrastructure/utils/CampaignAssessmentCsvLine.js @@ -1,5 +1,5 @@ -const moment = require('moment'); -const _ = require('lodash'); +import moment from 'moment'; +import _ from 'lodash'; const STATS_COLUMNS_COUNT = 3; @@ -199,4 +199,4 @@ class CampaignAssessmentCsvLine { } } -module.exports = CampaignAssessmentCsvLine; +export { CampaignAssessmentCsvLine }; diff --git a/api/lib/infrastructure/utils/RedisClient.js b/api/lib/infrastructure/utils/RedisClient.js index c0c45e8c569..52491f04f42 100644 --- a/api/lib/infrastructure/utils/RedisClient.js +++ b/api/lib/infrastructure/utils/RedisClient.js @@ -1,11 +1,14 @@ -const redis = require('redis'); -const Redlock = require('redlock'); -const { promisify } = require('util'); -const logger = require('../logger.js'); +import redis from 'redis'; +import Redlock from 'redlock'; +import util from 'util'; + +const { promisify } = util; + +import { logger } from '../logger.js'; const REDIS_CLIENT_OPTIONS = {}; -module.exports = class RedisClient { +class RedisClient { constructor(redisUrl, { name, prefix } = {}) { this._clientName = name; @@ -63,4 +66,6 @@ module.exports = class RedisClient { async quit() { await this._client.quit(); } -}; +} + +export { RedisClient }; diff --git a/api/lib/infrastructure/utils/bookshelf-to-domain-converter.js b/api/lib/infrastructure/utils/bookshelf-to-domain-converter.js index 50d69ab22a0..1ec785b7406 100644 --- a/api/lib/infrastructure/utils/bookshelf-to-domain-converter.js +++ b/api/lib/infrastructure/utils/bookshelf-to-domain-converter.js @@ -1,10 +1,7 @@ -const _ = require('lodash'); -const Models = require('../../domain/models/index.js'); +import _ from 'lodash'; +import * as Models from '../../domain/models/index.js'; -module.exports = { - buildDomainObjects, - buildDomainObject, -}; +export { buildDomainObjects, buildDomainObject }; function buildDomainObjects(BookshelfClass, bookshelfObjects) { return bookshelfObjects.map((bookshelfObject) => buildDomainObject(BookshelfClass, bookshelfObject)); @@ -18,6 +15,7 @@ function buildDomainObject(BookshelfClass, bookshelfObject) { } function _buildDomainObject(BookshelfClass, bookshelfObjectJson) { + // eslint-disable-next-line import/namespace const Model = Models[BookshelfClass.modelName]; const domainObject = new Model(); diff --git a/api/lib/infrastructure/utils/code-utils.js b/api/lib/infrastructure/utils/code-utils.js index 29fb624af92..eb82ea62327 100644 --- a/api/lib/infrastructure/utils/code-utils.js +++ b/api/lib/infrastructure/utils/code-utils.js @@ -1,11 +1,11 @@ -const randomString = require('randomstring'); +import randomString from 'randomstring'; -module.exports = { - generateNumericalString(numberOfDigits) { - return randomString.generate({ - charset: 'numeric', - length: numberOfDigits, - readable: true, - }); - }, +const generateNumericalString = function (numberOfDigits) { + return randomString.generate({ + charset: 'numeric', + length: numberOfDigits, + readable: true, + }); }; + +export { generateNumericalString }; diff --git a/api/lib/infrastructure/utils/csv/certification-results.js b/api/lib/infrastructure/utils/csv/certification-results.js index c6d12446979..ab992d885ba 100644 --- a/api/lib/infrastructure/utils/csv/certification-results.js +++ b/api/lib/infrastructure/utils/csv/certification-results.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); -const moment = require('moment'); -const { getCsvContent } = require('./write-csv-utils.js'); +import _ from 'lodash'; +import moment from 'moment'; +import { getCsvContent } from './write-csv-utils.js'; const REJECTED_AUTOMATICALLY_COMMENT = "Le candidat a répondu faux à plus de 50% des questions posées, cela a invalidé l'ensemble de sa certification, et a donc entraîné un score de 0 pix"; @@ -343,7 +343,7 @@ const _headers = { FIRST_SHOT: 'Obtention après la première évaluation ?', }; -module.exports = { +export { getSessionCertificationResultsCsv, getDivisionCertificationResultsCsv, getCleaCertifiedCandidateCsv, diff --git a/api/lib/infrastructure/utils/csv/sessions-import.js b/api/lib/infrastructure/utils/csv/sessions-import.js index 391feac0085..3acb74f20a9 100644 --- a/api/lib/infrastructure/utils/csv/sessions-import.js +++ b/api/lib/infrastructure/utils/csv/sessions-import.js @@ -49,8 +49,4 @@ const emptySession = { const COMPLEMENTARY_CERTIFICATION_SUFFIX = "('oui' ou laisser vide)"; -module.exports = { - headers, - emptySession, - COMPLEMENTARY_CERTIFICATION_SUFFIX, -}; +export { headers, emptySession, COMPLEMENTARY_CERTIFICATION_SUFFIX }; diff --git a/api/lib/infrastructure/utils/csv/write-csv-utils.js b/api/lib/infrastructure/utils/csv/write-csv-utils.js index b715c06b756..7c6da905e44 100644 --- a/api/lib/infrastructure/utils/csv/write-csv-utils.js +++ b/api/lib/infrastructure/utils/csv/write-csv-utils.js @@ -1,5 +1,6 @@ -const { parseAsync } = require('json2csv'); -const { CsvParsingError } = require('../../../../lib/domain/errors.js'); +import { parseAsync } from 'json2csv'; + +import { CsvParsingError } from '../../../../lib/domain/errors.js'; async function getCsvContent({ data, delimiter = ';', eol = '\n', fileHeaders, withBOM = true }) { try { @@ -11,6 +12,4 @@ async function getCsvContent({ data, delimiter = ';', eol = '\n', fileHeaders, w } } -module.exports = { - getCsvContent, -}; +export { getCsvContent }; diff --git a/api/lib/infrastructure/utils/date-utils.js b/api/lib/infrastructure/utils/date-utils.js index 6a0416289c0..5d242194305 100644 --- a/api/lib/infrastructure/utils/date-utils.js +++ b/api/lib/infrastructure/utils/date-utils.js @@ -1,4 +1,4 @@ -const moment = require('moment-timezone'); +import moment from 'moment-timezone'; moment.parseTwoDigitYear = function (yearString) { const year = parseInt(yearString); @@ -23,8 +23,4 @@ function getNowDate() { return new Date(); } -module.exports = { - isValidDate, - convertDateValue, - getNowDate, -}; +export { isValidDate, convertDateValue, getNowDate }; diff --git a/api/lib/infrastructure/utils/dependency-injection.js b/api/lib/infrastructure/utils/dependency-injection.js index 9a5017bef85..e022bc101d8 100644 --- a/api/lib/infrastructure/utils/dependency-injection.js +++ b/api/lib/infrastructure/utils/dependency-injection.js @@ -1,4 +1,4 @@ -const _ = require('lodash'); +import _ from 'lodash'; function injectDefaults(defaults, targetFn) { return (args) => targetFn(Object.assign(Object.create(defaults), args)); @@ -8,4 +8,4 @@ function injectDependencies(toBeInjected, dependencies) { return _.mapValues(toBeInjected, _.partial(injectDefaults, dependencies)); } -module.exports = { injectDependencies, injectDefaults }; +export { injectDependencies, injectDefaults }; diff --git a/api/lib/infrastructure/utils/filter-utils.js b/api/lib/infrastructure/utils/filter-utils.js index ec7627e1e6f..eb3c5b601bf 100644 --- a/api/lib/infrastructure/utils/filter-utils.js +++ b/api/lib/infrastructure/utils/filter-utils.js @@ -1,16 +1,17 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; const DISTANCE = 0.8; -module.exports = { - filterByFullName(queryBuilder, search, firstName, lastName) { - const searchLowerCase = search.trim().toLowerCase(); - queryBuilder.where(function () { - //the search is performed by pg_search which uses the distances between the pattern and the data - //if the distance is too large then pg-search won't find anything - //this is why the others where are used - this.where(knex.raw(`CONCAT (??, ' ', ??) <-> ?`, [firstName, lastName, searchLowerCase]), '<=', DISTANCE); - this.orWhereRaw('LOWER(??) LIKE ?', [firstName, `%${searchLowerCase}%`]); - this.orWhereRaw('LOWER(??) LIKE ?', [lastName, `%${searchLowerCase}%`]); - }); - }, + +const filterByFullName = function (queryBuilder, search, firstName, lastName) { + const searchLowerCase = search.trim().toLowerCase(); + queryBuilder.where(function () { + //the search is performed by pg_search which uses the distances between the pattern and the data + //if the distance is too large then pg-search won't find anything + //this is why the others where are used + this.where(knex.raw(`CONCAT (??, ' ', ??) <-> ?`, [firstName, lastName, searchLowerCase]), '<=', DISTANCE); + this.orWhereRaw('LOWER(??) LIKE ?', [firstName, `%${searchLowerCase}%`]); + this.orWhereRaw('LOWER(??) LIKE ?', [lastName, `%${searchLowerCase}%`]); + }); }; + +export { filterByFullName }; diff --git a/api/lib/infrastructure/utils/knex-utils.js b/api/lib/infrastructure/utils/knex-utils.js index 5da4bf02e86..8be380e7cfe 100644 --- a/api/lib/infrastructure/utils/knex-utils.js +++ b/api/lib/infrastructure/utils/knex-utils.js @@ -1,4 +1,4 @@ -const { knex } = require('../../../db/knex-database-connection.js'); +import { knex } from '../../../db/knex-database-connection.js'; const DEFAULT_PAGINATION = { PAGE: 1, @@ -57,7 +57,7 @@ function getChunkSizeForParameterBinding(objectAboutToBeBinded) { return MAX_BINDED_PARAMS_PG; } -module.exports = { +export { fetchPage, isUniqConstraintViolated, foreignKeyConstraintViolated, diff --git a/api/lib/infrastructure/utils/lodash-utils.js b/api/lib/infrastructure/utils/lodash-utils.js index ce943a2265a..63ca13e0e6a 100644 --- a/api/lib/infrastructure/utils/lodash-utils.js +++ b/api/lib/infrastructure/utils/lodash-utils.js @@ -1,4 +1,5 @@ -const { runInContext } = require('lodash'); +import pkg from 'lodash'; +const { runInContext } = pkg; const _ = runInContext(); _.mixin({ /* @@ -72,4 +73,4 @@ _.mixin({ }, }); -module.exports = _; +export { _ }; diff --git a/api/lib/infrastructure/utils/ods/added-cell-option.js b/api/lib/infrastructure/utils/ods/added-cell-option.js index bd4f7bf5878..58e2c1600b4 100644 --- a/api/lib/infrastructure/utils/ods/added-cell-option.js +++ b/api/lib/infrastructure/utils/ods/added-cell-option.js @@ -1,8 +1,10 @@ -module.exports = class AddedCellOption { +class AddedCellOption { constructor({ labels = [], rowspan = 0, colspan = 0, positionOffset = 0 }) { this.labels = labels; this.rowspan = rowspan; this.colspan = colspan; this.positionOffset = positionOffset; } -}; +} + +export { AddedCellOption }; diff --git a/api/lib/infrastructure/utils/ods/common-ods-utils.js b/api/lib/infrastructure/utils/ods/common-ods-utils.js index a2e9fe890f5..8c862fe36e5 100644 --- a/api/lib/infrastructure/utils/ods/common-ods-utils.js +++ b/api/lib/infrastructure/utils/ods/common-ods-utils.js @@ -1,5 +1,5 @@ -const JSZip = require('jszip'); -const fs = require('fs').promises; +import JSZip from 'jszip'; +import * as fs from 'fs/promises'; async function loadOdsZip(odsFilePath) { const odsFileData = await _openOdsFile(odsFilePath); @@ -11,6 +11,4 @@ function _openOdsFile(odsFilePath) { return fs.readFile(odsFilePath); } -module.exports = { - loadOdsZip, -}; +export { loadOdsZip }; diff --git a/api/lib/infrastructure/utils/ods/read-ods-utils.js b/api/lib/infrastructure/utils/ods/read-ods-utils.js index 0360c985521..bfc546b4b87 100644 --- a/api/lib/infrastructure/utils/ods/read-ods-utils.js +++ b/api/lib/infrastructure/utils/ods/read-ods-utils.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const XLSX = require('xlsx'); +import _ from 'lodash'; +import XLSX from 'xlsx'; -const { UnprocessableEntityError } = require('../../../application/http-errors.js'); -const { loadOdsZip } = require('./common-ods-utils.js'); +import { UnprocessableEntityError } from '../../../application/http-errors.js'; +import { loadOdsZip } from './common-ods-utils.js'; const CONTENT_XML_IN_ODS = 'content.xml'; @@ -122,9 +122,4 @@ function _transformSheetDataRow(sheetDataRow, sheetHeaderPropertyMap) { ); } -module.exports = { - extractTableDataFromOdsFile, - getContentXml, - getSheetDataRowsFromOdsBuffer, - validateOdsHeaders, -}; +export { extractTableDataFromOdsFile, getContentXml, getSheetDataRowsFromOdsBuffer, validateOdsHeaders }; diff --git a/api/lib/infrastructure/utils/ods/write-ods-utils.js b/api/lib/infrastructure/utils/ods/write-ods-utils.js index c64d1d68be4..fa7af55e6bd 100644 --- a/api/lib/infrastructure/utils/ods/write-ods-utils.js +++ b/api/lib/infrastructure/utils/ods/write-ods-utils.js @@ -1,7 +1,11 @@ -const { loadOdsZip } = require('./common-ods-utils.js'); -const { DOMParser, XMLSerializer } = require('@xmldom/xmldom'); -const _ = require('lodash'); -const AddedCellOption = require('./added-cell-option.js'); +import { loadOdsZip } from './common-ods-utils.js'; + +import xmldom from '@xmldom/xmldom'; + +const { DOMParser, XMLSerializer } = xmldom; + +import _ from 'lodash'; +import { AddedCellOption } from './added-cell-option.js'; const CONTENT_XML_IN_ODS = 'content.xml'; @@ -496,7 +500,7 @@ function _translateNoteBackgroundTitle(targetXmlDomElement, translate) { } } -module.exports = { +export { makeUpdatedOdsByContentXml, updateXmlSparseValues, updateXmlRows, diff --git a/api/lib/infrastructure/utils/paginate.js b/api/lib/infrastructure/utils/paginate.js index bd648cf03ec..f855390a6d7 100644 --- a/api/lib/infrastructure/utils/paginate.js +++ b/api/lib/infrastructure/utils/paginate.js @@ -17,4 +17,4 @@ function paginate(data, { number = DEFAULT_PAGINATION.PAGE, size = DEFAULT_PAGIN }; } -module.exports = { paginate }; +export { paginate }; diff --git a/api/lib/infrastructure/utils/pdf/AttestationViewModel.js b/api/lib/infrastructure/utils/pdf/AttestationViewModel.js index 7f75abc42df..fd155851a0d 100644 --- a/api/lib/infrastructure/utils/pdf/AttestationViewModel.js +++ b/api/lib/infrastructure/utils/pdf/AttestationViewModel.js @@ -1,6 +1,9 @@ -const sortBy = require('lodash/sortBy'); -const moment = require('moment'); -const { toArrayOfFixedLengthStringsConservingWords } = require('../string-utils.js'); +import lodash from 'lodash'; + +const { sortBy } = lodash; + +import moment from 'moment'; +import { toArrayOfFixedLengthStringsConservingWords } from '../string-utils.js'; const PROFESSIONALIZING_VALIDITY_START_DATE = new Date('2022-01-01'); @@ -135,4 +138,4 @@ function _formatDate(date) { return moment(date).locale('fr').format('LL'); } -module.exports = AttestationViewModel; +export { AttestationViewModel }; diff --git a/api/lib/infrastructure/utils/pdf/certification-attestation-pdf.js b/api/lib/infrastructure/utils/pdf/certification-attestation-pdf.js index e03ca1a783b..e08f8277484 100644 --- a/api/lib/infrastructure/utils/pdf/certification-attestation-pdf.js +++ b/api/lib/infrastructure/utils/pdf/certification-attestation-pdf.js @@ -1,15 +1,17 @@ -const { PDFDocument, rgb } = require('pdf-lib'); -const { readFile } = require('fs/promises'); -const pdfLibFontkit = require('@pdf-lib/fontkit'); -const moment = require('moment'); -const _ = require('lodash'); -const bluebird = require('bluebird'); -// eslint-disable-next-line no-restricted-modules -const axios = require('axios'); - -const AttestationViewModel = require('./AttestationViewModel.js'); -const { CertificationAttestationGenerationError } = require('../../../domain/errors.js'); +import { PDFDocument, rgb } from 'pdf-lib'; +import { readFile } from 'fs/promises'; +import pdfLibFontkit from '@pdf-lib/fontkit'; +import moment from 'moment'; +import _ from 'lodash'; +import bluebird from 'bluebird'; +import axios from 'axios'; +import * as url from 'url'; + +import { AttestationViewModel } from './AttestationViewModel.js'; +import { CertificationAttestationGenerationError } from '../../../domain/errors.js'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); const fonts = { openSansBold: 'OpenSans-Bold.ttf', openSansSemiBold: 'OpenSans-SemiBold.ttf', @@ -359,6 +361,5 @@ async function _finalizeDocument(pdfDocument) { return buffer; } -module.exports = { - getCertificationAttestationsPdfBuffer, -}; +const getCertificationAttestationsPdf = { getCertificationAttestationsPdfBuffer }; +export { getCertificationAttestationsPdfBuffer, getCertificationAttestationsPdf }; diff --git a/api/lib/infrastructure/utils/pdf/supervisor-kit-pdf.js b/api/lib/infrastructure/utils/pdf/supervisor-kit-pdf.js index d073afb6852..0701c8d45a1 100644 --- a/api/lib/infrastructure/utils/pdf/supervisor-kit-pdf.js +++ b/api/lib/infrastructure/utils/pdf/supervisor-kit-pdf.js @@ -1,6 +1,12 @@ -const { PDFDocument, rgb } = require('pdf-lib'); -const { readFile } = require('fs/promises'); -const pdfLibFontkit = require('@pdf-lib/fontkit'); +import { readFile } from 'fs/promises'; + +import { PDFDocument, rgb } from 'pdf-lib'; + +import pdfLibFontkit from '@pdf-lib/fontkit'; +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); + const MAX_SESSION_DETAIL_WIDTH = 155; const SESSION_DETAIL_FONT_SIZE = 7; const SESSION_DETAIL_LINE_HEIGHT = 8; @@ -175,6 +181,4 @@ function _toArrayOfFixedWidthConservingWords(str, font, maxWidth) { return result.map((str) => str.trim()); } -module.exports = { - getSupervisorKitPdfBuffer, -}; +export { getSupervisorKitPdfBuffer }; diff --git a/api/lib/infrastructure/utils/progression-logger.js b/api/lib/infrastructure/utils/progression-logger.js index 563046448f0..7271e44ed42 100644 --- a/api/lib/infrastructure/utils/progression-logger.js +++ b/api/lib/infrastructure/utils/progression-logger.js @@ -20,4 +20,4 @@ class ProgressionLogger { } } -module.exports = ProgressionLogger; +export { ProgressionLogger }; diff --git a/api/lib/infrastructure/utils/pseudo-random.js b/api/lib/infrastructure/utils/pseudo-random.js index fb29c0262ee..4242091c1ca 100644 --- a/api/lib/infrastructure/utils/pseudo-random.js +++ b/api/lib/infrastructure/utils/pseudo-random.js @@ -1,4 +1,4 @@ -const hashInt = require('hash-int'); +import hashInt from 'hash-int'; class PseudoRandom { constructor(initialSeed) { @@ -31,8 +31,8 @@ class PseudoRandom { } } -module.exports = { - create: (seed) => { - return new PseudoRandom(seed); - }, +const create = (seed) => { + return new PseudoRandom(seed); }; + +export { create }; diff --git a/api/lib/infrastructure/utils/query-params-utils.js b/api/lib/infrastructure/utils/query-params-utils.js index cc39214200a..157f0b7a2e7 100644 --- a/api/lib/infrastructure/utils/query-params-utils.js +++ b/api/lib/infrastructure/utils/query-params-utils.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); +import _ from 'lodash'; -module.exports = { extractParameters }; +export { extractParameters }; // query example: 'filter[organizationId]=4&page[size]=30$page[number]=3&sort=createdAt[desc]&include=user' // Warning: there is not any order between sort parameters diff --git a/api/lib/infrastructure/utils/redis-monitor.js b/api/lib/infrastructure/utils/redis-monitor.js index 5b3d2e4e5cf..719930dfc00 100644 --- a/api/lib/infrastructure/utils/redis-monitor.js +++ b/api/lib/infrastructure/utils/redis-monitor.js @@ -1,10 +1,10 @@ -const settings = require('../../config.js'); -const RedisClient = require('./RedisClient.js'); +import { config } from '../../config.js'; +import { RedisClient } from './RedisClient.js'; class RedisMonitor { constructor() { - if (settings.caching.redisUrl) { - this._client = new RedisClient(settings.caching.redisUrl, { name: 'redis-monitor' }); + if (config.caching.redisUrl) { + this._client = new RedisClient(config.caching.redisUrl, { name: 'redis-monitor' }); } } @@ -22,4 +22,4 @@ class RedisMonitor { const redisMonitor = new RedisMonitor(); -module.exports = { redisMonitor }; +export { redisMonitor }; diff --git a/api/lib/infrastructure/utils/request-response-utils.js b/api/lib/infrastructure/utils/request-response-utils.js index 31c5146d6e2..05d0ef30ffc 100644 --- a/api/lib/infrastructure/utils/request-response-utils.js +++ b/api/lib/infrastructure/utils/request-response-utils.js @@ -1,8 +1,10 @@ -const accept = require('@hapi/accept'); -const tokenService = require('../../domain/services/token-service.js'); -const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = require('../../domain/constants.js').LOCALE; +import accept from '@hapi/accept'; +import { tokenService } from '../../domain/services/token-service.js'; +import { LOCALE } from '../../domain/constants.js'; -module.exports = { escapeFileName, extractUserIdFromRequest, extractLocaleFromRequest }; +const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = LOCALE; + +export { escapeFileName, extractUserIdFromRequest, extractLocaleFromRequest }; function escapeFileName(fileName) { return fileName.replace(/[^_. A-Za-z0-9-]/g, '_'); diff --git a/api/lib/infrastructure/utils/string-utils.js b/api/lib/infrastructure/utils/string-utils.js index d0ed0c84baf..ad82353816e 100644 --- a/api/lib/infrastructure/utils/string-utils.js +++ b/api/lib/infrastructure/utils/string-utils.js @@ -1,4 +1,4 @@ -const _ = require('../../infrastructure/utils/lodash-utils.js'); +import { _ } from '../../infrastructure/utils/lodash-utils.js'; function getArrayOfStrings(commaSeparatedStrings) { if (!commaSeparatedStrings) return []; @@ -66,7 +66,7 @@ function toArrayOfFixedLengthStringsConservingWords(str, maxLength) { return result.map((str) => str.trim()); } -module.exports = { +export { isNumeric, splitIntoWordsAndRemoveBackspaces, cleanStringAndParseFloat, diff --git a/api/lib/infrastructure/utils/url-builder.js b/api/lib/infrastructure/utils/url-builder.js index 5d8a1b84609..6e7a07b7249 100644 --- a/api/lib/infrastructure/utils/url-builder.js +++ b/api/lib/infrastructure/utils/url-builder.js @@ -1,16 +1,16 @@ -const settings = require('../../config.js'); +import { config } from '../../config.js'; -module.exports = { getCampaignUrl }; +export { getCampaignUrl }; function getCampaignUrl(locale, campaignCode) { if (!campaignCode) { return null; } if (locale === 'fr') { - return `${settings.domain.pixApp + settings.domain.tldOrg}/campagnes/${campaignCode}/?lang=fr`; + return `${config.domain.pixApp + config.domain.tldOrg}/campagnes/${campaignCode}/?lang=fr`; } if (locale === 'en') { - return `${settings.domain.pixApp + settings.domain.tldOrg}/campagnes/${campaignCode}/?lang=en`; + return `${config.domain.pixApp + config.domain.tldOrg}/campagnes/${campaignCode}/?lang=en`; } - return `${settings.domain.pixApp + settings.domain.tldFr}/campagnes/${campaignCode}`; + return `${config.domain.pixApp + config.domain.tldFr}/campagnes/${campaignCode}`; } diff --git a/api/lib/infrastructure/utils/xml/siecle-file-streamer.js b/api/lib/infrastructure/utils/xml/siecle-file-streamer.js index 50ad1c2f193..72b058486e7 100644 --- a/api/lib/infrastructure/utils/xml/siecle-file-streamer.js +++ b/api/lib/infrastructure/utils/xml/siecle-file-streamer.js @@ -1,17 +1,24 @@ -const { isObject, values } = require('lodash'); -const { FileValidationError, SiecleXmlImportError } = require('../../../domain/errors.js'); -const { logErrorWithCorrelationIds } = require('../../monitoring-tools.js'); -const fs = require('fs'); +import _ from 'lodash'; + +const { isObject, values } = _; +import { FileValidationError, SiecleXmlImportError } from '../../../domain/errors.js'; +import { logErrorWithCorrelationIds } from '../../monitoring-tools.js'; +import fs from 'fs'; + const fsPromises = fs.promises; -const Path = require('path'); -const os = require('os'); -const { Buffer } = require('buffer'); -const StreamZip = require('node-stream-zip'); -const FileType = require('file-type'); -const iconv = require('iconv-lite'); -const sax = require('sax'); -const xmlEncoding = require('xml-buffer-tostring').xmlEncoding; -const _ = require('lodash'); +import Path from 'path'; +import os from 'os'; +import buffer from 'buffer'; + +const { xmlEncoding } = xmlBufferTostring; + +const { Buffer } = buffer; + +import StreamZip from 'node-stream-zip'; +import FileType from 'file-type'; +import iconv from 'iconv-lite'; +import sax from 'sax'; +import xmlBufferTostring from 'xml-buffer-tostring'; /* https://github.com/1024pix/pix/pull/3470#discussion_r707319744 @@ -69,11 +76,13 @@ async function _isFileZipped(path) { const fileType = await FileType.fromFile(path); return isObject(fileType) && fileType.mime === ZIP; } + function _createTempDir() { const tmpDir = os.tmpdir(); const directory = Path.join(tmpDir, 'import-siecle-'); return fsPromises.mkdtemp(directory); } + async function _unzipFile(directory, path) { const extractedFileName = Path.join(directory, 'organization-learners.xml'); const zip = new StreamZip.async({ file: path }); @@ -158,4 +167,4 @@ function getDecodingStream(encoding) { } } -module.exports = SiecleFileStreamer; +export { SiecleFileStreamer }; diff --git a/api/lib/infrastructure/validate-environment-variables.js b/api/lib/infrastructure/validate-environment-variables.js index 9b0d78820d9..06a43b1a113 100644 --- a/api/lib/infrastructure/validate-environment-variables.js +++ b/api/lib/infrastructure/validate-environment-variables.js @@ -1,4 +1,4 @@ -const Joi = require('joi'); +import Joi from 'joi'; const schema = Joi.object({ REDIS_URL: Joi.string().uri().optional(), @@ -65,4 +65,4 @@ const validateEnvironmentVariables = function () { } }; -module.exports = validateEnvironmentVariables; +export { validateEnvironmentVariables }; diff --git a/api/lib/routes.js b/api/lib/routes.js index a5c627a9128..8302bc96262 100644 --- a/api/lib/routes.js +++ b/api/lib/routes.js @@ -1,59 +1,59 @@ -const accountRecovery = require('./application/account-recovery/index.js'); -const adminMembers = require('./application/admin-members/index.js'); -const answers = require('./application/answers/index.js'); -const assessmentResults = require('./application/assessment-results/index.js'); -const assessments = require('./application/assessments/index.js'); -const authentication = require('./application/authentication/index.js'); -const authenticationOidc = require('./application/authentication/oidc/index.js'); -const badges = require('./application/badges/index.js'); -const cache = require('./application/cache/index.js'); -const campaignParticipations = require('./application/campaign-participations/index.js'); -const campaigns = require('./application/campaigns/index.js'); -const campaignsAdministration = require('./application/campaigns-administration/index.js'); -const certificationCandidates = require('./application/certification-candidates/index.js'); -const certificationCenters = require('./application/certification-centers/index.js'); -const certificationCenterInvitations = require('./application/certification-center-invitations/index.js'); -const certificationCenterMemberships = require('./application/certification-center-memberships/index.js'); -const certificationCourses = require('./application/certification-courses/index.js'); -const certificationPointOfContacts = require('./application/certification-point-of-contacts/index.js'); -const certificationLivretScolaire = require('./application/certification-livret-scolaire/index.js'); -const certificationReports = require('./application/certification-reports/index.js'); -const certificationIssueReports = require('./application/certification-issue-reports/index.js'); -const certifications = require('./application/certifications/index.js'); -const challenges = require('./application/challenges/index.js'); -const competenceEvaluations = require('./application/competence-evaluations/index.js'); -const complementaryCertifications = require('./application/complementary-certifications/index.js'); -const complementaryCertificationCourseResults = require('./application/complementary-certification-course-results/index.js'); -const countries = require('./application/countries/index.js'); -const courses = require('./application/courses/index.js'); -const featureToggles = require('./application/feature-toggles/index.js'); -const feedbacks = require('./application/feedbacks/index.js'); -const healthcheck = require('./application/healthcheck/index.js'); -const lcms = require('./application/lcms/index.js'); -const memberships = require('./application/memberships/index.js'); -const organizationInvitations = require('./application/organization-invitations/index.js'); -const organizations = require('./application/organizations/index.js'); -const organizationsAdministration = require('./application/organizations-administration/index.js'); -const passwords = require('./application/passwords/index.js'); -const poleEmploi = require('./application/pole-emploi/index.js'); -const prescribers = require('./application/prescribers/index.js'); -const progressions = require('./application/progressions/index.js'); -const saml = require('./application/saml/index.js'); -const stageCollection = require('./application/stage-collections/index.js'); -const scoringSimulator = require('./application/scoring-simulator/index.js'); -const organizationLearners = require('./application/organization-learners/index.js'); -const scorecards = require('./application/scorecards/index.js'); -const scoOrganizationLearners = require('./application/sco-organization-learners/index.js'); -const supOrganizationLearners = require('./application/sup-organization-learners/index.js'); -const sessions = require('./application/sessions/index.js'); -const tags = require('./application/tags/index.js'); -const targetProfiles = require('./application/target-profiles/index.js'); -const trainings = require('./application/trainings/index.js'); -const frameworks = require('./application/frameworks/index.js'); -const tutorialEvaluations = require('./application/tutorial-evaluations/index.js'); -const userOrgaSettings = require('./application/user-orga-settings/index.js'); -const userTutorials = require('./application/user-tutorials/index.js'); -const users = require('./application/users/index.js'); +import * as accountRecovery from './application/account-recovery/index.js'; +import * as adminMembers from './application/admin-members/index.js'; +import * as answers from './application/answers/index.js'; +import * as assessmentResults from './application/assessment-results/index.js'; +import * as assessments from './application/assessments/index.js'; +import * as authentication from './application/authentication/index.js'; +import * as authenticationOidc from './application/authentication/oidc/index.js'; +import * as badges from './application/badges/index.js'; +import * as cache from './application/cache/index.js'; +import * as campaignParticipations from './application/campaign-participations/index.js'; +import * as campaigns from './application/campaigns/index.js'; +import * as campaignsAdministration from './application/campaigns-administration/index.js'; +import * as certificationCandidates from './application/certification-candidates/index.js'; +import * as certificationCenters from './application/certification-centers/index.js'; +import * as certificationCenterInvitations from './application/certification-center-invitations/index.js'; +import * as certificationCenterMemberships from './application/certification-center-memberships/index.js'; +import * as certificationCourses from './application/certification-courses/index.js'; +import * as certificationPointOfContacts from './application/certification-point-of-contacts/index.js'; +import * as certificationLivretScolaire from './application/certification-livret-scolaire/index.js'; +import * as certificationReports from './application/certification-reports/index.js'; +import * as certificationIssueReports from './application/certification-issue-reports/index.js'; +import * as certifications from './application/certifications/index.js'; +import * as challenges from './application/challenges/index.js'; +import * as competenceEvaluations from './application/competence-evaluations/index.js'; +import * as complementaryCertifications from './application/complementary-certifications/index.js'; +import * as complementaryCertificationCourseResults from './application/complementary-certification-course-results/index.js'; +import * as countries from './application/countries/index.js'; +import * as courses from './application/courses/index.js'; +import * as featureToggles from './application/feature-toggles/index.js'; +import * as feedbacks from './application/feedbacks/index.js'; +import * as healthcheck from './application/healthcheck/index.js'; +import * as lcms from './application/lcms/index.js'; +import * as memberships from './application/memberships/index.js'; +import * as organizationInvitations from './application/organization-invitations/index.js'; +import * as organizations from './application/organizations/index.js'; +import * as organizationsAdministration from './application/organizations-administration/index.js'; +import * as passwords from './application/passwords/index.js'; +import * as poleEmploi from './application/pole-emploi/index.js'; +import * as prescribers from './application/prescribers/index.js'; +import * as progressions from './application/progressions/index.js'; +import * as saml from './application/saml/index.js'; +import * as stageCollection from './application/stage-collections/index.js'; +import * as scoringSimulator from './application/scoring-simulator/index.js'; +import * as organizationLearners from './application/organization-learners/index.js'; +import * as scorecards from './application/scorecards/index.js'; +import * as scoOrganizationLearners from './application/sco-organization-learners/index.js'; +import * as supOrganizationLearners from './application/sup-organization-learners/index.js'; +import * as sessions from './application/sessions/index.js'; +import * as tags from './application/tags/index.js'; +import * as targetProfiles from './application/target-profiles/index.js'; +import * as trainings from './application/trainings/index.js'; +import * as frameworks from './application/frameworks/index.js'; +import * as tutorialEvaluations from './application/tutorial-evaluations/index.js'; +import * as userOrgaSettings from './application/user-orga-settings/index.js'; +import * as userTutorials from './application/user-tutorials/index.js'; +import * as users from './application/users/index.js'; const routes = [ accountRecovery, @@ -114,4 +114,4 @@ const routes = [ users, ]; -module.exports = { routes }; +export { routes }; diff --git a/api/lib/swaggers.js b/api/lib/swaggers.js index cfdf54649c3..05ef2808a2c 100644 --- a/api/lib/swaggers.js +++ b/api/lib/swaggers.js @@ -1,5 +1,5 @@ -const HapiSwagger = require('hapi-swagger'); -const packageJSON = require('../package.json'); +import HapiSwagger from 'hapi-swagger'; +import packageJSON from '../package.json' assert { type: 'json' }; const swaggerOptionsAuthorizationServer = { routeTag: 'authorization-server', @@ -59,4 +59,4 @@ const swaggers = [ swaggerOptionsIn, ].map(_buildSwaggerArgs); -module.exports = swaggers; +export { swaggers }; diff --git a/api/lib/validate.js b/api/lib/validate.js index 047f03b2264..b6df0fc2892 100644 --- a/api/lib/validate.js +++ b/api/lib/validate.js @@ -1,11 +1,12 @@ -const get = require('lodash/get'); -const { BadRequestError, sendJsonApiError } = require('./application/http-errors.js'); +import lodash from 'lodash'; + +const { get } = lodash; + +import { BadRequestError, sendJsonApiError } from './application/http-errors.js'; function handleFailAction(request, h, err) { const message = get(err, 'details[0].message', ''); return sendJsonApiError(new BadRequestError(message), h); } -module.exports = { - handleFailAction, -}; +export { handleFailAction }; diff --git a/api/package-lock.json b/api/package-lock.json index 22ba6e39a3d..fcb2928fcc7 100644 --- a/api/package-lock.json +++ b/api/package-lock.json @@ -25,7 +25,6 @@ "bcrypt": "^5.0.1", "bluebird": "^3.7.2", "bookshelf": "^1.2.0", - "bookshelf-json-columns": "^3.0.0", "bookshelf-validate": "^2.0.3", "cron-parser": "^4.6.0", "dayjs": "^1.11.5", @@ -83,6 +82,7 @@ }, "devDependencies": { "@babel/eslint-parser": "^7.18.2", + "@babel/plugin-syntax-import-assertions": "^7.20.0", "@ls-lint/ls-lint": "^1.11.2", "chai": "^4.3.6", "chai-as-promised": "^7.1.1", @@ -92,6 +92,7 @@ "eslint-config-prettier": "^8.5.0", "eslint-plugin-chai-expect": "^3.0.0", "eslint-plugin-i18n-json": "^4.0.0", + "eslint-plugin-import": "^2.27.5", "eslint-plugin-knex": "^0.2.1", "eslint-plugin-mocha": "^10.0.5", "eslint-plugin-node": "^11.1.0", @@ -101,7 +102,6 @@ "flush-write-stream": "^2.0.0", "form-data": "^4.0.0", "inquirer": "^8.2.4", - "jscodeshift": "^0.14.0", "mocha": "^10.0.0", "mocha-junit-reporter": "^2.0.2", "mockdate": "^3.0.5", @@ -109,7 +109,6 @@ "nodemon": "^2.0.16", "npm-run-all": "^4.1.5", "prettier": "^2.7.1", - "proxyquire": "^2.1.3", "sinon": "^15.0.0", "sinon-chai": "^3.7.0", "split2": "^4.1.0", @@ -2934,7 +2933,6 @@ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz", "integrity": "sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==", "dev": true, - "peer": true, "dependencies": { "@babel/helper-plugin-utils": "^7.19.0" }, @@ -4857,6 +4855,19 @@ "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", "dev": true }, + "node_modules/@ianvs/eslint-stats": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@ianvs/eslint-stats/-/eslint-stats-2.0.0.tgz", + "integrity": "sha512-DnIVVAiXR4tfWERTiQxr1Prrs/uFEbC1C4gTGORMvbF4k7ENyVQeLcoUfNyhlAj2MB/OeorCrN3wSnYuDOUS6Q==", + "dev": true, + "dependencies": { + "chalk": "^2.4.2", + "lodash": "^4.17.15" + }, + "engines": { + "node": ">=8.0.0" + } + }, "node_modules/@istanbuljs/load-nyc-config": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", @@ -5427,6 +5438,12 @@ "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==" }, + "node_modules/@types/json5": { + "version": "0.0.29", + "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", + "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", + "dev": true + }, "node_modules/@types/mime-db": { "version": "1.43.1", "resolved": "https://registry.npmjs.org/@types/mime-db/-/mime-db-1.43.1.tgz", @@ -5762,6 +5779,19 @@ "node": ">=6" } }, + "node_modules/array-buffer-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", + "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "is-array-buffer": "^3.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/array-differ": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/array-differ/-/array-differ-3.0.0.tgz", @@ -5771,6 +5801,25 @@ "node": ">=8" } }, + "node_modules/array-includes": { + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.6.tgz", + "integrity": "sha512-sgTbLvL6cNnw24FnbaDyjmvddQ2ML8arZsgaJhoABMoplz/4QRhtrYS+alr1BUM1Bwp6dhx8vVCBSLG+StwOFw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "get-intrinsic": "^1.1.3", + "is-string": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/array-union": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", @@ -5788,6 +5837,42 @@ "node": ">=0.10.0" } }, + "node_modules/array.prototype.flat": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.1.tgz", + "integrity": "sha512-roTU0KWIOmJ4DRLmwKd19Otg0/mT3qPNt0Qb3GWW8iObuZXxrjB/pzn0R3hqpRSWg4HCwqx+0vwOnWnvlOyeIA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flatmap": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.1.tgz", + "integrity": "sha512-8UGn9O1FDVvMNB0UlLv4voxRMze7+FpHyF5mSMRjWHUMlpoDViniy05870VlxhfgTnLbpuwTzvD76MTtWxB/mQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/arrify": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/arrify/-/arrify-2.0.1.tgz", @@ -5871,6 +5956,18 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/available-typed-arrays": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", + "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/aws-sign2": { "version": "0.7.0", "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", @@ -6944,15 +7041,19 @@ } }, "node_modules/define-properties": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", - "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.0.tgz", + "integrity": "sha512-xvqAVKGfT1+UAvPwKTVw/njhdQ8ZhXK4lI0bCIuCMrp2up9nPnaDftrLtmpTazqd1o+UY4zgzU+avtMbDP+ldA==", "dev": true, "dependencies": { - "object-keys": "^1.0.12" + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" }, "engines": { "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" } }, "node_modules/delay": { @@ -7259,31 +7360,45 @@ } }, "node_modules/es-abstract": { - "version": "1.19.1", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.19.1.tgz", - "integrity": "sha512-2vJ6tjA/UfqLm2MPs7jxVybLoB8i1t1Jd9R3kISld20sIxPcTbLuggQOUxeWeAvIUkduv/CfMjuh4WmiXr2v9w==", + "version": "1.21.2", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.21.2.tgz", + "integrity": "sha512-y/B5POM2iBnIxCiernH1G7rC9qQoM77lLIMQLuob0zhp8C56Po81+2Nj0WFKnd0pNReDTnkYryc+zhOzpEIROg==", "dev": true, "dependencies": { + "array-buffer-byte-length": "^1.0.0", + "available-typed-arrays": "^1.0.5", "call-bind": "^1.0.2", + "es-set-tostringtag": "^2.0.1", "es-to-primitive": "^1.2.1", - "function-bind": "^1.1.1", - "get-intrinsic": "^1.1.1", + "function.prototype.name": "^1.1.5", + "get-intrinsic": "^1.2.0", "get-symbol-description": "^1.0.0", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", "has": "^1.0.3", - "has-symbols": "^1.0.2", - "internal-slot": "^1.0.3", - "is-callable": "^1.2.4", - "is-negative-zero": "^2.0.1", + "has-property-descriptors": "^1.0.0", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.5", + "is-array-buffer": "^3.0.2", + "is-callable": "^1.2.7", + "is-negative-zero": "^2.0.2", "is-regex": "^1.1.4", - "is-shared-array-buffer": "^1.0.1", + "is-shared-array-buffer": "^1.0.2", "is-string": "^1.0.7", - "is-weakref": "^1.0.1", - "object-inspect": "^1.11.0", + "is-typed-array": "^1.1.10", + "is-weakref": "^1.0.2", + "object-inspect": "^1.12.3", "object-keys": "^1.1.1", - "object.assign": "^4.1.2", - "string.prototype.trimend": "^1.0.4", - "string.prototype.trimstart": "^1.0.4", - "unbox-primitive": "^1.0.1" + "object.assign": "^4.1.4", + "regexp.prototype.flags": "^1.4.3", + "safe-regex-test": "^1.0.0", + "string.prototype.trim": "^1.2.7", + "string.prototype.trimend": "^1.0.6", + "string.prototype.trimstart": "^1.0.6", + "typed-array-length": "^1.0.4", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.9" }, "engines": { "node": ">= 0.4" @@ -7292,6 +7407,29 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/es-set-tostringtag": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.1.tgz", + "integrity": "sha512-g3OMbtlwY3QewlqAiMLI47KywjWZoEytKr8pf6iTC8uJq5bIAH52Z9pnQ8pVL6whrCto53JZDuUIsifGeLorTg==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.3", + "has": "^1.0.3", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-shim-unscopables": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz", + "integrity": "sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w==", + "dev": true, + "dependencies": { + "has": "^1.0.3" + } + }, "node_modules/es-to-primitive": { "version": "1.2.1", "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", @@ -7486,6 +7624,201 @@ "eslint": ">=7.0.0" } }, + "node_modules/eslint-filtered-fix": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/eslint-filtered-fix/-/eslint-filtered-fix-0.3.0.tgz", + "integrity": "sha512-UMHOza9epEn9T+yVT8RiCFf0JdALpVzmoH62Ez/zvxM540IyUNAkr7aH2Frkv6zlm9a/gbmq/sc7C4SvzZQXcA==", + "dev": true, + "dependencies": { + "optionator": "^0.9.1" + }, + "bin": { + "eslint-filtered-fix": "bin/eslint-filtered-fix.js" + }, + "peerDependencies": { + "eslint": ">=7.0.0" + } + }, + "node_modules/eslint-formatter-friendly": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/eslint-formatter-friendly/-/eslint-formatter-friendly-7.0.0.tgz", + "integrity": "sha512-WXg2D5kMHcRxIZA3ulxdevi8/BGTXu72pfOO5vXHqcAfClfIWDSlOljROjCSOCcKvilgmHz1jDWbvFCZHjMQ5w==", + "dev": true, + "dependencies": { + "@babel/code-frame": "7.0.0", + "chalk": "2.4.2", + "extend": "3.0.2", + "strip-ansi": "5.2.0", + "text-table": "0.2.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-formatter-friendly/node_modules/@babel/code-frame": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", + "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", + "dev": true, + "dependencies": { + "@babel/highlight": "^7.0.0" + } + }, + "node_modules/eslint-formatter-friendly/node_modules/ansi-regex": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", + "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/eslint-formatter-friendly/node_modules/strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "dependencies": { + "ansi-regex": "^4.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/eslint-import-resolver-node": { + "version": "0.3.7", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.7.tgz", + "integrity": "sha512-gozW2blMLJCeFpBwugLTGyvVjNoeo1knonXAcatC6bjPBZitotxdWf7Gimr25N4c0AAOo4eOUfaG82IJPDpqCA==", + "dev": true, + "dependencies": { + "debug": "^3.2.7", + "is-core-module": "^2.11.0", + "resolve": "^1.22.1" + } + }, + "node_modules/eslint-import-resolver-node/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-module-utils": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz", + "integrity": "sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw==", + "dev": true, + "dependencies": { + "debug": "^3.2.7" + }, + "engines": { + "node": ">=4" + }, + "peerDependenciesMeta": { + "eslint": { + "optional": true + } + } + }, + "node_modules/eslint-module-utils/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-nibble": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/eslint-nibble/-/eslint-nibble-8.1.0.tgz", + "integrity": "sha512-x9H/1oeuKdC0HsaWeBarOryqNLC+7QZfAZIAP0HnGcmiiPktFIQq/D0e+iiCSyqYLSaui3UwvH56sXMrf5oQhw==", + "dev": true, + "dependencies": { + "@ianvs/eslint-stats": "^2.0.0", + "chalk": "^4.1.1", + "eslint-filtered-fix": "^0.3.0", + "eslint-formatter-friendly": "^7.0.0", + "eslint-summary": "^1.0.0", + "inquirer": "^8.2.3", + "optionator": "^0.9.1" + }, + "bin": { + "eslint-nibble": "bin/eslint-nibble.js" + }, + "engines": { + "node": ">=12.0.0" + }, + "peerDependencies": { + "eslint": ">=7.0.0" + } + }, + "node_modules/eslint-nibble/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/eslint-nibble/node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/eslint-nibble/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/eslint-nibble/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/eslint-nibble/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/eslint-plugin-chai-expect": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/eslint-plugin-chai-expect/-/eslint-plugin-chai-expect-3.0.0.tgz", @@ -7588,23 +7921,82 @@ "node": ">=4" } }, - "node_modules/eslint-plugin-knex": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-knex/-/eslint-plugin-knex-0.2.1.tgz", - "integrity": "sha512-6D/XCF5Sb3RSFF2VTk74t+8RkHg8abJC7VIdSJqeokxZqkKkr0HsndxSidhVOKFcG1VLqFb5Rq4a3CFOAseicQ==", - "dev": true, - "dependencies": { - "eslint-remote-tester": "^1.1.0" - } - }, - "node_modules/eslint-plugin-mocha": { - "version": "10.0.5", - "resolved": "https://registry.npmjs.org/eslint-plugin-mocha/-/eslint-plugin-mocha-10.0.5.tgz", - "integrity": "sha512-H5xuD5NStlpaKLqUWYC5BsMx8fHgrIYsdloFbONUTc2vgVNiJcWdKoX29Tt0BO75QgAltplPLIziByMozGGixA==", + "node_modules/eslint-plugin-import": { + "version": "2.27.5", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.27.5.tgz", + "integrity": "sha512-LmEt3GVofgiGuiE+ORpnvP+kAm3h6MLZJ4Q5HCyHADofsb4VzXFsRiWj3c0OFiV+3DWFh0qg3v9gcPlfc3zRow==", "dev": true, "dependencies": { - "eslint-utils": "^3.0.0", - "rambda": "^7.1.0" + "array-includes": "^3.1.6", + "array.prototype.flat": "^1.3.1", + "array.prototype.flatmap": "^1.3.1", + "debug": "^3.2.7", + "doctrine": "^2.1.0", + "eslint-import-resolver-node": "^0.3.7", + "eslint-module-utils": "^2.7.4", + "has": "^1.0.3", + "is-core-module": "^2.11.0", + "is-glob": "^4.0.3", + "minimatch": "^3.1.2", + "object.values": "^1.1.6", + "resolve": "^1.22.1", + "semver": "^6.3.0", + "tsconfig-paths": "^3.14.1" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" + } + }, + "node_modules/eslint-plugin-import/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-plugin-import/node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-plugin-import/node_modules/semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/eslint-plugin-knex": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-knex/-/eslint-plugin-knex-0.2.1.tgz", + "integrity": "sha512-6D/XCF5Sb3RSFF2VTk74t+8RkHg8abJC7VIdSJqeokxZqkKkr0HsndxSidhVOKFcG1VLqFb5Rq4a3CFOAseicQ==", + "dev": true, + "dependencies": { + "eslint-remote-tester": "^1.1.0" + } + }, + "node_modules/eslint-plugin-mocha": { + "version": "10.0.5", + "resolved": "https://registry.npmjs.org/eslint-plugin-mocha/-/eslint-plugin-mocha-10.0.5.tgz", + "integrity": "sha512-H5xuD5NStlpaKLqUWYC5BsMx8fHgrIYsdloFbONUTc2vgVNiJcWdKoX29Tt0BO75QgAltplPLIziByMozGGixA==", + "dev": true, + "dependencies": { + "eslint-utils": "^3.0.0", + "rambda": "^7.1.0" }, "engines": { "node": ">=14.0.0" @@ -7872,6 +8264,53 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint-summary": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/eslint-summary/-/eslint-summary-1.0.0.tgz", + "integrity": "sha512-cHr5WiNFhu2guLQykhQV8O7BQcnpFLR6GdLjbQfDDL0yGy9U7dXC6zMUtwoxYgJRC/Wk3yZMc+I6Q15Z7r4j9Q==", + "dev": true, + "dependencies": { + "chalk": "^1.0.0", + "text-table": "^0.2.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-summary/node_modules/ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha512-kmCevFghRiWM7HB5zTPULl4r9bVFSWjz62MhqizDGUrq2NWuNMQyuv4tHHoKJHs69M/MF64lEcHdYIocrdWQYA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-summary/node_modules/chalk": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha512-U3lRVLMSlsCfjqYPbLyVv11M9CPW4I728d6TCKMAOJueEeB9/8o+eSsMnxPJD+Q+K909sdESg7C+tIkoH6on1A==", + "dev": true, + "dependencies": { + "ansi-styles": "^2.2.1", + "escape-string-regexp": "^1.0.2", + "has-ansi": "^2.0.0", + "strip-ansi": "^3.0.0", + "supports-color": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-summary/node_modules/supports-color": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", + "integrity": "sha512-KKNVtd6pCYgPIKU4cp2733HWYCpplQhddZLBUryaAHou723x+FRzQ5Df824Fj+IyyuiQTRoub4SnIFfIcrp70g==", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, "node_modules/eslint-utils": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", @@ -7987,18 +8426,6 @@ "node": ">=10.13.0" } }, - "node_modules/eslint/node_modules/glob-parent/node_modules/is-glob": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", - "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dev": true, - "dependencies": { - "is-extglob": "^2.1.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/eslint/node_modules/globals": { "version": "13.20.0", "resolved": "https://registry.npmjs.org/globals/-/globals-13.20.0.tgz", @@ -8488,6 +8915,15 @@ } } }, + "node_modules/for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.3" + } + }, "node_modules/foreground-child": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", @@ -8588,6 +9024,33 @@ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" }, + "node_modules/function.prototype.name": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.5.tgz", + "integrity": "sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3", + "es-abstract": "^1.19.0", + "functions-have-names": "^1.2.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/gauge": { "version": "2.7.4", "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", @@ -8630,13 +9093,14 @@ } }, "node_modules/get-intrinsic": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", - "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", + "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", "dependencies": { "function-bind": "^1.1.1", "has": "^1.0.3", - "has-symbols": "^1.0.1" + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -8719,6 +9183,33 @@ "node": ">=4" } }, + "node_modules/globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, + "dependencies": { + "define-properties": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/graceful-fs": { "version": "4.2.8", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", @@ -8936,10 +9427,22 @@ "node": ">= 0.4.0" } }, + "node_modules/has-ansi": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", + "integrity": "sha512-C8vBJ8DwUCx19vhm7urhTuUsr4/IyP6l4VzNQDv+ryHQObW3TTTp9yB68WpYgRe2bbaGuZ/se74IqFeVnMnLZg==", + "dev": true, + "dependencies": { + "ansi-regex": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/has-bigints": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", - "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", "dev": true, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -8953,10 +9456,33 @@ "node": ">=4" } }, + "node_modules/has-property-descriptors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", + "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", + "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/has-symbols": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", - "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", "engines": { "node": ">= 0.4" }, @@ -9537,12 +10063,12 @@ } }, "node_modules/internal-slot": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", - "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.5.tgz", + "integrity": "sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ==", "dev": true, "dependencies": { - "get-intrinsic": "^1.1.0", + "get-intrinsic": "^1.2.0", "has": "^1.0.3", "side-channel": "^1.0.4" }, @@ -9576,6 +10102,20 @@ "node": ">=0.10.0" } }, + "node_modules/is-array-buffer": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", + "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.0", + "is-typed-array": "^1.1.10" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", @@ -9644,9 +10184,9 @@ } }, "node_modules/is-callable": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.4.tgz", - "integrity": "sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w==", + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", "dev": true, "engines": { "node": ">= 0.4" @@ -9668,9 +10208,9 @@ } }, "node_modules/is-core-module": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.4.0.tgz", - "integrity": "sha512-6A2fkfq1rfeQZjxrZJGerpLCTHRNEBiSgnu0+obeJpEPZRUooHgsizvzv0ZjJwOz3iWIHdJtVWJ/tmPr3D21/A==", + "version": "2.12.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz", + "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==", "dependencies": { "has": "^1.0.3" }, @@ -9714,9 +10254,9 @@ } }, "node_modules/is-glob": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", - "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", "dev": true, "dependencies": { "is-extglob": "^2.1.1" @@ -9735,9 +10275,9 @@ } }, "node_modules/is-negative-zero": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.1.tgz", - "integrity": "sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w==", + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", + "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", "dev": true, "engines": { "node": ">= 0.4" @@ -9756,9 +10296,9 @@ } }, "node_modules/is-number-object": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.6.tgz", - "integrity": "sha512-bEVOqiRcvo3zO1+G2lVMy+gkkEm9Yh7cDMRusKKu5ZJKPUYSJwICTKZrNKHA2EbSP0Tu0+6B/emsYNHZyn6K8g==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", "dev": true, "dependencies": { "has-tostringtag": "^1.0.0" @@ -9826,10 +10366,13 @@ } }, "node_modules/is-shared-array-buffer": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.1.tgz", - "integrity": "sha512-IU0NmyknYZN0rChcKhRO1X8LYz5Isj/Fsqh8NJOSf+N/hCOTwy29F32Ik7a+QszE63IdvmwdTPDd6cZ5pg4cwA==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", + "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, "funding": { "url": "https://github.com/sponsors/ljharb" } @@ -9876,6 +10419,25 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/is-typed-array": { + "version": "1.1.10", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.10.tgz", + "integrity": "sha512-PJqgEHiWZvMpaFZ3uTc8kHPM4+4ADTlDniuQL7cU/UDA0Ql7F70yGfHph3cLNe+c9toaigv+DFzTJKhc2CtO6A==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/is-typedarray": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", @@ -9894,12 +10456,12 @@ } }, "node_modules/is-weakref": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.1.tgz", - "integrity": "sha512-b2jKc2pQZjaeFYWEf7ScFj+Be1I+PXmlu572Q8coTXZ+LD/QQZ7ShPMst8h16riVgyXTQwUsFEl74mDvc/3MHQ==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.0" + "call-bind": "^1.0.2" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -12051,9 +12613,9 @@ } }, "node_modules/object-inspect": { - "version": "1.11.0", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.11.0.tgz", - "integrity": "sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg==", + "version": "1.12.3", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", + "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", "funding": { "url": "https://github.com/sponsors/ljharb" } @@ -12068,14 +12630,14 @@ } }, "node_modules/object.assign": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", - "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", + "version": "4.1.4", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", + "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.0", - "define-properties": "^1.1.3", - "has-symbols": "^1.0.1", + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "has-symbols": "^1.0.3", "object-keys": "^1.1.1" }, "engines": { @@ -12085,6 +12647,23 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/object.values": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.6.tgz", + "integrity": "sha512-FVVTkD1vENCsAcwNs9k6jea2uHC/X0+JcjG8YA60FN5CMaJmG95wT9jek/xX9nornqGRrBkKtzuAu2wuHpKqvw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/on-exit-leak-free": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/on-exit-leak-free/-/on-exit-leak-free-2.1.0.tgz", @@ -13595,6 +14174,23 @@ "regexp-tree": "bin/regexp-tree" } }, + "node_modules/regexp.prototype.flags": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz", + "integrity": "sha512-0SutC3pNudRKgquxGoRGIz946MZVHqbNfPjBdxeOhBrdgDKlRoXmYLQN9xRbrR09ZXWeGAdPuif7egofn6v5LA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "functions-have-names": "^1.2.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/regexpp": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", @@ -13790,12 +14386,16 @@ "dev": true }, "node_modules/resolve": { - "version": "1.20.0", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", - "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", + "version": "1.22.2", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", + "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", "dependencies": { - "is-core-module": "^2.2.0", - "path-parse": "^1.0.6" + "is-core-module": "^2.11.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -13913,6 +14513,20 @@ "regexp-tree": "~0.1.1" } }, + "node_modules/safe-regex-test": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.0.tgz", + "integrity": "sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.1.3", + "is-regex": "^1.1.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/safe-stable-stringify": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/safe-stable-stringify/-/safe-stable-stringify-2.3.1.tgz", @@ -14661,33 +15275,52 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/string.prototype.trimend": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", - "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", + "node_modules/string.prototype.trim": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.7.tgz", + "integrity": "sha512-p6TmeT1T3411M8Cgg9wBTMRtY2q9+PNy9EV1i2lIXUN/btt763oIfxwN3RR8VU6wHX8j/1CFy0L+YuThm6bgOg==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.3" + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/string.prototype.trimstart": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", - "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", + "node_modules/string.prototype.trimend": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz", + "integrity": "sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "define-properties": "^1.1.3" + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/strip-ansi": { + "node_modules/string.prototype.trimstart": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz", + "integrity": "sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/strip-ansi": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", @@ -14799,6 +15432,17 @@ "node": ">=4" } }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/swagger-parser": { "version": "10.0.3", "resolved": "https://registry.npmjs.org/swagger-parser/-/swagger-parser-10.0.3.tgz", @@ -15022,6 +15666,30 @@ "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", "integrity": "sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=" }, + "node_modules/tsconfig-paths": { + "version": "3.14.2", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.14.2.tgz", + "integrity": "sha512-o/9iXgCYc5L/JxCHPe3Hvh8Q/2xm5Z+p18PESBU6Ff33695QnCHBEjcytY2q19ua7Mbl/DavtBOLq+oG0RCL+g==", + "dev": true, + "dependencies": { + "@types/json5": "^0.0.29", + "json5": "^1.0.2", + "minimist": "^1.2.6", + "strip-bom": "^3.0.0" + } + }, + "node_modules/tsconfig-paths/node_modules/json5": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", + "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", + "dev": true, + "dependencies": { + "minimist": "^1.2.0" + }, + "bin": { + "json5": "lib/cli.js" + } + }, "node_modules/tslib": { "version": "1.14.1", "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", @@ -15075,6 +15743,20 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/typed-array-length": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", + "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "is-typed-array": "^1.1.9" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/typedarray-to-buffer": { "version": "3.1.5", "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", @@ -15097,14 +15779,14 @@ } }, "node_modules/unbox-primitive": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", - "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", "dev": true, "dependencies": { - "function-bind": "^1.1.1", - "has-bigints": "^1.0.1", - "has-symbols": "^1.0.2", + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", "which-boxed-primitive": "^1.0.2" }, "funding": { @@ -15307,6 +15989,26 @@ "integrity": "sha512-B+enWhmw6cjfVC7kS8Pj9pCrKSc5txArRyaYGe088shv/FGWH+0Rjx/xPgtsWfsUtS27FkP697E4DDhgrgoc0Q==", "optional": true }, + "node_modules/which-typed-array": { + "version": "1.1.9", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.9.tgz", + "integrity": "sha512-w9c4xkx6mPidwp7180ckYWfMmvxpjlZuIudNtDf4N/tTAUB8VJbX25qZoAsrtGuYNnGw3pa0AXgbGKRB8/EceA==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/wide-align": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", @@ -18240,7 +18942,6 @@ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz", "integrity": "sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==", "dev": true, - "peer": true, "requires": { "@babel/helper-plugin-utils": "^7.19.0" } @@ -19828,6 +20529,16 @@ "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", "dev": true }, + "@ianvs/eslint-stats": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@ianvs/eslint-stats/-/eslint-stats-2.0.0.tgz", + "integrity": "sha512-DnIVVAiXR4tfWERTiQxr1Prrs/uFEbC1C4gTGORMvbF4k7ENyVQeLcoUfNyhlAj2MB/OeorCrN3wSnYuDOUS6Q==", + "dev": true, + "requires": { + "chalk": "^2.4.2", + "lodash": "^4.17.15" + } + }, "@istanbuljs/load-nyc-config": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", @@ -20305,6 +21016,12 @@ "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==" }, + "@types/json5": { + "version": "0.0.29", + "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", + "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", + "dev": true + }, "@types/mime-db": { "version": "1.43.1", "resolved": "https://registry.npmjs.org/@types/mime-db/-/mime-db-1.43.1.tgz", @@ -20587,12 +21304,35 @@ } } }, + "array-buffer-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", + "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "is-array-buffer": "^3.0.1" + } + }, "array-differ": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/array-differ/-/array-differ-3.0.0.tgz", "integrity": "sha512-THtfYS6KtME/yIAhKjZ2ul7XI96lQGHRputJQHO80LAWQnuGP4iCIN8vdMRboGbIEYBwU33q8Tch1os2+X0kMg==", "dev": true }, + "array-includes": { + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.6.tgz", + "integrity": "sha512-sgTbLvL6cNnw24FnbaDyjmvddQ2ML8arZsgaJhoABMoplz/4QRhtrYS+alr1BUM1Bwp6dhx8vVCBSLG+StwOFw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "get-intrinsic": "^1.1.3", + "is-string": "^1.0.7" + } + }, "array-union": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", @@ -20604,6 +21344,30 @@ "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.2.tgz", "integrity": "sha1-X8w3OSB3VyPP1k1lxkvvU7+eum0=" }, + "array.prototype.flat": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.1.tgz", + "integrity": "sha512-roTU0KWIOmJ4DRLmwKd19Otg0/mT3qPNt0Qb3GWW8iObuZXxrjB/pzn0R3hqpRSWg4HCwqx+0vwOnWnvlOyeIA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "es-shim-unscopables": "^1.0.0" + } + }, + "array.prototype.flatmap": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.1.tgz", + "integrity": "sha512-8UGn9O1FDVvMNB0UlLv4voxRMze7+FpHyF5mSMRjWHUMlpoDViniy05870VlxhfgTnLbpuwTzvD76MTtWxB/mQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "es-shim-unscopables": "^1.0.0" + } + }, "arrify": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/arrify/-/arrify-2.0.1.tgz", @@ -20665,6 +21429,12 @@ "integrity": "sha512-Hdw8qdNiqdJ8LqT0iK0sVzkFbzg6fhnQqqfWhBDxcHZvU75+B+ayzTy8x+k5Ix0Y92XOhOUlx74ps+bA6BeYMQ==", "dev": true }, + "available-typed-arrays": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", + "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", + "dev": true + }, "aws-sign2": { "version": "0.7.0", "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", @@ -20822,8 +21592,7 @@ } }, "bookshelf-json-columns": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/bookshelf-json-columns/-/bookshelf-json-columns-3.0.0.tgz", + "version": "https://registry.npmjs.org/bookshelf-json-columns/-/bookshelf-json-columns-3.0.0.tgz", "integrity": "sha512-oLJ4P7DxgrERLjxCfQQxTa5KJ8CREr9aRXc7ejtomkl+DZvr5JD0OxQnvoGNA0/BBSEli5tbYtBVA5mSwjTYGw==", "requires": {} }, @@ -21455,12 +22224,13 @@ } }, "define-properties": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", - "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.0.tgz", + "integrity": "sha512-xvqAVKGfT1+UAvPwKTVw/njhdQ8ZhXK4lI0bCIuCMrp2up9nPnaDftrLtmpTazqd1o+UY4zgzU+avtMbDP+ldA==", "dev": true, "requires": { - "object-keys": "^1.0.12" + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" } }, "delay": { @@ -21700,31 +22470,65 @@ } }, "es-abstract": { - "version": "1.19.1", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.19.1.tgz", - "integrity": "sha512-2vJ6tjA/UfqLm2MPs7jxVybLoB8i1t1Jd9R3kISld20sIxPcTbLuggQOUxeWeAvIUkduv/CfMjuh4WmiXr2v9w==", + "version": "1.21.2", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.21.2.tgz", + "integrity": "sha512-y/B5POM2iBnIxCiernH1G7rC9qQoM77lLIMQLuob0zhp8C56Po81+2Nj0WFKnd0pNReDTnkYryc+zhOzpEIROg==", "dev": true, "requires": { + "array-buffer-byte-length": "^1.0.0", + "available-typed-arrays": "^1.0.5", "call-bind": "^1.0.2", + "es-set-tostringtag": "^2.0.1", "es-to-primitive": "^1.2.1", - "function-bind": "^1.1.1", - "get-intrinsic": "^1.1.1", + "function.prototype.name": "^1.1.5", + "get-intrinsic": "^1.2.0", "get-symbol-description": "^1.0.0", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", "has": "^1.0.3", - "has-symbols": "^1.0.2", - "internal-slot": "^1.0.3", - "is-callable": "^1.2.4", - "is-negative-zero": "^2.0.1", + "has-property-descriptors": "^1.0.0", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.5", + "is-array-buffer": "^3.0.2", + "is-callable": "^1.2.7", + "is-negative-zero": "^2.0.2", "is-regex": "^1.1.4", - "is-shared-array-buffer": "^1.0.1", + "is-shared-array-buffer": "^1.0.2", "is-string": "^1.0.7", - "is-weakref": "^1.0.1", - "object-inspect": "^1.11.0", + "is-typed-array": "^1.1.10", + "is-weakref": "^1.0.2", + "object-inspect": "^1.12.3", "object-keys": "^1.1.1", - "object.assign": "^4.1.2", - "string.prototype.trimend": "^1.0.4", - "string.prototype.trimstart": "^1.0.4", - "unbox-primitive": "^1.0.1" + "object.assign": "^4.1.4", + "regexp.prototype.flags": "^1.4.3", + "safe-regex-test": "^1.0.0", + "string.prototype.trim": "^1.2.7", + "string.prototype.trimend": "^1.0.6", + "string.prototype.trimstart": "^1.0.6", + "typed-array-length": "^1.0.4", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.9" + } + }, + "es-set-tostringtag": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.1.tgz", + "integrity": "sha512-g3OMbtlwY3QewlqAiMLI47KywjWZoEytKr8pf6iTC8uJq5bIAH52Z9pnQ8pVL6whrCto53JZDuUIsifGeLorTg==", + "dev": true, + "requires": { + "get-intrinsic": "^1.1.3", + "has": "^1.0.3", + "has-tostringtag": "^1.0.0" + } + }, + "es-shim-unscopables": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz", + "integrity": "sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w==", + "dev": true, + "requires": { + "has": "^1.0.3" } }, "es-to-primitive": { @@ -21913,17 +22717,6 @@ "dev": true, "requires": { "is-glob": "^4.0.3" - }, - "dependencies": { - "is-glob": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", - "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dev": true, - "requires": { - "is-extglob": "^2.1.1" - } - } } }, "globals": { @@ -21968,6 +22761,156 @@ "dev": true, "requires": {} }, + "eslint-filtered-fix": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/eslint-filtered-fix/-/eslint-filtered-fix-0.3.0.tgz", + "integrity": "sha512-UMHOza9epEn9T+yVT8RiCFf0JdALpVzmoH62Ez/zvxM540IyUNAkr7aH2Frkv6zlm9a/gbmq/sc7C4SvzZQXcA==", + "dev": true, + "requires": { + "optionator": "^0.9.1" + } + }, + "eslint-formatter-friendly": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/eslint-formatter-friendly/-/eslint-formatter-friendly-7.0.0.tgz", + "integrity": "sha512-WXg2D5kMHcRxIZA3ulxdevi8/BGTXu72pfOO5vXHqcAfClfIWDSlOljROjCSOCcKvilgmHz1jDWbvFCZHjMQ5w==", + "dev": true, + "requires": { + "@babel/code-frame": "7.0.0", + "chalk": "2.4.2", + "extend": "3.0.2", + "strip-ansi": "5.2.0", + "text-table": "0.2.0" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", + "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", + "dev": true, + "requires": { + "@babel/highlight": "^7.0.0" + } + }, + "ansi-regex": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", + "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", + "dev": true + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "eslint-import-resolver-node": { + "version": "0.3.7", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.7.tgz", + "integrity": "sha512-gozW2blMLJCeFpBwugLTGyvVjNoeo1knonXAcatC6bjPBZitotxdWf7Gimr25N4c0AAOo4eOUfaG82IJPDpqCA==", + "dev": true, + "requires": { + "debug": "^3.2.7", + "is-core-module": "^2.11.0", + "resolve": "^1.22.1" + }, + "dependencies": { + "debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "eslint-module-utils": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz", + "integrity": "sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw==", + "dev": true, + "requires": { + "debug": "^3.2.7" + }, + "dependencies": { + "debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "eslint-nibble": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/eslint-nibble/-/eslint-nibble-8.1.0.tgz", + "integrity": "sha512-x9H/1oeuKdC0HsaWeBarOryqNLC+7QZfAZIAP0HnGcmiiPktFIQq/D0e+iiCSyqYLSaui3UwvH56sXMrf5oQhw==", + "dev": true, + "requires": { + "@ianvs/eslint-stats": "^2.0.0", + "chalk": "^4.1.1", + "eslint-filtered-fix": "^0.3.0", + "eslint-formatter-friendly": "^7.0.0", + "eslint-summary": "^1.0.0", + "inquirer": "^8.2.3", + "optionator": "^0.9.1" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, "eslint-plugin-chai-expect": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/eslint-plugin-chai-expect/-/eslint-plugin-chai-expect-3.0.0.tgz", @@ -22039,6 +22982,55 @@ } } }, + "eslint-plugin-import": { + "version": "2.27.5", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.27.5.tgz", + "integrity": "sha512-LmEt3GVofgiGuiE+ORpnvP+kAm3h6MLZJ4Q5HCyHADofsb4VzXFsRiWj3c0OFiV+3DWFh0qg3v9gcPlfc3zRow==", + "dev": true, + "requires": { + "array-includes": "^3.1.6", + "array.prototype.flat": "^1.3.1", + "array.prototype.flatmap": "^1.3.1", + "debug": "^3.2.7", + "doctrine": "^2.1.0", + "eslint-import-resolver-node": "^0.3.7", + "eslint-module-utils": "^2.7.4", + "has": "^1.0.3", + "is-core-module": "^2.11.0", + "is-glob": "^4.0.3", + "minimatch": "^3.1.2", + "object.values": "^1.1.6", + "resolve": "^1.22.1", + "semver": "^6.3.0", + "tsconfig-paths": "^3.14.1" + }, + "dependencies": { + "debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + }, + "doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, "eslint-plugin-knex": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/eslint-plugin-knex/-/eslint-plugin-knex-0.2.1.tgz", @@ -22226,6 +23218,43 @@ "estraverse": "^5.2.0" } }, + "eslint-summary": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/eslint-summary/-/eslint-summary-1.0.0.tgz", + "integrity": "sha512-cHr5WiNFhu2guLQykhQV8O7BQcnpFLR6GdLjbQfDDL0yGy9U7dXC6zMUtwoxYgJRC/Wk3yZMc+I6Q15Z7r4j9Q==", + "dev": true, + "requires": { + "chalk": "^1.0.0", + "text-table": "^0.2.0" + }, + "dependencies": { + "ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha512-kmCevFghRiWM7HB5zTPULl4r9bVFSWjz62MhqizDGUrq2NWuNMQyuv4tHHoKJHs69M/MF64lEcHdYIocrdWQYA==", + "dev": true + }, + "chalk": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha512-U3lRVLMSlsCfjqYPbLyVv11M9CPW4I728d6TCKMAOJueEeB9/8o+eSsMnxPJD+Q+K909sdESg7C+tIkoH6on1A==", + "dev": true, + "requires": { + "ansi-styles": "^2.2.1", + "escape-string-regexp": "^1.0.2", + "has-ansi": "^2.0.0", + "strip-ansi": "^3.0.0", + "supports-color": "^2.0.0" + } + }, + "supports-color": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", + "integrity": "sha512-KKNVtd6pCYgPIKU4cp2733HWYCpplQhddZLBUryaAHou723x+FRzQ5Df824Fj+IyyuiQTRoub4SnIFfIcrp70g==", + "dev": true + } + } + }, "eslint-utils": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", @@ -22565,6 +23594,15 @@ "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.9.tgz", "integrity": "sha512-MQDfihBQYMcyy5dhRDJUHcw7lb2Pv/TuE6xP1vyraLukNDHKbDxDNaOE3NbCAdKQApno+GPRyo1YAp89yCjK4w==" }, + "for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "requires": { + "is-callable": "^1.1.3" + } + }, "foreground-child": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", @@ -22634,6 +23672,24 @@ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" }, + "function.prototype.name": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.5.tgz", + "integrity": "sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3", + "es-abstract": "^1.19.0", + "functions-have-names": "^1.2.2" + } + }, + "functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true + }, "gauge": { "version": "2.7.4", "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", @@ -22667,13 +23723,14 @@ "dev": true }, "get-intrinsic": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", - "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", + "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", "requires": { "function-bind": "^1.1.1", "has": "^1.0.3", - "has-symbols": "^1.0.1" + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3" } }, "get-package-type": { @@ -22732,6 +23789,24 @@ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", "devOptional": true }, + "globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, + "requires": { + "define-properties": "^1.1.3" + } + }, + "gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "requires": { + "get-intrinsic": "^1.1.3" + } + }, "graceful-fs": { "version": "4.2.8", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", @@ -22920,10 +23995,19 @@ "function-bind": "^1.1.1" } }, + "has-ansi": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", + "integrity": "sha512-C8vBJ8DwUCx19vhm7urhTuUsr4/IyP6l4VzNQDv+ryHQObW3TTTp9yB68WpYgRe2bbaGuZ/se74IqFeVnMnLZg==", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, "has-bigints": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", - "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", "dev": true }, "has-flag": { @@ -22931,10 +24015,24 @@ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" }, + "has-property-descriptors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", + "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", + "dev": true, + "requires": { + "get-intrinsic": "^1.1.1" + } + }, + "has-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", + "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==" + }, "has-symbols": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", - "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==" + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" }, "has-tostringtag": { "version": "1.0.0", @@ -23350,12 +24448,12 @@ } }, "internal-slot": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", - "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.5.tgz", + "integrity": "sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ==", "dev": true, "requires": { - "get-intrinsic": "^1.1.0", + "get-intrinsic": "^1.2.0", "has": "^1.0.3", "side-channel": "^1.0.4" } @@ -23380,6 +24478,17 @@ "integrity": "sha1-LKmwM2UREYVUEvFr5dd8YqRYp2Y=", "dev": true }, + "is-array-buffer": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", + "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.0", + "is-typed-array": "^1.1.10" + } + }, "is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", @@ -23430,9 +24539,9 @@ } }, "is-callable": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.4.tgz", - "integrity": "sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w==", + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", "dev": true }, "is-ci": { @@ -23445,9 +24554,9 @@ } }, "is-core-module": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.4.0.tgz", - "integrity": "sha512-6A2fkfq1rfeQZjxrZJGerpLCTHRNEBiSgnu0+obeJpEPZRUooHgsizvzv0ZjJwOz3iWIHdJtVWJ/tmPr3D21/A==", + "version": "2.12.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz", + "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==", "requires": { "has": "^1.0.3" } @@ -23476,9 +24585,9 @@ } }, "is-glob": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", - "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", "dev": true, "requires": { "is-extglob": "^2.1.1" @@ -23491,9 +24600,9 @@ "dev": true }, "is-negative-zero": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.1.tgz", - "integrity": "sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w==", + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", + "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", "dev": true }, "is-number": { @@ -23503,9 +24612,9 @@ "dev": true }, "is-number-object": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.6.tgz", - "integrity": "sha512-bEVOqiRcvo3zO1+G2lVMy+gkkEm9Yh7cDMRusKKu5ZJKPUYSJwICTKZrNKHA2EbSP0Tu0+6B/emsYNHZyn6K8g==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", "dev": true, "requires": { "has-tostringtag": "^1.0.0" @@ -23549,10 +24658,13 @@ } }, "is-shared-array-buffer": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.1.tgz", - "integrity": "sha512-IU0NmyknYZN0rChcKhRO1X8LYz5Isj/Fsqh8NJOSf+N/hCOTwy29F32Ik7a+QszE63IdvmwdTPDd6cZ5pg4cwA==", - "dev": true + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", + "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2" + } }, "is-stream": { "version": "2.0.1", @@ -23578,6 +24690,19 @@ "has-symbols": "^1.0.2" } }, + "is-typed-array": { + "version": "1.1.10", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.10.tgz", + "integrity": "sha512-PJqgEHiWZvMpaFZ3uTc8kHPM4+4ADTlDniuQL7cU/UDA0Ql7F70yGfHph3cLNe+c9toaigv+DFzTJKhc2CtO6A==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0" + } + }, "is-typedarray": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", @@ -23590,12 +24715,12 @@ "dev": true }, "is-weakref": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.1.tgz", - "integrity": "sha512-b2jKc2pQZjaeFYWEf7ScFj+Be1I+PXmlu572Q8coTXZ+LD/QQZ7ShPMst8h16riVgyXTQwUsFEl74mDvc/3MHQ==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", "dev": true, "requires": { - "call-bind": "^1.0.0" + "call-bind": "^1.0.2" } }, "is-windows": { @@ -25264,9 +26389,9 @@ "dev": true }, "object-inspect": { - "version": "1.11.0", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.11.0.tgz", - "integrity": "sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg==" + "version": "1.12.3", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", + "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==" }, "object-keys": { "version": "1.1.1", @@ -25275,17 +26400,28 @@ "dev": true }, "object.assign": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", - "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", + "version": "4.1.4", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", + "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", "dev": true, "requires": { - "call-bind": "^1.0.0", - "define-properties": "^1.1.3", - "has-symbols": "^1.0.1", + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "has-symbols": "^1.0.3", "object-keys": "^1.1.1" } }, + "object.values": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.6.tgz", + "integrity": "sha512-FVVTkD1vENCsAcwNs9k6jea2uHC/X0+JcjG8YA60FN5CMaJmG95wT9jek/xX9nornqGRrBkKtzuAu2wuHpKqvw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + } + }, "on-exit-leak-free": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/on-exit-leak-free/-/on-exit-leak-free-2.1.0.tgz", @@ -26430,6 +27566,17 @@ "integrity": "sha512-s2aEVuLhvnVJW6s/iPgEGK6R+/xngd2jNQ+xy4bXNDKxZKJH6jpPHY6kVeVv1IeLCHgswRj+Kl3ELaDjG6V1iw==", "dev": true }, + "regexp.prototype.flags": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz", + "integrity": "sha512-0SutC3pNudRKgquxGoRGIz946MZVHqbNfPjBdxeOhBrdgDKlRoXmYLQN9xRbrR09ZXWeGAdPuif7egofn6v5LA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "functions-have-names": "^1.2.3" + } + }, "regexpp": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", @@ -26567,12 +27714,13 @@ "dev": true }, "resolve": { - "version": "1.20.0", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", - "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", + "version": "1.22.2", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", + "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", "requires": { - "is-core-module": "^2.2.0", - "path-parse": "^1.0.6" + "is-core-module": "^2.11.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" } }, "resolve-from": { @@ -26656,6 +27804,17 @@ "regexp-tree": "~0.1.1" } }, + "safe-regex-test": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.0.tgz", + "integrity": "sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.1.3", + "is-regex": "^1.1.4" + } + }, "safe-stable-stringify": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/safe-stable-stringify/-/safe-stable-stringify-2.3.1.tgz", @@ -27241,24 +28400,37 @@ "es-abstract": "^1.19.1" } }, + "string.prototype.trim": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.7.tgz", + "integrity": "sha512-p6TmeT1T3411M8Cgg9wBTMRtY2q9+PNy9EV1i2lIXUN/btt763oIfxwN3RR8VU6wHX8j/1CFy0L+YuThm6bgOg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + } + }, "string.prototype.trimend": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", - "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz", + "integrity": "sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.3" + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" } }, "string.prototype.trimstart": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", - "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz", + "integrity": "sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA==", "dev": true, "requires": { "call-bind": "^1.0.2", - "define-properties": "^1.1.3" + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" } }, "strip-ansi": { @@ -27343,6 +28515,11 @@ "has-flag": "^3.0.0" } }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==" + }, "swagger-parser": { "version": "10.0.3", "resolved": "https://registry.npmjs.org/swagger-parser/-/swagger-parser-10.0.3.tgz", @@ -27516,6 +28693,29 @@ "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", "integrity": "sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=" }, + "tsconfig-paths": { + "version": "3.14.2", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.14.2.tgz", + "integrity": "sha512-o/9iXgCYc5L/JxCHPe3Hvh8Q/2xm5Z+p18PESBU6Ff33695QnCHBEjcytY2q19ua7Mbl/DavtBOLq+oG0RCL+g==", + "dev": true, + "requires": { + "@types/json5": "^0.0.29", + "json5": "^1.0.2", + "minimist": "^1.2.6", + "strip-bom": "^3.0.0" + }, + "dependencies": { + "json5": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", + "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", + "dev": true, + "requires": { + "minimist": "^1.2.0" + } + } + } + }, "tslib": { "version": "1.14.1", "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", @@ -27554,6 +28754,17 @@ "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", "dev": true }, + "typed-array-length": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", + "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "is-typed-array": "^1.1.9" + } + }, "typedarray-to-buffer": { "version": "3.1.5", "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", @@ -27570,14 +28781,14 @@ "optional": true }, "unbox-primitive": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", - "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", "dev": true, "requires": { - "function-bind": "^1.1.1", - "has-bigints": "^1.0.1", - "has-symbols": "^1.0.2", + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", "which-boxed-primitive": "^1.0.2" } }, @@ -27730,6 +28941,20 @@ "integrity": "sha512-B+enWhmw6cjfVC7kS8Pj9pCrKSc5txArRyaYGe088shv/FGWH+0Rjx/xPgtsWfsUtS27FkP697E4DDhgrgoc0Q==", "optional": true }, + "which-typed-array": { + "version": "1.1.9", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.9.tgz", + "integrity": "sha512-w9c4xkx6mPidwp7180ckYWfMmvxpjlZuIudNtDf4N/tTAUB8VJbX25qZoAsrtGuYNnGw3pa0AXgbGKRB8/EceA==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0", + "is-typed-array": "^1.1.10" + } + }, "wide-align": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", diff --git a/api/package.json b/api/package.json index d98cc04afc0..639d3f4e1b9 100644 --- a/api/package.json +++ b/api/package.json @@ -9,6 +9,7 @@ "node": "16", "npm": ">=8.13.2 <9" }, + "type": "module", "repository": { "type": "git", "url": "git+https://github.com/1024pix/pix.git" @@ -31,7 +32,6 @@ "bcrypt": "^5.0.1", "bluebird": "^3.7.2", "bookshelf": "^1.2.0", - "bookshelf-json-columns": "^3.0.0", "bookshelf-validate": "^2.0.3", "cron-parser": "^4.6.0", "dayjs": "^1.11.5", @@ -89,6 +89,7 @@ }, "devDependencies": { "@babel/eslint-parser": "^7.18.2", + "@babel/plugin-syntax-import-assertions": "^7.20.0", "@ls-lint/ls-lint": "^1.11.2", "chai": "^4.3.6", "chai-as-promised": "^7.1.1", @@ -98,6 +99,7 @@ "eslint-config-prettier": "^8.5.0", "eslint-plugin-chai-expect": "^3.0.0", "eslint-plugin-i18n-json": "^4.0.0", + "eslint-plugin-import": "^2.27.5", "eslint-plugin-knex": "^0.2.1", "eslint-plugin-mocha": "^10.0.5", "eslint-plugin-node": "^11.1.0", @@ -107,7 +109,6 @@ "flush-write-stream": "^2.0.0", "form-data": "^4.0.0", "inquirer": "^8.2.4", - "jscodeshift": "^0.14.0", "mocha": "^10.0.0", "mocha-junit-reporter": "^2.0.2", "mockdate": "^3.0.5", @@ -115,7 +116,6 @@ "nodemon": "^2.0.16", "npm-run-all": "^4.1.5", "prettier": "^2.7.1", - "proxyquire": "^2.1.3", "sinon": "^15.0.0", "sinon-chai": "^3.7.0", "split2": "^4.1.0", @@ -140,8 +140,8 @@ "db:reset": "npm run db:prepare && npm run db:seed", "lint": "npm-run-all --parallel --continue-on-error lint:*", "lint:dependencies": "depcheck", - "lint:database": "NODE_ENV=test npm run db:prepare && schemalint --config tests/acceptance/database/configuration.js", "lint:file-and-directory-names": "ls-lint", + "lint:database": "NODE_ENV=test npm run db:prepare && schemalint --config tests/acceptance/database/configuration.cjs", "lint:code": "eslint . --ext js --cache --cache-strategy content", "lint:code:uncached": "eslint . --ext js", "lint:translations": "eslint --ext .json --format node_modules/eslint-plugin-i18n-json/formatter.js translations", @@ -149,7 +149,6 @@ "lint-fix:translations": "eslint --fix --ext .json --format node_modules/eslint-plugin-i18n-json/formatter.js translations", "lint-fix:code": "eslint --fix . --ext js --cache --cache-strategy content", "local:test:coverage": "nyc npm test", - "migrate-to-esm": "jscodeshift --transform ./codemods/migrate-cjs-to-esm/transforms/index.js --extensions js --ignore-config=.esmignore --dry .", "postdeploy": "npm run db:migrate", "preinstall": "npx check-engine", "scalingo-postbuild": "node scripts/generate-cron > cron.json", @@ -157,7 +156,7 @@ "start:watch": "nodemon index.js", "start:job": "node worker.js", "start:job:watch": "nodemon worker.js", - "test": "NODE_ENV=test npm run db:prepare && npm run test:api && npm run test:codemods", + "test": "NODE_ENV=test npm run db:prepare && npm run test:api", "test:api": "status=0; npm run test:api:unit || status=1 ; for dir in $(find tests/* -maxdepth 0 -type d -not -path tests/unit) ; do npm run test:api:path -- $dir || status=1 ; done ; exit $status", "test:api:path": "NODE_ENV=test mocha --exit --recursive --reporter=${MOCHA_REPORTER:-dot}", "test:api:scripts": "npm run test:api:path -- tests/integration/scripts", @@ -167,10 +166,7 @@ "test:api:debug": "NODE_ENV=test mocha --inspect-brk=9229 --recursive --exit --reporter dot tests", "test:api:watch": "NODE_ENV=test mocha --recursive tests --watch --reporter dot", "test:api:bail": "npm run test:api:unit -- --bail && npm run test:api:integration -- --bail && npm run test:api:acceptance -- --bail", - "test:codemods": "cd codemods/migrate-cjs-to-esm; npm install; npm run test", - "test:lint": "npm test && npm run lint", - "esm-migration:prepare": "jscodeshift --transform ./codemods/migrate-cjs-to-esm/transforms/prepare.js --extensions js --ignore-config=.codemodsignore ./lib", - "esm-migration:execute": "jscodeshift --transform ./codemods/migrate-cjs-to-esm/transforms/execute.js --extensions js --ignore-config=.codemodsignore ./lib" + "test:lint": "npm test && npm run lint" }, "optionalDependencies": { "nyc": "^15.1.0" diff --git a/api/scripts/PgClient.js b/api/scripts/PgClient.js index 0182539e83e..12c892993c3 100644 --- a/api/scripts/PgClient.js +++ b/api/scripts/PgClient.js @@ -1,4 +1,6 @@ -const { Client } = require('pg'); +import pg from 'pg'; + +const { Client } = pg; class PgClient { constructor(databaseUrl) { @@ -29,4 +31,4 @@ class PgClient { } } -module.exports = PgClient; +export { PgClient }; diff --git a/api/scripts/_template.js b/api/scripts/_template.js index 86d14b52e77..ee75671dbaf 100644 --- a/api/scripts/_template.js +++ b/api/scripts/_template.js @@ -1,10 +1,14 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const { performance } = require('perf_hooks'); -const logger = require('../lib/infrastructure/logger'); -const { cache } = require('../lib/infrastructure/caches/learning-content-cache'); +import perf_hooks from 'perf_hooks'; +import * as url from 'url'; + +const { performance } = perf_hooks; -const { knex, disconnect } = require('../db/knex-database-connection'); +import { logger } from '../lib/infrastructure/logger.js'; +import { learningContentCache as cache } from '../lib/infrastructure/caches/learning-content-cache.js'; +import { knex, disconnect } from '../db/knex-database-connection.js'; const doSomething = async ({ throwError }) => { if (throwError) { @@ -14,7 +18,9 @@ const doSomething = async ({ throwError }) => { return data; }; -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +const __filename = modulePath; async function main() { const startTime = performance.now(); @@ -39,4 +45,4 @@ async function main() { } })(); -module.exports = { doSomething }; +export { doSomething }; diff --git a/api/scripts/add-or-update-certification-centers-dpo-infos.js b/api/scripts/add-or-update-certification-centers-dpo-infos.js index e94cde9fbf5..aac1c1217d1 100644 --- a/api/scripts/add-or-update-certification-centers-dpo-infos.js +++ b/api/scripts/add-or-update-certification-centers-dpo-infos.js @@ -1,14 +1,17 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); +import * as url from 'url'; -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { checkCsvHeader, parseCsvWithHeader } = require('./helpers/csvHelpers'); -const { disconnect } = require('../db/knex-database-connection'); -const updateCertificationCenterDataProtectionOfficerInformation = require('../lib/domain/usecases/update-certification-center-data-protection-officer-information'); -const dataProtectionOfficerRepository = require('../lib/infrastructure/repositories/data-protection-officer-repository'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import { checkCsvHeader, parseCsvWithHeader } from './helpers/csvHelpers.js'; +import { disconnect } from '../db/knex-database-connection.js'; +import { updateCertificationCenterDataProtectionOfficerInformation } from '../lib/domain/usecases/update-certification-center-data-protection-officer-information.js'; +import * as dataProtectionOfficerRepository from '../lib/infrastructure/repositories/data-protection-officer-repository.js'; -const IS_LAUNCHED_FROM_CLI = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const IS_LAUNCHED_FROM_CLI = process.argv[1] === modulePath; const REQUIRED_FIELD_NAMES = ['certificationCenterId', 'firstName', 'lastName', 'email']; const parsingOptions = { diff --git a/api/scripts/add-or-update-organizations-dpo-infos.js b/api/scripts/add-or-update-organizations-dpo-infos.js index f656a687aaf..588d9f62d58 100644 --- a/api/scripts/add-or-update-organizations-dpo-infos.js +++ b/api/scripts/add-or-update-organizations-dpo-infos.js @@ -1,14 +1,19 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { checkCsvHeader, parseCsvWithHeader } = require('./helpers/csvHelpers'); -const { disconnect } = require('../db/knex-database-connection'); -const updateOrganizationDataProtectionOfficerInformation = require('../lib/domain/usecases/update-organization-data-protection-officer-information'); -const dataProtectionOfficerRepository = require('../lib/infrastructure/repositories/data-protection-officer-repository'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import { checkCsvHeader, parseCsvWithHeader } from './helpers/csvHelpers.js'; +import { disconnect } from '../db/knex-database-connection.js'; +import { updateOrganizationDataProtectionOfficerInformation } from '../lib/domain/usecases/update-organization-data-protection-officer-information.js'; +import * as dataProtectionOfficerRepository from '../lib/infrastructure/repositories/data-protection-officer-repository.js'; + +import * as url from 'url'; + +const modulePath = url.fileURLToPath(import.meta.url); +const IS_LAUNCHED_FROM_CLI = process.argv[1] === modulePath; -const IS_LAUNCHED_FROM_CLI = require.main === module; const REQUIRED_FIELD_NAMES = ['organizationId', 'firstName', 'lastName', 'email']; const parsingOptions = { diff --git a/api/scripts/add-tags-to-organizations.js b/api/scripts/add-tags-to-organizations.js index 777c9a7b93a..61431a4dc29 100644 --- a/api/scripts/add-tags-to-organizations.js +++ b/api/scripts/add-tags-to-organizations.js @@ -1,29 +1,36 @@ // Usage: node add-tags-to-organizations.js path/file.csv // To use on file with columns |organizationId, tagName| -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const organizationTagRepository = require('../lib/infrastructure/repositories/organization-tag-repository'); -const tagRepository = require('../lib/infrastructure/repositories/tag-repository'); -const OrganizationTag = require('../lib/domain/models/OrganizationTag'); -const { parseCsv } = require('./helpers/csvHelpers'); -const uniq = require('lodash/uniq'); -const { disconnect } = require('../db/knex-database-connection'); +import * as organizationTagRepository from '../lib/infrastructure/repositories/organization-tag-repository.js'; +import * as tagRepository from '../lib/infrastructure/repositories/tag-repository.js'; +import { OrganizationTag } from '../lib/domain/models/OrganizationTag.js'; +import { parseCsv } from './helpers/csvHelpers.js'; +import lodash from 'lodash'; + +const { uniq } = lodash; +import { disconnect } from '../db/knex-database-connection.js'; + +import * as url from 'url'; + +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; function checkData({ csvData }) { return csvData .map(([organizationId, tagName]) => { if (!organizationId && !tagName) { - if (require.main === module) process.stdout.write('Found empty line in input file.'); + if (isLaunchedFromCommandLine) process.stdout.write('Found empty line in input file.'); return null; } if (!organizationId) { - if (require.main === module) process.stdout.write(`A line is missing an organizationId for tag ${tagName}`); + if (isLaunchedFromCommandLine) process.stdout.write(`A line is missing an organizationId for tag ${tagName}`); return null; } if (!tagName) { - if (require.main === module) + if (isLaunchedFromCommandLine) process.stdout.write(`A line is missing a tag name for organization id ${organizationId}`); return null; } @@ -50,7 +57,7 @@ async function retrieveTagsByName({ checkedData }) { async function addTagsToOrganizations({ tagsByName, checkedData, dependencies = { organizationTagRepository } }) { for (let i = 0; i < checkedData.length; i++) { - if (require.main === module) process.stdout.write(`\n${i + 1}/${checkedData.length} `); + if (isLaunchedFromCommandLine) process.stdout.write(`\n${i + 1}/${checkedData.length} `); const { organizationId, tagName } = checkedData[i]; const tagId = tagsByName.get(tagName).id; @@ -61,21 +68,19 @@ async function addTagsToOrganizations({ tagsByName, checkedData, dependencies = }); if (!isExisting) { - if (require.main === module) process.stdout.write(`Adding tag: ${tagName} to organization: ${organizationId} `); + if (isLaunchedFromCommandLine) process.stdout.write(`Adding tag: ${tagName} to organization: ${organizationId} `); const organizationTag = new OrganizationTag({ organizationId, tagId }); await dependencies.organizationTagRepository.create(organizationTag); - if (require.main === module) process.stdout.write('===> ✔'); + if (isLaunchedFromCommandLine) process.stdout.write('===> ✔'); } else { - if (require.main === module) + if (isLaunchedFromCommandLine) process.stdout.write(`Tag: ${tagName} already exists for organization: ${organizationId} `); } } } -const isLaunchedFromCommandLine = require.main === module; - async function main() { console.log('Starting script add-tags-to-organizations'); @@ -111,8 +116,4 @@ async function main() { } })(); -module.exports = { - addTagsToOrganizations, - retrieveTagsByName, - checkData, -}; +export { addTagsToOrganizations, retrieveTagsByName, checkData }; diff --git a/api/scripts/certification/cancel-certifications-and-publish-sessions.js b/api/scripts/certification/cancel-certifications-and-publish-sessions.js index 186db2b052c..84fa687f430 100644 --- a/api/scripts/certification/cancel-certifications-and-publish-sessions.js +++ b/api/scripts/certification/cancel-certifications-and-publish-sessions.js @@ -1,15 +1,17 @@ -const _ = require('lodash'); -const yargs = require('yargs'); -const unpublishSession = require('../../lib/domain/usecases/unpublish-session'); -const publishSession = require('../../lib/domain/usecases/publish-session'); -const finalizedSessionRepository = require('../../lib/infrastructure/repositories/sessions/finalized-session-repository'); -const sessionRepository = require('../../lib/infrastructure/repositories/sessions/session-repository'); -const certificationRepository = require('../../lib/infrastructure/repositories/certification-repository'); -const sessionPublicationService = require('../../lib/domain/services/session-publication-service'); -const { parseCsvWithHeader } = require('../helpers/csvHelpers'); -const { knex, disconnect } = require('../../db/knex-database-connection'); +import _ from 'lodash'; +import yargs from 'yargs'; +import { unpublishSession } from '../../lib/domain/usecases/unpublish-session.js'; +import { publishSession } from '../../lib/domain/usecases/publish-session.js'; +import * as finalizedSessionRepository from '../../lib/infrastructure/repositories/sessions/finalized-session-repository.js'; +import * as sessionRepository from '../../lib/infrastructure/repositories/sessions/session-repository.js'; +import * as certificationRepository from '../../lib/infrastructure/repositories/certification-repository.js'; +import * as sessionPublicationService from '../../lib/domain/services/session-publication-service.js'; +import { parseCsvWithHeader } from '../helpers/csvHelpers.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; let progression = 0; + function _logProgression(totalCount) { ++progression; process.stdout.cursorTo(0); @@ -168,7 +170,8 @@ async function _findAlreadyPublishedSessions(sessionIdsToPublish) { return _.map(results, 'id'); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const commandLineArgs = yargs diff --git a/api/scripts/certification/fill-issue-report-category-id.js b/api/scripts/certification/fill-issue-report-category-id.js index 42a72700d17..f6bdad59545 100644 --- a/api/scripts/certification/fill-issue-report-category-id.js +++ b/api/scripts/certification/fill-issue-report-category-id.js @@ -1,8 +1,11 @@ -const logger = require('../../lib/infrastructure/logger'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const bluebird = require('bluebird'); +import { logger } from '../../lib/infrastructure/logger.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import bluebird from 'bluebird'; +import * as url from 'url'; -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +const __filename = modulePath; async function _getIdCategorySubcategoryFromCertificationIssueReport() { return knex('certification-issue-reports').select('id', 'category', 'subcategory'); @@ -43,7 +46,7 @@ async function main() { } })(); -module.exports = { main }; +export { main }; async function _updateIssueReportsWithCategoryId(certificationIssueReports, categories) { let count = 0; diff --git a/api/scripts/certification/fill-last-assessment-result-certification-course-table.js b/api/scripts/certification/fill-last-assessment-result-certification-course-table.js index 75b327b0cbf..94da25ef958 100755 --- a/api/scripts/certification/fill-last-assessment-result-certification-course-table.js +++ b/api/scripts/certification/fill-last-assessment-result-certification-course-table.js @@ -1,9 +1,11 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const logger = require('../../lib/infrastructure/logger'); -const { cache } = require('../../lib/infrastructure/caches/learning-content-cache'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const bluebird = require('bluebird'); +import { logger } from '../../lib/infrastructure/logger.js'; +import { learningContentCache as cache } from '../../lib/infrastructure/caches/learning-content-cache.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import bluebird from 'bluebird'; +import * as url from 'url'; const ASSOC_TABLE_NAME = 'certification-courses-last-assessment-results'; @@ -28,7 +30,8 @@ const addLastAssessmentResultCertificationCourse = async () => { } }; -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; function main() { return addLastAssessmentResultCertificationCourse(); @@ -84,4 +87,4 @@ async function _getLatestAssessmentResultId(certificationCourseId) { return certificationDTO?.lastAssessmentResultId; } -module.exports = { addLastAssessmentResultCertificationCourse }; +export { addLastAssessmentResultCertificationCourse }; diff --git a/api/scripts/certification/fill-pix-certification-status-column-in-certification-courses-table.js b/api/scripts/certification/fill-pix-certification-status-column-in-certification-courses-table.js index 0b3147f8a1d..169e73b52fa 100644 --- a/api/scripts/certification/fill-pix-certification-status-column-in-certification-courses-table.js +++ b/api/scripts/certification/fill-pix-certification-status-column-in-certification-courses-table.js @@ -1,17 +1,24 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const { performance } = require('perf_hooks'); -const logger = require('../../lib/infrastructure/logger'); -const { cache } = require('../../lib/infrastructure/caches/learning-content-cache'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const yargs = require('yargs'); -const bluebird = require('bluebird'); -const { status } = require('../../lib/domain/models/AssessmentResult'); -const readline = require('readline'); +import perf_hooks from 'perf_hooks'; + +const { performance } = perf_hooks; + +import { logger } from '../../lib/infrastructure/logger.js'; +import { learningContentCache as cache } from '../../lib/infrastructure/caches/learning-content-cache.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import yargs from 'yargs'; +import bluebird from 'bluebird'; +import { status } from '../../lib/domain/models/AssessmentResult.js'; +import readline from 'readline'; +import * as url from 'url'; + const DEFAULT_COUNT = 20000; const DEFAULT_CONCURRENCY = 2; let progression = 0; + function _logProgression(totalCount) { ++progression; readline.cursorTo(process.stdout, 0); @@ -41,7 +48,9 @@ const updatePixCertificationStatus = async ({ count, concurrency }) => { logger.info(`\n\tOK, ${failedGenerations} générations de codes échouées pour cause de code en doublon`); }; -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +const __filename = modulePath; async function main() { const startTime = performance.now(); @@ -146,4 +155,4 @@ async function _updatePixCertificationStatus(certificationId) { }); } -module.exports = { updatePixCertificationStatus }; +export { updatePixCertificationStatus }; diff --git a/api/scripts/certification/generate-certificate-verification-code.js b/api/scripts/certification/generate-certificate-verification-code.js index 879af777644..90ecb10f15b 100755 --- a/api/scripts/certification/generate-certificate-verification-code.js +++ b/api/scripts/certification/generate-certificate-verification-code.js @@ -1,18 +1,20 @@ -#! /usr/bin/env node /* eslint no-console: ["off"] */ -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const yargs = require('yargs'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const bluebird = require('bluebird'); -const certificationRepository = require('../../lib/infrastructure/repositories/certification-repository'); -const verifyCertificateCodeService = require('../../lib/domain/services/verify-certificate-code-service'); +import yargs from 'yargs'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import bluebird from 'bluebird'; +import * as certificationRepository from '../../lib/infrastructure/repositories/certification-repository.js'; +import * as verifyCertificateCodeService from '../../lib/domain/services/verify-certificate-code-service.js'; +import * as url from 'url'; + const uniqueConstraintViolationCode = '23505'; const DEFAULT_COUNT = 20000; const DEFAULT_CONCURRENCY = 1; let progression = 0; + function _logProgression(totalCount) { ++progression; process.stdout.cursorTo(0); @@ -83,10 +85,12 @@ function _findEligibleCertifications(count) { async function _generateVerificationCode(certificationId) { const verificationCode = await verifyCertificateCodeService.generateCertificateVerificationCode(); + // eslint-disable-next-line import/namespace return certificationRepository.saveVerificationCode(certificationId, verificationCode); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Validation des arguments...'); diff --git a/api/scripts/certification/generate-certification-attestations-by-session-ids.js b/api/scripts/certification/generate-certification-attestations-by-session-ids.js index a99a098f06e..e43ac27770a 100644 --- a/api/scripts/certification/generate-certification-attestations-by-session-ids.js +++ b/api/scripts/certification/generate-certification-attestations-by-session-ids.js @@ -1,18 +1,20 @@ -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const fs = require('fs'); -const bluebird = require('bluebird'); -const isEmpty = require('lodash/isEmpty'); -const compact = require('lodash/compact'); -const logger = require('../../lib/infrastructure/logger'); -const certificateRepository = require('../../lib/infrastructure/repositories/certificate-repository'); -const certificationCourseRepository = require('../../lib/infrastructure/repositories/certification-course-repository'); -const certificationAttestationPdf = require('../../lib/infrastructure/utils/pdf/certification-attestation-pdf'); -const { NotFoundError } = require('../../lib/domain/errors'); -const { cache } = require('../../lib/infrastructure/caches/learning-content-cache'); -const { disconnect } = require('../../db/knex-database-connection'); +import fs from 'fs'; +import bluebird from 'bluebird'; +import lodash from 'lodash'; + +const { isEmpty, compact } = lodash; +import { logger } from '../../lib/infrastructure/logger.js'; +import * as certificateRepository from '../../lib/infrastructure/repositories/certificate-repository.js'; +import * as certificationCourseRepository from '../../lib/infrastructure/repositories/certification-course-repository.js'; +import * as certificationAttestationPdf from '../../lib/infrastructure/utils/pdf/certification-attestation-pdf.js'; +import { NotFoundError } from '../../lib/domain/errors.js'; +import { learningContentCache as cache } from '../../lib/infrastructure/caches/learning-content-cache.js'; +import { disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; /** * Avant de lancer le script, remplacer la variable DATABASE_URL par l'url de la base de réplication @@ -70,8 +72,10 @@ async function main() { logger.info('Fin du script.'); } +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; (async () => { - if (require.main === module) { + if (isLaunchedFromCommandLine) { try { await main(); } catch (error) { diff --git a/api/scripts/certification/generate-certification-csv-results-by-session-ids.js b/api/scripts/certification/generate-certification-csv-results-by-session-ids.js index 892ed0b2aa9..30e37fde71e 100644 --- a/api/scripts/certification/generate-certification-csv-results-by-session-ids.js +++ b/api/scripts/certification/generate-certification-csv-results-by-session-ids.js @@ -1,14 +1,19 @@ -'use strict'; -require('dotenv').config({ path: `${__dirname}/../.env` }); +import * as dotenv from 'dotenv'; -const fs = require('fs'); -const bluebird = require('bluebird'); -const isEmpty = require('lodash/isEmpty'); -const logger = require('../../lib/infrastructure/logger'); -const certificationResultUtils = require('../../lib/infrastructure/utils/csv/certification-results'); -const usecases = require('../../lib/domain/usecases/index.js'); -const temporaryStorage = require('../../lib/infrastructure/temporary-storage/index'); -const { disconnect } = require('../../db/knex-database-connection'); +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +dotenv.config({ path: `${__dirname}/../.env` }); + +import fs from 'fs'; +import bluebird from 'bluebird'; +import lodash from 'lodash'; +const { isEmpty } = lodash; +import { logger } from '../../lib/infrastructure/logger.js'; +import * as certificationResultUtils from '../../lib/infrastructure/utils/csv/certification-results.js'; +import { usecases } from '../../lib/domain/usecases/index.js'; +import { temporaryStorage } from '../../lib/infrastructure/temporary-storage/index.js'; +import { disconnect } from '../../db/knex-database-connection.js'; /** * Avant de lancer le script, remplacer la variable DATABASE_URL par l'url de la base de réplication @@ -47,8 +52,11 @@ async function main() { logger.info('Fin du script.'); } +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; + (async () => { - if (require.main === module) { + if (isLaunchedFromCommandLine) { try { await main(); } catch (error) { diff --git a/api/scripts/certification/generate-certification-results.js b/api/scripts/certification/generate-certification-results.js index 066d173cf95..f555d5e76f9 100644 --- a/api/scripts/certification/generate-certification-results.js +++ b/api/scripts/certification/generate-certification-results.js @@ -1,8 +1,10 @@ -const { knex, disconnect } = require('../../db/knex-database-connection'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; + const ASSESSMENT_COUNT = parseInt(process.env.ASSESSMENT_COUNT) || 100; -const bluebird = require('bluebird'); -const scoringCertificationService = require('../../lib/domain/services/scoring/scoring-certification-service'); -const certificationAssessmentRepository = require('../../lib/infrastructure/repositories/certification-assessment-repository'); +import bluebird from 'bluebird'; +import * as scoringCertificationService from '../../lib/domain/services/scoring/scoring-certification-service.js'; +import * as certificationAssessmentRepository from '../../lib/infrastructure/repositories/certification-assessment-repository.js'; +import * as url from 'url'; async function _retrieveLastScoredAssessmentIds() { const result = await knex.raw( @@ -39,7 +41,8 @@ async function _computeScore(assessmentIds) { return scores; } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.error(`Récupération de ${ASSESSMENT_COUNT} assessments...`); diff --git a/api/scripts/certification/generate-certification-test-statistics.js b/api/scripts/certification/generate-certification-test-statistics.js index 4c0b140ca92..f907400343e 100644 --- a/api/scripts/certification/generate-certification-test-statistics.js +++ b/api/scripts/certification/generate-certification-test-statistics.js @@ -1,15 +1,21 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const _ = require('lodash'); -const fp = require('lodash/fp').convert({ cap: false }); -const bluebird = require('bluebird'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const competenceRepository = require('../../lib/infrastructure/repositories/competence-repository'); -const challengeRepository = require('../../lib/infrastructure/repositories/challenge-repository'); -const placementProfileService = require('../../lib/domain/services/placement-profile-service'); -const certificationChallengeService = require('../../lib/domain/services/certification-challenges-service'); -const { FRENCH_FRANCE } = require('../../lib/domain/constants').LOCALE; +import _ from 'lodash'; + +import originalFp from 'lodash/fp.js'; + +const fp = originalFp.convert({ cap: false }); +import bluebird from 'bluebird'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as competenceRepository from '../../lib/infrastructure/repositories/competence-repository.js'; +import * as placementProfileService from '../../lib/domain/services/placement-profile-service.js'; +import * as certificationChallengeService from '../../lib/domain/services/certification-challenges-service.js'; +import { LOCALE } from '../../lib/domain/constants.js'; +import * as url from 'url'; + +const { FRENCH_FRANCE } = LOCALE; const USER_COUNT = parseInt(process.env.USER_COUNT) || 100; const USER_ID = parseInt(process.env.USER_ID) || null; @@ -20,14 +26,6 @@ const USER_ID = parseInt(process.env.USER_ID) || null; // Voir aussi : // - https://1024pix.atlassian.net/wiki/spaces/DEV/pages/1855422507/2020-09-28+G+n+rer+des+stats+sur+les+tests+de+certif -function makeRefDataFaster() { - challengeRepository.list = _.memoize(challengeRepository.findOperative); - competenceRepository.list = _.memoize(competenceRepository.list); - competenceRepository.listPixCompetencesOnly = _.memoize(competenceRepository.listPixCompetencesOnly); -} - -makeRefDataFaster(); - async function _retrieveUserIds() { const result = await knex.raw( ` @@ -80,7 +78,8 @@ function updateProgress() { process.stderr.write('.'); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { let userIds; diff --git a/api/scripts/certification/generate-last-assessments-score.js b/api/scripts/certification/generate-last-assessments-score.js index b241f503f00..485fa009653 100644 --- a/api/scripts/certification/generate-last-assessments-score.js +++ b/api/scripts/certification/generate-last-assessments-score.js @@ -1,10 +1,13 @@ -const { knex, disconnect } = require('../../db/knex-database-connection'); -const _ = require('lodash'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import _ from 'lodash'; + const ASSESSMENT_COUNT = parseInt(process.env.ASSESSMENT_COUNT) || 100; const ASSESSMENT_ID = parseInt(process.env.ASSESSMENT_ID) || null; -const bluebird = require('bluebird'); -const scoringCertificationService = require('../../lib/domain/services/scoring/scoring-certification-service'); -const certificationAssessmentRepository = require('../../lib/infrastructure/repositories/certification-assessment-repository'); +import bluebird from 'bluebird'; +import * as scoringCertificationService from '../../lib/domain/services/scoring/scoring-certification-service.js'; +import * as certificationAssessmentRepository from '../../lib/infrastructure/repositories/certification-assessment-repository.js'; +import * as url from 'url'; + async function _retrieveLastScoredAssessmentIds() { const result = await knex.raw( ` @@ -54,7 +57,8 @@ async function _computeScore(assessmentIds) { return scores; } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { let assessmentIds = []; diff --git a/api/scripts/certification/get-cpf-import-status-from-xml.js b/api/scripts/certification/get-cpf-import-status-from-xml.js index 5d5ed8635b5..909a5c0436c 100644 --- a/api/scripts/certification/get-cpf-import-status-from-xml.js +++ b/api/scripts/certification/get-cpf-import-status-from-xml.js @@ -1,15 +1,17 @@ -const fs = require('fs'); -const sax = require('sax'); -const saxPath = require('saxpath'); -const logger = require('../../lib/infrastructure/logger'); +import fs from 'fs'; +import sax from 'sax'; +import saxPath from 'saxpath'; +import { logger } from '../../lib/infrastructure/logger.js'; -const xml2js = require('xml2js'); +import xml2js from 'xml2js'; -const { disconnect } = require('../../db/knex-database-connection'); -const cpfCertificationResultRepository = require('../../lib/infrastructure/repositories/cpf-certification-result-repository'); -const { cpfImportStatus } = require('../../lib/domain/models/CertificationCourse'); +import { disconnect } from '../../db/knex-database-connection.js'; +import * as cpfCertificationResultRepository from '../../lib/infrastructure/repositories/cpf-certification-result-repository.js'; +import { cpfImportStatus } from '../../lib/domain/models/CertificationCourse.js'; +import * as url from 'url'; -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main(path) { logger.info("Récupération des résultats d'import CPF..."); @@ -90,7 +92,4 @@ function getCpfImportResults(filePath) { }); } -module.exports = { - getCpfImportResults, - main, -}; +export { getCpfImportResults, main }; diff --git a/api/scripts/certification/get-results-certifications-old.js b/api/scripts/certification/get-results-certifications-old.js index e93f7ab65b2..ca3b5afa11e 100755 --- a/api/scripts/certification/get-results-certifications-old.js +++ b/api/scripts/certification/get-results-certifications-old.js @@ -1,8 +1,7 @@ -#! /usr/bin/env node - -const request = require('request-promise-native'); -const json2csv = require('json2csv'); -const moment = require('moment-timezone'); +import request from 'request-promise-native'; +import json2csv from 'json2csv'; +import moment from 'moment-timezone'; +import * as url from 'url'; // request.debug = true; const HEADERS = [ @@ -98,15 +97,10 @@ function main() { } /*=================== tests =============================*/ - -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +if (isLaunchedFromCommandLine) { main(); -} else { - module.exports = { - parseArgs, - toCSVRow, - buildRequestObject, - findCompetence, - HEADERS, - }; } + +export { parseArgs, toCSVRow, buildRequestObject, findCompetence, HEADERS }; diff --git a/api/scripts/certification/get-results-certifications.js b/api/scripts/certification/get-results-certifications.js index c1534fa5229..81dda14fc1b 100755 --- a/api/scripts/certification/get-results-certifications.js +++ b/api/scripts/certification/get-results-certifications.js @@ -1,10 +1,8 @@ -#! /usr/bin/env node - -const fileSystem = require('fs'); - -const request = require('request-promise-native'); -const json2csv = require('json2csv'); -const moment = require('moment-timezone'); +import fileSystem from 'fs'; +import request from 'request-promise-native'; +import json2csv from 'json2csv'; +import moment from 'moment-timezone'; +import * as url from 'url'; const HEADERS = [ 'ID de certification', @@ -181,13 +179,10 @@ function main() { }); } -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +if (isLaunchedFromCommandLine) { main(); } -module.exports = { - buildCertificationRequest, - toCSVRow, - findCompetence, - buildSessionRequest, -}; +export { buildCertificationRequest, toCSVRow, findCompetence, buildSessionRequest }; diff --git a/api/scripts/certification/get-user-certifications-eligibility.js b/api/scripts/certification/get-user-certifications-eligibility.js index 3bae6e81611..fc22a1cda74 100644 --- a/api/scripts/certification/get-user-certifications-eligibility.js +++ b/api/scripts/certification/get-user-certifications-eligibility.js @@ -1,14 +1,19 @@ -require('dotenv').config({ path: `${__dirname}/../.env` }); -const logger = require('../../lib/infrastructure/logger'); -const usecases = require('../../lib/domain/usecases/index.js'); -const { cache } = require('../../lib/infrastructure/caches/learning-content-cache'); -const placementProfileService = require('../../lib/domain/services/placement-profile-service'); -const certificationBadgesService = require('../../lib/domain/services/certification-badges-service'); +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../.env` }); + +import { logger } from '../../lib/infrastructure/logger.js'; +import { usecases } from '../../lib/domain/usecases/index.js'; +import { learningContentCache as cache } from '../../lib/infrastructure/caches/learning-content-cache.js'; +import * as placementProfileService from '../../lib/domain/services/placement-profile-service.js'; +import * as certificationBadgesService from '../../lib/domain/services/certification-badges-service.js'; // Usage: node scripts/get-certifications-eligibility 1234 -('use strict'); -const { disconnect } = require('../../db/knex-database-connection'); -const temporaryStorage = require('../../lib/infrastructure/temporary-storage/index'); +import { disconnect } from '../../db/knex-database-connection.js'; +import { temporaryStorage } from '../../lib/infrastructure/temporary-storage/index.js'; async function getUserCertificationsEligibility(userId) { logger.info('Starting script get-user-certifications-eligibility'); @@ -26,7 +31,8 @@ async function getUserCertificationsEligibility(userId) { console.log(`COMPLEMENTAIRES: ${complementaires}`); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const userId = process.argv[2]; @@ -48,6 +54,4 @@ async function main() { } })(); -module.exports = { - getUserCertificationsEligibility, -}; +export { getUserCertificationsEligibility }; diff --git a/api/scripts/certification/import-certification-cpf-cities.js b/api/scripts/certification/import-certification-cpf-cities.js index d01aa0ce274..dc4a9703397 100644 --- a/api/scripts/certification/import-certification-cpf-cities.js +++ b/api/scripts/certification/import-certification-cpf-cities.js @@ -1,9 +1,7 @@ -#!/usr/bin/env node -// eslint-disable-file node/no-process-exit +import dotenv from 'dotenv'; -const dotenv = require('dotenv'); dotenv.config(); -const logger = require('../../lib/infrastructure/logger'); +import { logger } from '../../lib/infrastructure/logger.js'; /** * Usage: node scripts/import-certification-cpf-cities path/file.csv @@ -14,11 +12,11 @@ const logger = require('../../lib/infrastructure/logger'); * File downloaded from https://www.data.gouv.fr/fr/datasets/base-officielle-des-codes-postaux/ (Export au format CSV) **/ -('use strict'); -const { parseCsv, checkCsvHeader } = require('../helpers/csvHelpers'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const uniqBy = require('lodash/uniqBy'); -const values = require('lodash/values'); +import { parseCsv, checkCsvHeader } from '../helpers/csvHelpers.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import lodash from 'lodash'; +const { uniqBy, values } = lodash; +import * as url from 'url'; const wordsToReplace = [ { @@ -393,7 +391,8 @@ function _buildCityNameWithWordReplaced(cityName) { return cityName.replace(entry.regex, ` ${entry.value} `).trim(); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main(filePath) { logger.info('Starting script import-certification-cpf-cities'); @@ -443,7 +442,4 @@ async function main(filePath) { } })(); -module.exports = { - buildCities, - getCitiesWithDistricts, -}; +export { buildCities, getCitiesWithDistricts }; diff --git a/api/scripts/certification/import-certification-cpf-countries.js b/api/scripts/certification/import-certification-cpf-countries.js index 44337adb973..ba2fdca0aee 100755 --- a/api/scripts/certification/import-certification-cpf-countries.js +++ b/api/scripts/certification/import-certification-cpf-countries.js @@ -1,14 +1,12 @@ -#!/usr/bin/env node - // Usage: node import-certification-cpf-countries.js path/file.csv // File Millésime 2021 : Liste des pays et territoires étrangers au 01/01/2021 // downloaded from https://www.data.gouv.fr/fr/datasets/code-officiel-geographique-cog/ -'use strict'; -const { parseCsv } = require('../helpers/csvHelpers'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const { normalizeAndSortChars } = require('../../lib/infrastructure/utils/string-utils'); -const _ = require('lodash'); +import { parseCsv } from '../helpers/csvHelpers.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { normalizeAndSortChars } from '../../lib/infrastructure/utils/string-utils.js'; +import _ from 'lodash'; +import * as url from 'url'; const CURRENT_NAME_COLUMN = 'LIBCOG'; const ALTERNATIVE_NAME_COLUMN = 'LIBENR'; @@ -75,7 +73,8 @@ function checkTransformUnicity(countries) { if (hasError) throw new Error('There are more than 1 transformed name with distinct code'); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main(filePath) { console.log('Starting script import-certification-cpf-countries'); @@ -121,7 +120,4 @@ async function main(filePath) { } })(); -module.exports = { - buildCountries, - checkTransformUnicity, -}; +export { buildCountries, checkTransformUnicity }; diff --git a/api/scripts/certification/import-certifications-from-csv.js b/api/scripts/certification/import-certifications-from-csv.js index f0fe648b0f8..fef4e2be4f4 100755 --- a/api/scripts/certification/import-certifications-from-csv.js +++ b/api/scripts/certification/import-certifications-from-csv.js @@ -1,8 +1,9 @@ -const path = require('path'); -const fs = require('fs'); -const request = require('request-promise-native'); -const papa = require('papaparse'); -const { disconnect } = require('../../db/knex-database-connection'); +import path from 'path'; +import fs from 'fs'; +import request from 'request-promise-native'; +import papa from 'papaparse'; +import { disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; const CSV_HEADERS = { ID: 'ID de certification', @@ -117,7 +118,8 @@ function _logErrorObjects(errorObjects) { }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; /** * Usage: node import-certifications-from-csv.js http://localhost:3000 jwt.access.token my_file.csv @@ -152,8 +154,4 @@ function main() { } })(); -module.exports = { - assertFileValidity, - convertCSVDataIntoCertifications, - saveCertifications, -}; +export { assertFileValidity, convertCSVDataIntoCertifications, saveCertifications }; diff --git a/api/scripts/certification/launch-auto-jury-for-session.js b/api/scripts/certification/launch-auto-jury-for-session.js index 218213e67dd..eb6d8f9c17a 100644 --- a/api/scripts/certification/launch-auto-jury-for-session.js +++ b/api/scripts/certification/launch-auto-jury-for-session.js @@ -1,17 +1,19 @@ -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const SessionFinalized = require('../../lib/domain/events/SessionFinalized'); -const certificationAssessmentRepository = require('../../lib/infrastructure/repositories/certification-assessment-repository'); -const challengeRepository = require('../../lib/infrastructure/repositories/challenge-repository'); -const certificationIssueReportRepository = require('../../lib/infrastructure/repositories/certification-issue-report-repository'); -const certificationCourseRepository = require('../../lib/infrastructure/repositories/certification-course-repository'); -const handleAutoJury = require('../../lib/domain/events/handle-auto-jury'); -const events = require('../../lib/domain/events/index.js'); -const logger = require('../../lib/infrastructure/logger'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { SessionFinalized } from '../../lib/domain/events/SessionFinalized.js'; +import * as certificationAssessmentRepository from '../../lib/infrastructure/repositories/certification-assessment-repository.js'; +import * as challengeRepository from '../../lib/infrastructure/repositories/challenge-repository.js'; +import * as certificationIssueReportRepository from '../../lib/infrastructure/repositories/certification-issue-report-repository.js'; +import * as certificationCourseRepository from '../../lib/infrastructure/repositories/certification-course-repository.js'; +import { handleAutoJury } from '../../lib/domain/events/handle-auto-jury.js'; +import * as events from '../../lib/domain/events/index.js'; +import { logger } from '../../lib/infrastructure/logger.js'; +import * as url from 'url'; -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const id = process.argv[2]; diff --git a/api/scripts/certification/trigger-autojury-on-finalized-sessions.js b/api/scripts/certification/trigger-autojury-on-finalized-sessions.js index 7c651471149..ef489059685 100644 --- a/api/scripts/certification/trigger-autojury-on-finalized-sessions.js +++ b/api/scripts/certification/trigger-autojury-on-finalized-sessions.js @@ -1,13 +1,15 @@ -const { knex, disconnect } = require('../../db/knex-database-connection'); -const bluebird = require('bluebird'); -const handleAutoJury = require('../../lib/domain/events/handle-auto-jury'); -const certificationIssueReportRepository = require('../../lib/infrastructure/repositories/certification-issue-report-repository'); -const certificationAssessmentRepository = require('../../lib/infrastructure/repositories/certification-assessment-repository'); -const certificationCourseRepository = require('../../lib/infrastructure/repositories/certification-course-repository'); -const challengeRepository = require('../../lib/infrastructure/repositories/challenge-repository'); -const logger = require('../../lib/infrastructure/logger'); -const SessionFinalized = require('../../lib/domain/events/SessionFinalized'); -const { eventDispatcher } = require('../../lib/domain/events/index.js'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import bluebird from 'bluebird'; +import { handleAutoJury } from '../../lib/domain/events/handle-auto-jury.js'; +import * as certificationIssueReportRepository from '../../lib/infrastructure/repositories/certification-issue-report-repository.js'; +import * as certificationAssessmentRepository from '../../lib/infrastructure/repositories/certification-assessment-repository.js'; +import * as certificationCourseRepository from '../../lib/infrastructure/repositories/certification-course-repository.js'; +import * as challengeRepository from '../../lib/infrastructure/repositories/challenge-repository.js'; +import { logger } from '../../lib/infrastructure/logger.js'; +import { SessionFinalized } from '../../lib/domain/events/SessionFinalized.js'; +import { eventDispatcher } from '../../lib/domain/events/index.js'; +import * as url from 'url'; + const IS_FROM_SCRATCH = process.env.IS_FROM_SCRATCH === 'true'; const AUDIT_TABLE = 'autojury-script-audit'; @@ -138,7 +140,8 @@ async function _toRetry(sessionId, error) { .where({ sessionId }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { let finalizedSessionEvents; diff --git a/api/scripts/certification/update-certification-infos.js b/api/scripts/certification/update-certification-infos.js index 5df34d1b3e0..51dad658e89 100644 --- a/api/scripts/certification/update-certification-infos.js +++ b/api/scripts/certification/update-certification-infos.js @@ -1,8 +1,15 @@ -require('dotenv').config({ path: `${__dirname}/../.env` }); +import * as url from 'url'; -const bluebird = require('bluebird'); -const { readFile } = require('fs/promises'); -const logger = require('../../lib/infrastructure/logger'); +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../.env` }); + +import bluebird from 'bluebird'; + +import { readFile } from 'fs/promises'; + +import { logger } from '../../lib/infrastructure/logger.js'; // Usage: node scripts/update-certifications-infos path/data.csv path/sessionsId.csv // data.csv // #externalId,birthdate,birthINSEECode,birthPostalCode,birthCity,birthCountry @@ -10,10 +17,10 @@ const logger = require('../../lib/infrastructure/logger'); // sessionsId.csv // 1,12,30 -('use strict'); -const { parseCsv, checkCsvHeader } = require('../helpers/csvHelpers'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const values = require('lodash/values'); +import { parseCsv, checkCsvHeader } from '../helpers/csvHelpers.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import lodash from 'lodash'; +const { values } = lodash; const headers = { externalId: 'externalId', @@ -107,7 +114,8 @@ async function updateCertificationInfos(dataFilePath, sessionIdsFilePath) { logger.info('Done.'); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const dataFilePath = process.argv[2]; @@ -128,7 +136,4 @@ async function main() { } })(); -module.exports = { - updateCertificationInfos, - headers, -}; +export { updateCertificationInfos, headers }; diff --git a/api/scripts/certification/verify-certificate-code-service_script.js b/api/scripts/certification/verify-certificate-code-service_script.js index f9223bfc72f..f0cbbf56625 100644 --- a/api/scripts/certification/verify-certificate-code-service_script.js +++ b/api/scripts/certification/verify-certificate-code-service_script.js @@ -1,6 +1,9 @@ -const _ = require('lodash'); -const verifyCertificationCodeService = require('../../lib/domain/services/verify-certificate-code-service'); -const verifyCertificateCodeRepository = require('../../../../lib/infrastructure/repositories/verify-certificate-code-repository'); +// eslint-disable-next-line eslint-comments/disable-enable-pair +/* eslint-disable import/namespace */ +import _ from 'lodash'; +import * as verifyCertificationCodeService from '../../lib/domain/services/verify-certificate-code-service.js'; +// eslint-disable-next-line node/no-missing-import, import/no-unresolved, node/no-unpublished-import +import * as verifyCertificateCodeRepository from '../../../../lib/infrastructure/repositories/verify-certificate-code-repository.js'; const addCertification = async () => { const code = await verifyCertificationCodeService.getNewVerifyCertificationCode(); diff --git a/api/scripts/clean-anonymized-users-authentication-methods.js b/api/scripts/clean-anonymized-users-authentication-methods.js index 7dc41937418..88646fdcd62 100644 --- a/api/scripts/clean-anonymized-users-authentication-methods.js +++ b/api/scripts/clean-anonymized-users-authentication-methods.js @@ -1,12 +1,16 @@ -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { disconnect } = require('../db/knex-database-connection'); -const { parseCsvWithHeader } = require('./helpers/csvHelpers'); -const authenticationMethodRepository = require('../lib/infrastructure/repositories/authentication-method-repository'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import { disconnect } from '../db/knex-database-connection.js'; +import { parseCsvWithHeader } from './helpers/csvHelpers.js'; +import * as authenticationMethodRepository from '../lib/infrastructure/repositories/authentication-method-repository.js'; +import * as url from 'url'; + +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function cleanAnonymizedAuthenticationMethods({ arrayOfAnonymizedUsersIds }) { const anonymizedUserIdsWithAuthenticationMethodsDeleted = []; @@ -21,8 +25,6 @@ async function cleanAnonymizedAuthenticationMethods({ arrayOfAnonymizedUsersIds return anonymizedUserIdsWithAuthenticationMethodsDeleted; } -const isLaunchedFromCommandLine = require.main === module; - async function main() { console.log('Starting deleting anonymized users authentication methods'); @@ -60,4 +62,4 @@ async function main() { } })(); -module.exports = { cleanAnonymizedAuthenticationMethods }; +export { cleanAnonymizedAuthenticationMethods }; diff --git a/api/scripts/compare-pix-with-latest-release.js b/api/scripts/compare-pix-with-latest-release.js index 16e9da6be6a..d3e2029cd35 100644 --- a/api/scripts/compare-pix-with-latest-release.js +++ b/api/scripts/compare-pix-with-latest-release.js @@ -1,15 +1,15 @@ -const dotenv = require('dotenv'); -dotenv.config(); -const _ = require('lodash'); -const calculateScoringInformationForCompetence = - require('../lib/domain/services/scoring/scoring-service').calculateScoringInformationForCompetence; -const buildKnowledgeElement = require('../db/database-builder/factory/build-knowledge-element'); -const tubeRepository = require('../lib/infrastructure/repositories/tube-repository'); -const skillRepository = require('../lib/infrastructure/repositories/skill-repository'); -const knowledgeElementRepository = require('../lib/infrastructure/repositories/knowledge-element-repository'); -const { cache } = require('../lib/infrastructure/caches/learning-content-cache'); +import dotenv from 'dotenv'; +import * as url from 'url'; -const { disconnect } = require('../db/knex-database-connection'); +dotenv.config(); +import _ from 'lodash'; +import { calculateScoringInformationForCompetence } from '../lib/domain/services/scoring/scoring-service.js'; +import { buildKnowledgeElement } from '../db/database-builder/factory/build-knowledge-element.js'; +import * as tubeRepository from '../lib/infrastructure/repositories/tube-repository.js'; +import * as skillRepository from '../lib/infrastructure/repositories/skill-repository.js'; +import * as knowledgeElementRepository from '../lib/infrastructure/repositories/knowledge-element-repository.js'; +import { learningContentCache as cache } from '../lib/infrastructure/caches/learning-content-cache.js'; +import { disconnect } from '../db/knex-database-connection.js'; async function getUserSkillsGroupedByTubeId(elements) { const ids = _.map(elements, (current) => current.skillId); @@ -120,7 +120,7 @@ async function main(userId) { console.log(result); } -module.exports = { +export { compareUserScoreWithLatestRelease, getUserValidatedKnowledgeElements, getUserSkillsGroupedByTubeId, @@ -128,4 +128,10 @@ module.exports = { getTubeByIds, }; -main(parseInt(process.argv[2])); +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +async () => { + if (isLaunchedFromCommandLine) { + await main(parseInt(process.argv[2])); + } +}; diff --git a/api/scripts/create-badge-criteria-for-specified-badge.js b/api/scripts/create-badge-criteria-for-specified-badge.js index 522b0122e5c..2894242f070 100644 --- a/api/scripts/create-badge-criteria-for-specified-badge.js +++ b/api/scripts/create-badge-criteria-for-specified-badge.js @@ -1,13 +1,14 @@ -('use strict'); -const Joi = require('joi'); -const bluebird = require('bluebird'); -const { NotFoundError } = require('../lib/domain/errors'); -const BadgeCriterion = require('../lib/domain/models/BadgeCriterion'); -const badgeRepository = require('../lib/infrastructure/repositories/badge-repository'); -const badgeCriteriaRepository = require('../lib/infrastructure/repositories/badge-criteria-repository'); -const skillSetRepository = require('../lib/infrastructure/repositories/skill-set-repository'); -const DomainTransaction = require('../lib/infrastructure/DomainTransaction'); -const { knex, disconnect } = require('../db/knex-database-connection'); +import Joi from 'joi'; +import bluebird from 'bluebird'; +import { NotFoundError } from '../lib/domain/errors.js'; +import { BadgeCriterion } from '../lib/domain/models/BadgeCriterion.js'; +import * as badgeRepository from '../lib/infrastructure/repositories/badge-repository.js'; +import * as badgeCriteriaRepository from '../lib/infrastructure/repositories/badge-criteria-repository.js'; +import * as skillSetRepository from '../lib/infrastructure/repositories/skill-set-repository.js'; +import { DomainTransaction } from '../lib/infrastructure/DomainTransaction.js'; +import { knex, disconnect } from '../db/knex-database-connection.js'; +import { readFile } from 'fs/promises'; +import * as url from 'url'; // Usage: node scripts/create-badge-criteria-for-specified-badge path/data.json // data.json @@ -86,7 +87,8 @@ async function copySkillSets({ skillSetIds, newBadgeId }) { }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting creating badge criteria'); @@ -94,7 +96,7 @@ async function main() { const filePath = process.argv[2]; console.log('Reading json data file... '); - const jsonFile = require(filePath); + const jsonFile = await readFile(filePath); console.log('ok'); await checkBadgeExistence(jsonFile.badgeId); @@ -133,4 +135,4 @@ async function main() { } })(); -module.exports = { checkBadgeExistence, checkCriteriaFormat, checkSkillSetIds, copySkillSets }; +export { checkBadgeExistence, checkCriteriaFormat, checkSkillSetIds, copySkillSets }; diff --git a/api/scripts/create-certification-center-memberships-from-organization-admins.js b/api/scripts/create-certification-center-memberships-from-organization-admins.js index 79bbcde17dc..546ea58244a 100644 --- a/api/scripts/create-certification-center-memberships-from-organization-admins.js +++ b/api/scripts/create-certification-center-memberships-from-organization-admins.js @@ -1,13 +1,10 @@ -'use strict'; +import _ from 'lodash'; +import bluebird from 'bluebird'; -const _ = require('lodash'); -const bluebird = require('bluebird'); - -const { parseCsvWithHeader } = require('./helpers/csvHelpers'); - -const Membership = require('../lib/domain/models/Membership'); - -const { knex, disconnect } = require('../db/knex-database-connection'); +import { parseCsvWithHeader } from './helpers/csvHelpers.js'; +import { Membership } from '../lib/domain/models/Membership.js'; +import { knex, disconnect } from '../db/knex-database-connection.js'; +import * as url from 'url'; async function getCertificationCenterIdWithMembershipsUserIdByExternalId(externalId) { const certificationCenterIdWithMemberships = await knex('certification-centers') @@ -73,7 +70,8 @@ async function createCertificationCenterMemberships(certificationCenterMembershi return knex.batchInsert('certification-center-memberships', certificationCenterMemberships); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting creating Certification Center memberships with a list of ExternalIds.'); @@ -106,7 +104,7 @@ async function main() { } })(); -module.exports = { +export { getCertificationCenterIdWithMembershipsUserIdByExternalId, getAdminMembershipsUserIdByOrganizationExternalId, buildCertificationCenterMemberships, diff --git a/api/scripts/create-or-update-sco-agri-organizations.js b/api/scripts/create-or-update-sco-agri-organizations.js index c7dcb7d6c3f..4dded2116b1 100644 --- a/api/scripts/create-or-update-sco-agri-organizations.js +++ b/api/scripts/create-or-update-sco-agri-organizations.js @@ -1,23 +1,25 @@ // Usage: scalingo scalingo --region osc-secnum-fr1 -a pix-api-production run --file file.csv node scripts/create-or-update-sco-agri-organizations.js /tmp/uploads/file.csv // To use on file with columns |externalId, name, email| (email is optional) -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const logoUrl = require('./logo/default-sco-agri-organization-logo-base64'); -const { +import { logoUrl } from './logo/default-sco-agri-organization-logo-base64.js'; +import { findOrganizationsByExternalIds, organizeOrganizationsByExternalId, -} = require('./helpers/organizations-by-external-id-helper'); -const { parseCsv } = require('./helpers/csvHelpers'); -const Organization = require('../lib/domain/models/Organization'); -const Tag = require('../lib/domain/models/Tag'); -const OrganizationTag = require('../lib/domain/models/OrganizationTag'); -const organizationRepository = require('../lib/infrastructure/repositories/organization-repository'); -const tagRepository = require('../lib/infrastructure/repositories/tag-repository'); -const organizationTagRepository = require('../lib/infrastructure/repositories/organization-tag-repository'); -const { disconnect } = require('../db/knex-database-connection'); +} from './helpers/organizations-by-external-id-helper.js'; +import { parseCsv } from './helpers/csvHelpers.js'; +import { Organization } from '../lib/domain/models/Organization.js'; +import { Tag } from '../lib/domain/models/Tag.js'; +import { OrganizationTag } from '../lib/domain/models/OrganizationTag.js'; +import * as organizationRepository from '../lib/infrastructure/repositories/organization-repository.js'; +import * as tagRepository from '../lib/infrastructure/repositories/tag-repository.js'; +import * as organizationTagRepository from '../lib/infrastructure/repositories/organization-tag-repository.js'; +import { disconnect } from '../db/knex-database-connection.js'; + +import * as url from 'url'; const TAG_NAME = 'AGRICULTURE'; @@ -27,15 +29,15 @@ function checkData({ csvData }) { const [externalIdLowerCase, name, email] = data; if (!externalIdLowerCase && !name) { - if (require.main === module) process.stdout.write('Found empty line in input file.'); + if (isLaunchedFromCommandLine) process.stdout.write('Found empty line in input file.'); return null; } if (!externalIdLowerCase) { - if (require.main === module) process.stdout.write(`A line is missing an externalId for name ${name}`); + if (isLaunchedFromCommandLine) process.stdout.write(`A line is missing an externalId for name ${name}`); return null; } if (!name) { - if (require.main === module) + if (isLaunchedFromCommandLine) process.stdout.write(`A line is missing a name for external id ${externalIdLowerCase}`); return null; } @@ -57,7 +59,7 @@ function checkData({ csvData }) { async function createOrUpdateOrganizations({ organizationsByExternalId, checkedData }) { const createdOrUpdatedOrganizations = []; for (let i = 0; i < checkedData.length; i++) { - if (require.main === module) process.stdout.write(`\n${i + 1}/${checkedData.length} `); + if (isLaunchedFromCommandLine) process.stdout.write(`\n${i + 1}/${checkedData.length} `); const { externalId, name, email } = checkedData[i]; let organization = organizationsByExternalId[externalId]; @@ -104,7 +106,8 @@ async function addTag(organizations) { } } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting creating or updating SCO AGRICULTURE organizations.'); @@ -147,8 +150,4 @@ async function main() { } })(); -module.exports = { - addTag, - checkData, - createOrUpdateOrganizations, -}; +export { addTag, checkData, createOrUpdateOrganizations }; diff --git a/api/scripts/create-or-update-sco-organizations.js b/api/scripts/create-or-update-sco-organizations.js index fbf92bfe178..97113252137 100644 --- a/api/scripts/create-or-update-sco-organizations.js +++ b/api/scripts/create-or-update-sco-organizations.js @@ -1,18 +1,19 @@ // Usage: BASE_URL=... PIXMASTER_EMAIL=... PIXMASTER_PASSWORD=... node create-or-update-sco-organizations.js path/file.csv // To use on file with columns |externalId, name| -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const request = require('request-promise-native'); +import request from 'request-promise-native'; -const logoUrl = require('./logo/default-sco-organization-logo-base64'); -const { +import { logoUrl } from './logo/default-sco-organization-logo-base64.js'; +import { findOrganizationsByExternalIds, organizeOrganizationsByExternalId, -} = require('./helpers/organizations-by-external-id-helper'); -const { parseCsv } = require('./helpers/csvHelpers'); -const { disconnect } = require('../db/knex-database-connection'); +} from './helpers/organizations-by-external-id-helper.js'; +import { parseCsv } from './helpers/csvHelpers.js'; +import { disconnect } from '../db/knex-database-connection.js'; +import * as url from 'url'; const baseUrl = process.env.BASE_URL || 'http://localhost:3000'; @@ -22,15 +23,15 @@ function checkData({ csvData }) { const [externalIdLowerCase, name] = data; if (!externalIdLowerCase && !name) { - if (require.main === module) process.stdout.write('Found empty line in input file.'); + if (isLaunchedFromCommandLine) process.stdout.write('Found empty line in input file.'); return null; } if (!externalIdLowerCase) { - if (require.main === module) process.stdout.write(`A line is missing an externalId for name ${name}`); + if (isLaunchedFromCommandLine) process.stdout.write(`A line is missing an externalId for name ${name}`); return null; } if (!name) { - if (require.main === module) + if (isLaunchedFromCommandLine) process.stdout.write(`A line is missing a name for external id ${externalIdLowerCase}`); return null; } @@ -43,7 +44,7 @@ function checkData({ csvData }) { async function createOrUpdateOrganizations({ accessToken, organizationsByExternalId, checkedData }) { for (let i = 0; i < checkedData.length; i++) { - if (require.main === module) process.stdout.write(`\n${i + 1}/${checkedData.length} `); + if (isLaunchedFromCommandLine) process.stdout.write(`\n${i + 1}/${checkedData.length} `); const { externalId, name } = checkedData[i]; const organization = organizationsByExternalId[externalId]; @@ -126,7 +127,8 @@ function _buildPostOrganizationRequestObject(accessToken, organization) { }; } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting creating or updating SCO organizations.'); @@ -169,7 +171,4 @@ async function main() { } })(); -module.exports = { - checkData, - createOrUpdateOrganizations, -}; +export { checkData, createOrUpdateOrganizations }; diff --git a/api/scripts/create-organizations-with-tags-and-target-profiles.js b/api/scripts/create-organizations-with-tags-and-target-profiles.js index d12d4d9c63e..a79d09e9b37 100644 --- a/api/scripts/create-organizations-with-tags-and-target-profiles.js +++ b/api/scripts/create-organizations-with-tags-and-target-profiles.js @@ -1,23 +1,24 @@ // Usage: node create-organizations-with-tags-and-target-profiles.js path/file.csv // To use on file with columns |type, externalId, name, provinceCode, credit, emailInvitations, emailForSCOActivation, organizationInvitationRole, locale, tags, createdBy, targetProfiles, isManagingStudents, identityProviderForCampaigns, DPOFirstName, DPOLastName, DPOEmail| -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const { checkCsvHeader, parseCsvWithHeader } = require('./helpers/csvHelpers'); +import { checkCsvHeader, parseCsvWithHeader } from './helpers/csvHelpers.js'; +import { temporaryStorage } from '../lib/infrastructure/temporary-storage/index.js'; +import { createOrganizationsWithTagsAndTargetProfiles } from '../lib/domain/usecases/create-organizations-with-tags-and-target-profiles.js'; +import { DomainTransaction as domainTransaction } from '../lib/infrastructure/DomainTransaction.js'; +import * as organizationInvitationRepository from '../lib/infrastructure/repositories/organization-invitation-repository.js'; +import * as organizationRepository from '../lib/infrastructure/repositories/organization-repository.js'; +import * as dataProtectionOfficerRepository from '../lib/infrastructure/repositories/data-protection-officer-repository.js'; +import * as organizationTagRepository from '../lib/infrastructure/repositories/organization-tag-repository.js'; +import * as tagRepository from '../lib/infrastructure/repositories/tag-repository.js'; +import * as targetProfileShareRepository from '../lib/infrastructure/repositories/target-profile-share-repository.js'; +import { disconnect } from '../db/knex-database-connection.js'; +import lodash from 'lodash'; -const { temporaryStorage } = require('../lib/infrastructure/temporary-storage/index.js'); -const createOrganizationsWithTagsAndTargetProfiles = require('../lib/domain/usecases/create-organizations-with-tags-and-target-profiles'); -const domainTransaction = require('../lib/infrastructure/DomainTransaction'); -const organizationInvitationRepository = require('../lib/infrastructure/repositories/organization-invitation-repository'); -const organizationRepository = require('../lib/infrastructure/repositories/organization-repository'); -const dataProtectionOfficerRepository = require('../lib/infrastructure/repositories/data-protection-officer-repository'); -const organizationTagRepository = require('../lib/infrastructure/repositories/organization-tag-repository'); -const tagRepository = require('../lib/infrastructure/repositories/tag-repository'); -const targetProfileShareRepository = require('../lib/infrastructure/repositories/target-profile-share-repository'); -const { disconnect } = require('../db/knex-database-connection'); -const { isEmpty } = require('lodash'); +const { isEmpty } = lodash; const REQUIRED_FIELD_NAMES = [ 'type', @@ -112,7 +113,10 @@ async function createOrganizationWithTagsAndTargetProfiles(filePath) { }); } -const isLaunchedFromCommandLine = require.main === module; +import * as url from 'url'; + +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting creating PRO organizations with tags and target profiles.'); @@ -137,7 +141,4 @@ async function main() { } })(); -module.exports = { - createOrganizationWithTagsAndTargetProfiles, - batchOrganizationOptionsWithHeader, -}; +export { createOrganizationWithTagsAndTargetProfiles, batchOrganizationOptionsWithHeader }; diff --git a/api/scripts/create-sco-certification-centers.js b/api/scripts/create-sco-certification-centers.js index 3ed23e9f9da..c66a6d08e5c 100644 --- a/api/scripts/create-sco-certification-centers.js +++ b/api/scripts/create-sco-certification-centers.js @@ -1,7 +1,6 @@ -const { parseCsvWithHeader } = require('./helpers/csvHelpers'); - -const Bookshelf = require('../lib/infrastructure/bookshelf'); -const { disconnect } = require('../db/knex-database-connection'); +import { parseCsvWithHeader } from './helpers/csvHelpers.js'; +import { Bookshelf } from '../lib/infrastructure/bookshelf.js'; +import { disconnect } from '../db/knex-database-connection.js'; function prepareDataForInsert(rawCertificationCenters) { return rawCertificationCenters.map(({ name, uai }) => { @@ -17,7 +16,10 @@ function createScoCertificationCenters(certificationCenters) { return Bookshelf.knex.batchInsert('certification-centers', certificationCenters); } -const isLaunchedFromCommandLine = require.main === module; +import * as url from 'url'; + +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting creating SCO certification centers.'); @@ -50,7 +52,4 @@ async function main() { } })(); -module.exports = { - prepareDataForInsert, - createScoCertificationCenters, -}; +export { prepareDataForInsert, createScoCertificationCenters }; diff --git a/api/scripts/create-users-accounts-for-contest.js b/api/scripts/create-users-accounts-for-contest.js index 17668c299bb..398c6d3ff81 100644 --- a/api/scripts/create-users-accounts-for-contest.js +++ b/api/scripts/create-users-accounts-for-contest.js @@ -1,10 +1,11 @@ -const { parseCsvWithHeader } = require('./helpers/csvHelpers'); -const bluebird = require('bluebird'); -const userToCreateRepository = require('../lib/infrastructure/repositories/user-to-create-repository'); -const authenticationMethodRepository = require('../lib/infrastructure/repositories/authentication-method-repository'); -const userService = require('../lib/domain/services/user-service'); -const encryptionService = require('../lib/domain/services/encryption-service'); -const { disconnect } = require('../db/knex-database-connection'); +import { parseCsvWithHeader } from './helpers/csvHelpers.js'; +import bluebird from 'bluebird'; +import * as userToCreateRepository from '../lib/infrastructure/repositories/user-to-create-repository.js'; +import * as authenticationMethodRepository from '../lib/infrastructure/repositories/authentication-method-repository.js'; +import * as userService from '../lib/domain/services/user-service.js'; +import * as encryptionService from '../lib/domain/services/encryption-service.js'; +import { disconnect } from '../db/knex-database-connection.js'; +import * as url from 'url'; function prepareDataForInsert(rawUsers) { return rawUsers.map(({ firstName, lastName, email, password }) => { @@ -40,7 +41,8 @@ async function createUsers({ usersInRaw }) { }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting creating users accounts for contest.'); @@ -73,7 +75,4 @@ async function main() { } })(); -module.exports = { - prepareDataForInsert, - createUsers, -}; +export { prepareDataForInsert, createUsers }; diff --git a/api/scripts/data-generation/add-many-divisions-and-students-to-sco-organization.js b/api/scripts/data-generation/add-many-divisions-and-students-to-sco-organization.js index 187ca70f2e9..38ec220699f 100644 --- a/api/scripts/data-generation/add-many-divisions-and-students-to-sco-organization.js +++ b/api/scripts/data-generation/add-many-divisions-and-students-to-sco-organization.js @@ -1,8 +1,9 @@ -const _ = require('lodash'); -const randomString = require('randomstring'); -const OrganizationLearner = require('../../lib/domain/models/OrganizationLearner'); -const { OrganizationLearnersCouldNotBeSavedError } = require('../../lib/domain/errors'); -const { knex, disconnect } = require('../../db/knex-database-connection'); +import _ from 'lodash'; +import randomString from 'randomstring'; +import { OrganizationLearner } from '../../lib/domain/models/OrganizationLearner.js'; +import { OrganizationLearnersCouldNotBeSavedError } from '../../lib/domain/errors.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; function _buildOrganizationLearner(division, organizationId, iteration) { const birthdates = ['2001-01-05', '2002-11-15', '1995-06-25']; @@ -48,7 +49,8 @@ async function addManyDivisionsAndStudentsToScoCertificationCenter(numberOfDivis } } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting adding SCO students to certification center.'); @@ -74,6 +76,4 @@ async function main() { } })(); -module.exports = { - addManyDivisionsAndStudentsToScoCertificationCenter, -}; +export { addManyDivisionsAndStudentsToScoCertificationCenter }; diff --git a/api/scripts/data-generation/add-many-fake-members-related-to-one-organization.js b/api/scripts/data-generation/add-many-fake-members-related-to-one-organization.js index 05ec6beb3c1..f665f451884 100644 --- a/api/scripts/data-generation/add-many-fake-members-related-to-one-organization.js +++ b/api/scripts/data-generation/add-many-fake-members-related-to-one-organization.js @@ -1,7 +1,9 @@ -const DomainTransaction = require('../../lib/infrastructure/DomainTransaction'); -const { MembershipUpdateError, UserCantBeCreatedError, ForbiddenAccess } = require('../../lib/domain/errors'); -const times = require('lodash/times'); -const { knex, disconnect } = require('../../db/knex-database-connection'); +import { DomainTransaction } from '../../lib/infrastructure/DomainTransaction.js'; +import { MembershipUpdateError, UserCantBeCreatedError, ForbiddenAccess } from '../../lib/domain/errors.js'; +import lodash from 'lodash'; +const { times } = lodash; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; const INITIAL_ID = 300000; @@ -60,7 +62,8 @@ async function addManyMembersToExistingOrganization({ numberOfUsers }) { } } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const numberOfUsers = process.argv[2]; @@ -90,6 +93,4 @@ async function main() { } })(); -module.exports = { - addManyMembersToExistingOrganization, -}; +export { addManyMembersToExistingOrganization }; diff --git a/api/scripts/data-generation/add-many-students-to-sco-certification-center.js b/api/scripts/data-generation/add-many-students-to-sco-certification-center.js index c42401a3bad..ad4b76c90f9 100644 --- a/api/scripts/data-generation/add-many-students-to-sco-certification-center.js +++ b/api/scripts/data-generation/add-many-students-to-sco-certification-center.js @@ -1,9 +1,10 @@ -const _ = require('lodash'); -const { SCO_MIDDLE_SCHOOL_ID } = require('../../db/seeds/data/organizations-sco-builder'); -const OrganizationLearner = require('../../lib/domain/models/OrganizationLearner'); -const { OrganizationLearnersCouldNotBeSavedError } = require('../../lib/domain/errors'); -const DomainTransaction = require('../../lib/infrastructure/DomainTransaction'); -const { knex, disconnect } = require('../../db/knex-database-connection'); +import _ from 'lodash'; +import { SCO_MIDDLE_SCHOOL_ID } from '../../db/seeds/data/organizations-sco-builder.js'; +import { OrganizationLearner } from '../../lib/domain/models/OrganizationLearner.js'; +import { OrganizationLearnersCouldNotBeSavedError } from '../../lib/domain/errors.js'; +import { DomainTransaction } from '../../lib/infrastructure/DomainTransaction.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; function _buildOrganizationLearner(iteration) { const birthdates = ['2001-01-05', '2002-11-15', '1995-06-25']; @@ -28,7 +29,8 @@ async function addManyStudentsToScoCertificationCenter(numberOfStudents) { } } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting adding SCO students to certification center.'); @@ -53,6 +55,4 @@ async function main() { } })(); -module.exports = { - addManyStudentsToScoCertificationCenter, -}; +export { addManyStudentsToScoCertificationCenter }; diff --git a/api/scripts/data-generation/generate-campaign-with-participants.js b/api/scripts/data-generation/generate-campaign-with-participants.js index 09a170e5abd..acb4e70dae6 100644 --- a/api/scripts/data-generation/generate-campaign-with-participants.js +++ b/api/scripts/data-generation/generate-campaign-with-participants.js @@ -1,19 +1,24 @@ -require('dotenv').config({ path: `${__dirname}/../../.env` }); - -const _ = require('lodash'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const { learningContentCache: cache } = require('../../lib/infrastructure/caches/learning-content-cache'); -const moment = require('moment'); -const competenceRepository = require('../../lib/infrastructure/repositories/competence-repository'); -const skillRepository = require('../../lib/infrastructure/repositories/skill-repository'); -const campaignRepository = require('../../lib/infrastructure/repositories/campaign-repository'); -const CampaignParticipationStatuses = require('../../lib/domain/models/CampaignParticipationStatuses'); -const computeParticipationResults = require('../prod/compute-participation-results'); -const { +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../../.env` }); + +import _ from 'lodash'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { learningContentCache as cache } from '../../lib/infrastructure/caches/learning-content-cache.js'; +import moment from 'moment'; +import * as competenceRepository from '../../lib/infrastructure/repositories/competence-repository.js'; +import * as skillRepository from '../../lib/infrastructure/repositories/skill-repository.js'; +import * as campaignRepository from '../../lib/infrastructure/repositories/campaign-repository.js'; +import { CampaignParticipationStatuses } from '../../lib/domain/models/CampaignParticipationStatuses.js'; +import { computeParticipantResultsShared as computeParticipationResults } from '../prod/compute-participation-results.js'; +import { getEligibleCampaignParticipations, generateKnowledgeElementSnapshots, -} = require('../prod/generate-knowledge-element-snapshots-for-campaigns'); -const { generate } = require('../../lib/domain/services/campaigns/campaign-code-generator'); +} from '../prod/generate-knowledge-element-snapshots-for-campaigns.js'; +import { generate } from '../../lib/domain/services/campaigns/campaign-code-generator.js'; const { SHARED, TO_SHARE } = CampaignParticipationStatuses; @@ -539,7 +544,8 @@ async function generateCampaignWithParticipants({ ); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const commandLineArgs = process.argv.slice(2); @@ -574,4 +580,4 @@ async function main() { } })(); -module.exports = { generateCampaignWithParticipants }; +export { generateCampaignWithParticipants }; diff --git a/api/scripts/data-generation/generate-certif-cli.js b/api/scripts/data-generation/generate-certif-cli.js index 3715e2ffa37..3b33287fe9d 100755 --- a/api/scripts/data-generation/generate-certif-cli.js +++ b/api/scripts/data-generation/generate-certif-cli.js @@ -1,25 +1,33 @@ -#!/usr/bin/env node -'use strict'; -const inquirer = require('inquirer'); -require('dotenv').config({ path: `${__dirname}/../../.env` }); -const { knex, disconnect } = require(`../../db/knex-database-connection`); -const bluebird = require('bluebird'); -const maxBy = require('lodash/maxBy'); -const logger = require('../../lib/infrastructure/logger'); -const { getNewSessionCode } = require('../../lib/domain/services/session-code-service'); -const { temporaryStorage } = require('../../lib/infrastructure/temporary-storage/index'); -const { +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +// eslint-disable-next-line node/no-unpublished-import +import inquirer from 'inquirer'; +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../../.env` }); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import bluebird from 'bluebird'; +import lodash from 'lodash'; + +const { maxBy } = lodash; +import { logger } from '../../lib/infrastructure/logger.js'; +import { getNewSessionCode } from '../../lib/domain/services/session-code-service.js'; +import { temporaryStorage } from '../../lib/infrastructure/temporary-storage/index.js'; +import { makeUserPixCertifiable, makeUserPixDroitCertifiable, makeUserCleaCertifiable, makeUserPixEduCertifiable, -} = require('../../db/seeds/data/certification/tooling'); -const DatabaseBuilder = require('../../db/database-builder/database-builder'); -const databaseBuffer = require('../../db/database-builder/database-buffer'); -const databaseBuilder = new DatabaseBuilder({ knex, emptyFirst: false }); -const { learningContentCache } = require('../../lib/infrastructure/caches/learning-content-cache'); -const { SHARED } = require('../../lib/domain/models/CampaignParticipationStatuses'); +} from '../../db/seeds/data/certification/tooling.js'; +import { DatabaseBuilder } from '../../db/database-builder/database-builder.js'; +import { databaseBuffer } from '../../db/database-builder/database-buffer.js'; +import { learningContentCache } from '../../lib/infrastructure/caches/learning-content-cache.js'; +import { CampaignParticipationStatuses } from '../../lib/domain/models/CampaignParticipationStatuses.js'; + +const { SHARED } = CampaignParticipationStatuses; +const databaseBuilder = new DatabaseBuilder({ knex, emptyFirst: false }); /** * LOG_LEVEL=info ./scripts/data-generation/generate-certif-cli.js 'SUP' 1 '[{"candidateNumber": 1, "key": "EDU_1ER_DEGRE"}, {"candidateNumber": 1, "key": "EDU_2ND_DEGRE"}]' * LOG_LEVEL=info ./scripts/data-generation/generate-certif-cli.js 'PRO' 2 '[{"candidateNumber": 1, "key": "CLEA"}, {"candidateNumber": 2, "key": "DROIT"}]' @@ -390,6 +398,8 @@ async function _createUser({ firstName, lastName, birthdate, email, organization return { userId, organizationLearnerId }; } +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; if (process.argv.length > 2 && !isInTest) { const [centerType, candidateNumber, complementaryCertifications = '[]'] = process.argv.slice(2); @@ -403,7 +413,7 @@ if (process.argv.length > 2 && !isInTest) { throw error; }) .finally(_disconnect); -} else if (require.main === module) { +} else if (isLaunchedFromCommandLine) { inquirer .prompt(questions) .then(async (answers) => { @@ -416,11 +426,6 @@ if (process.argv.length > 2 && !isInTest) { throw error; }) .finally(_disconnect); -} else { - module.exports = { - main, - databaseBuilder, - }; } async function _disconnect() { @@ -431,3 +436,5 @@ async function _disconnect() { await temporaryStorage.quit(); logger.info('Exiting process gracefully...'); } + +export { main, databaseBuilder }; diff --git a/api/scripts/data-generation/generate-certifications-for-organization.js b/api/scripts/data-generation/generate-certifications-for-organization.js index c4be99470bf..81cfb560634 100644 --- a/api/scripts/data-generation/generate-certifications-for-organization.js +++ b/api/scripts/data-generation/generate-certifications-for-organization.js @@ -1,7 +1,8 @@ -const yargs = require('yargs'); -const _ = require('lodash'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const { competenceDatasource } = require('../../lib/infrastructure/datasources/learning-content/competence-datasource'); +import yargs from 'yargs'; +import _ from 'lodash'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { competenceDatasource } from '../../lib/infrastructure/datasources/learning-content/competence-datasource.js'; +import * as url from 'url'; const CERTIF_ERROR_RATE = 0.05; const CERTIF_REJECTED_RATE = 0.15; @@ -304,7 +305,8 @@ function _getChunkSize(objectToBeInserted) { return MAX_BINDED_PG; } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('DEBUT'); diff --git a/api/scripts/data-generation/seeds/dump-target-profile-data-as-seeds.js b/api/scripts/data-generation/seeds/dump-target-profile-data-as-seeds.js index 28a468e99ec..b48549e582b 100644 --- a/api/scripts/data-generation/seeds/dump-target-profile-data-as-seeds.js +++ b/api/scripts/data-generation/seeds/dump-target-profile-data-as-seeds.js @@ -1,9 +1,17 @@ -require('dotenv').config({ path: `${__dirname}/../../../.env` }); -const yargs = require('yargs'); -const { hideBin } = require('yargs/helpers'); -const { knex, disconnect } = require('../../../db/knex-database-connection'); -const logger = require('../../../lib/infrastructure/logger'); -const { learningContentCache } = require('../../../lib/infrastructure/caches/learning-content-cache'); +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; + +dotenv.config({ + path: `${__dirname}/../../../.env`, +}); +import yargs from 'yargs'; +import { hideBin } from 'yargs/helpers'; + +import { knex, disconnect } from '../../../db/knex-database-connection.js'; +import { logger } from '../../../lib/infrastructure/logger.js'; +import { learningContentCache } from '../../../lib/infrastructure/caches/learning-content-cache.js'; async function main() { try { @@ -138,10 +146,10 @@ function escapedOrNull(value) { return value === null ? null : `\`${value}\``; } -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +if (isLaunchedFromCommandLine) { main(); } -module.exports = { - doJob, -}; +export { doJob }; diff --git a/api/scripts/database/create-database.js b/api/scripts/database/create-database.js index 1b3084c4034..d07f52e2078 100644 --- a/api/scripts/database/create-database.js +++ b/api/scripts/database/create-database.js @@ -1,8 +1,8 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; dotenv.config(); -const logger = require('../../lib/infrastructure/logger'); -const PgClient = require('../PgClient'); -const { PGSQL_DUPLICATE_DATABASE_ERROR } = require('../../db/pgsql-errors'); +import { logger } from '../../lib/infrastructure/logger.js'; +import { PgClient } from '../PgClient.js'; +import { PGSQL_DUPLICATE_DATABASE_ERROR } from '../../db/pgsql-errors.js'; const dbUrl = process.env.NODE_ENV === 'test' ? process.env.TEST_DATABASE_URL : process.env.DATABASE_URL; diff --git a/api/scripts/database/drop-database.js b/api/scripts/database/drop-database.js index 43a1f8a130a..0ec253dea6b 100644 --- a/api/scripts/database/drop-database.js +++ b/api/scripts/database/drop-database.js @@ -1,8 +1,8 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; dotenv.config(); -const logger = require('../../lib/infrastructure/logger'); -const PgClient = require('../PgClient'); -const { PGSQL_NON_EXISTENT_DATABASE_ERROR } = require('../../db/pgsql-errors'); +import { logger } from '../../lib/infrastructure/logger.js'; +import { PgClient } from '../PgClient.js'; +import { PGSQL_NON_EXISTENT_DATABASE_ERROR } from '../../db/pgsql-errors.js'; function isPlatformScalingo() { return Boolean(process.env.CONTAINER); diff --git a/api/scripts/database/empty-database.js b/api/scripts/database/empty-database.js index b09d00735f9..e7d5baacb29 100644 --- a/api/scripts/database/empty-database.js +++ b/api/scripts/database/empty-database.js @@ -1,5 +1,5 @@ -const { emptyAllTables, disconnect } = require('../../db/knex-database-connection'); -const logger = require('../../lib/infrastructure/logger'); +import { emptyAllTables, disconnect } from '../../db/knex-database-connection.js'; +import { logger } from '../../lib/infrastructure/logger.js'; const main = async () => { logger.info('Emptying all tables...'); diff --git a/api/scripts/database/pg-boss-migration.js b/api/scripts/database/pg-boss-migration.js index d188d5434df..c4e54dc380a 100644 --- a/api/scripts/database/pg-boss-migration.js +++ b/api/scripts/database/pg-boss-migration.js @@ -1,8 +1,8 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; dotenv.config(); -const PgBoss = require('pg-boss'); -const logger = require('../../lib/infrastructure/logger'); -const { disconnect } = require('../../db/knex-database-connection'); +import PgBoss from 'pg-boss'; +import { logger } from '../../lib/infrastructure/logger.js'; +import { disconnect } from '../../db/knex-database-connection.js'; async function main() { console.log('run pgboss migrations'); diff --git a/api/scripts/database/restore-dump/download-backup.js b/api/scripts/database/restore-dump/download-backup.js index b7d2f01268f..3d4404d7577 100644 --- a/api/scripts/database/restore-dump/download-backup.js +++ b/api/scripts/database/restore-dump/download-backup.js @@ -1,10 +1,12 @@ -require('dotenv').config({ path: '../../../.env' }); +import * as dotenv from 'dotenv'; -const fs = require('fs'); -const Joi = require('joi'); -const ScalingoClient = require('./helpers/scalingo/scalingo-client'); -const logger = require('../../../lib/infrastructure/logger'); -const { disconnect } = require('../../../db/knex-database-connection'); +dotenv.config({ path: '../../../.env' }); + +import fs from 'fs'; +import Joi from 'joi'; +import { ScalingoClient } from './helpers/scalingo/scalingo-client.js'; +import { logger } from '../../../lib/infrastructure/logger.js'; +import { disconnect } from '../../../db/knex-database-connection.js'; const postgresDatabaseAddonProviderId = 'postgresql'; diff --git a/api/scripts/database/restore-dump/helpers/scalingo/db-client.js b/api/scripts/database/restore-dump/helpers/scalingo/db-client.js index 8543c3afdf1..1ba99cd7b60 100644 --- a/api/scripts/database/restore-dump/helpers/scalingo/db-client.js +++ b/api/scripts/database/restore-dump/helpers/scalingo/db-client.js @@ -1,7 +1,10 @@ -const axios = require('axios'); -const util = require('util'); -const fs = require('fs'); -const streamPipeline = util.promisify(require('stream').pipeline); +import axios from 'axios'; +import util from 'util'; +import fs from 'fs'; + +import pipeline from 'stream'; + +const streamPipeline = util.promisify(pipeline); class ScalingoDBClient { constructor(dbId, client) { @@ -52,4 +55,4 @@ class ScalingoDBClient { } } -module.exports = ScalingoDBClient; +export { ScalingoDBClient }; diff --git a/api/scripts/database/restore-dump/helpers/scalingo/scalingo-client.js b/api/scripts/database/restore-dump/helpers/scalingo/scalingo-client.js index 4db455e6279..e9d04956171 100644 --- a/api/scripts/database/restore-dump/helpers/scalingo/scalingo-client.js +++ b/api/scripts/database/restore-dump/helpers/scalingo/scalingo-client.js @@ -1,5 +1,5 @@ -const scalingo = require('scalingo'); -const ScalingoDBClient = require('./db-client'); +import scalingo from 'scalingo'; +import { ScalingoDBClient } from './db-client.js'; class ScalingoClient { constructor({ client, application, region }) { @@ -39,4 +39,4 @@ class ScalingoClient { } } -module.exports = ScalingoClient; +export { ScalingoClient }; diff --git a/api/scripts/delete-assessment.js b/api/scripts/delete-assessment.js index d16c34403d5..46a9269b5d2 100755 --- a/api/scripts/delete-assessment.js +++ b/api/scripts/delete-assessment.js @@ -1,6 +1,5 @@ -#! /usr/bin/env node -/* eslint no-console: ["off"] */ -const PgClient = require('./PgClient'); +import { PgClient } from './PgClient.js'; +import * as url from 'url'; async function initialize() { const client = await PgClient.getClient(process.env.DATABASE_URL); @@ -87,11 +86,10 @@ class ScriptQueryBuilder { /*=================== tests =============================*/ -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +if (isLaunchedFromCommandLine) { main(); } -module.exports = { - ScriptQueryBuilder, - AssessmentEraser, -}; +export { ScriptQueryBuilder, AssessmentEraser }; diff --git a/api/scripts/delete-user.js b/api/scripts/delete-user.js index 4ab28cb467e..a63364c35a1 100755 --- a/api/scripts/delete-user.js +++ b/api/scripts/delete-user.js @@ -1,6 +1,5 @@ -#! /usr/bin/env node -/* eslint no-console: ["off"] */ -const PgClient = require('./PgClient'); +import { PgClient } from './PgClient.js'; +import * as url from 'url'; async function initialize() { const client = await PgClient.getClient(process.env.DATABASE_URL); @@ -167,12 +166,10 @@ class ScriptQueryBuilder { /*=================== tests =============================*/ -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +if (isLaunchedFromCommandLine) { main(); } -module.exports = { - ScriptQueryBuilder, - ClientQueryAdapter, - UserEraser, -}; +export { ScriptQueryBuilder, ClientQueryAdapter, UserEraser }; diff --git a/api/scripts/extract-challenge-with-skills.js b/api/scripts/extract-challenge-with-skills.js index f50e46b3bcf..c692dee3fc5 100644 --- a/api/scripts/extract-challenge-with-skills.js +++ b/api/scripts/extract-challenge-with-skills.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const challengeRepository = require('../lib/infrastructure/repositories/challenge-repository'); -const skillsRepository = require('../lib/infrastructure/repositories/skill-repository'); -const competencesRepository = require('../lib/infrastructure/repositories/competence-repository'); +import _ from 'lodash'; +import * as challengeRepository from '../lib/infrastructure/repositories/challenge-repository.js'; +import * as skillsRepository from '../lib/infrastructure/repositories/skill-repository.js'; +import * as competencesRepository from '../lib/infrastructure/repositories/competence-repository.js'; async function findChallengesWithSkills() { const [challenges, skillsFromDb] = await _getReferentialData(); @@ -51,6 +51,7 @@ async function _getReferentialData() { // Récupération des acquis par compétences let skills = await Promise.all( _.map(competences, (competence) => { + // eslint-disable-next-line import/namespace return skillsRepository.findByCompetenceId(competence.id); }) ); @@ -144,4 +145,4 @@ function _createObjectInvalidatedInferred(skill) { }; } -module.exports = findChallengesWithSkills; +export { findChallengesWithSkills }; diff --git a/api/scripts/fill-campaign-participation-id-in-badge-acquisitions.js b/api/scripts/fill-campaign-participation-id-in-badge-acquisitions.js index 3cca1933000..8cb2a63c6e8 100644 --- a/api/scripts/fill-campaign-participation-id-in-badge-acquisitions.js +++ b/api/scripts/fill-campaign-participation-id-in-badge-acquisitions.js @@ -1,5 +1,6 @@ -const { knex, disconnect } = require('../db/knex-database-connection'); -const bluebird = require('bluebird'); +import { knex, disconnect } from '../db/knex-database-connection.js'; +import bluebird from 'bluebird'; +import * as url from 'url'; async function getAllBadgeAcquistionsWithoutCampaignParticipationId() { return knex('badge-acquisitions').select().where({ campaignParticipationId: null }); @@ -59,7 +60,8 @@ async function updateBadgeAcquisitionWithCampaignParticipationId(badgeAcquisitio ); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const badgeAcquisitionsWithoutCampaignParticipationId = await getAllBadgeAcquistionsWithoutCampaignParticipationId(); @@ -85,7 +87,7 @@ async function main() { } })(); -module.exports = { +export { main, getAllBadgeAcquistionsWithoutCampaignParticipationId, getCampaignParticipationFromBadgeAcquisition, diff --git a/api/scripts/fill-in-assessment-method.js b/api/scripts/fill-in-assessment-method.js index e1d97e7053a..890571216ea 100644 --- a/api/scripts/fill-in-assessment-method.js +++ b/api/scripts/fill-in-assessment-method.js @@ -1,8 +1,8 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; dotenv.config(); -const { knex } = require('../db/knex-database-connection'); -const logger = require('../lib/infrastructure/logger'); +import { knex } from '../db/knex-database-connection.js'; +import { logger } from '../lib/infrastructure/logger.js'; async function fillInAssessmentMethod() { const chunkSize = 50000; diff --git a/api/scripts/fill-score-level.js b/api/scripts/fill-score-level.js index de55b09e167..f18df8a2790 100755 --- a/api/scripts/fill-score-level.js +++ b/api/scripts/fill-score-level.js @@ -1,6 +1,5 @@ -#! /usr/bin/env node - -const request = require('request-promise-native'); +import request from 'request-promise-native'; +import * as url from 'url'; function parseArgs(argv) { return argv.slice(3); @@ -46,7 +45,10 @@ function main() { /*=================== tests =============================*/ -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; + +if (isLaunchedFromCommandLine) { console.log('Start script : '); main(); } diff --git a/api/scripts/fill-skill-id-in-user-saved-tutorials.js b/api/scripts/fill-skill-id-in-user-saved-tutorials.js index d65c52a28cd..59466f0b10f 100644 --- a/api/scripts/fill-skill-id-in-user-saved-tutorials.js +++ b/api/scripts/fill-skill-id-in-user-saved-tutorials.js @@ -1,13 +1,16 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const groupBy = require('lodash/groupBy'); -const { knex, disconnect } = require('../db/knex-database-connection'); -const UserSavedTutorial = require('../lib/domain/models/UserSavedTutorial'); -const KnowledgeElement = require('../lib/domain/models/KnowledgeElement'); -const UserSavedTutorialWithTutorial = require('../lib/domain/models/UserSavedTutorialWithTutorial'); -const knowledgeElementRepository = require('../lib/infrastructure/repositories/knowledge-element-repository'); -const { tutorialDatasource } = require('../lib/infrastructure/datasources/learning-content/tutorial-datasource'); -const { skillDatasource } = require('../lib/infrastructure/datasources/learning-content/skill-datasource'); +import lodash from 'lodash'; +const { groupBy } = lodash; +import { knex, disconnect } from '../db/knex-database-connection.js'; +import { UserSavedTutorial } from '../lib/domain/models/UserSavedTutorial.js'; +import { KnowledgeElement } from '../lib/domain/models/KnowledgeElement.js'; +import { UserSavedTutorialWithTutorial } from '../lib/domain/models/UserSavedTutorialWithTutorial.js'; +import * as knowledgeElementRepository from '../lib/infrastructure/repositories/knowledge-element-repository.js'; +import { tutorialDatasource } from '../lib/infrastructure/datasources/learning-content/tutorial-datasource.js'; +import { skillDatasource } from '../lib/infrastructure/datasources/learning-content/skill-datasource.js'; +import * as url from 'url'; async function getAllUserSavedTutorialsWithoutSkillId() { const userSavedTutorials = await knex('user-saved-tutorials').whereNull('skillId'); @@ -152,7 +155,8 @@ async function main() { console.log('End filling skillId to user saved tutorials'); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; (async () => { if (isLaunchedFromCommandLine) { @@ -167,7 +171,7 @@ const isLaunchedFromCommandLine = require.main === module; } })(); -module.exports = { +export { getAllUserSavedTutorialsWithoutSkillId, getAllTutorials, getAllSkills, diff --git a/api/scripts/get-next-commit-subject.js b/api/scripts/get-next-commit-subject.js index 5f6f2a8eef2..2c410f5d809 100644 --- a/api/scripts/get-next-commit-subject.js +++ b/api/scripts/get-next-commit-subject.js @@ -1,25 +1,4 @@ -/* - * IF message title: - * > Doesn't start with square brackets [] - * > Doesn't start with Merge branch - * > Doesn't start with Merge pull request - * > Doesn't start with # - * - * AND - * > branch name starts with AA-XXX-something (e.g. pi-123-branch-description) - * > branch name is not: - * > - dev - * > - master - * > - gh-pages - * > - release-xxx - * - * THEN - * > prepend the issue tag to the commit message - * - * My awesome commit -> [pi-123] My awesome commit - */ - -module.exports = function getNextCommitSubject(messageTitle, branchName) { +const getNextCommitSubject = function (messageTitle, branchName) { const startsWithBraces = (str) => str.match(/^\[[^\]]/); const startsWithMergeBranch = (str) => str.indexOf('Merge branch') === 0; const startsWithMergePR = (str) => str.indexOf('Merge pull request') === 0; @@ -57,3 +36,5 @@ module.exports = function getNextCommitSubject(messageTitle, branchName) { return messageTitle; } }; + +export { getNextCommitSubject }; diff --git a/api/scripts/helpers/csvHelpers.js b/api/scripts/helpers/csvHelpers.js index c7f7293c4fb..994b16bf7dc 100644 --- a/api/scripts/helpers/csvHelpers.js +++ b/api/scripts/helpers/csvHelpers.js @@ -1,10 +1,16 @@ -const fs = require('fs'); -const { readFile, access } = require('fs').promises; -const { difference, isEmpty } = require('lodash'); -const papa = require('papaparse'); +import fs from 'fs'; -const { NotFoundError, FileValidationError } = require('../../lib/domain/errors'); -const { UnprocessableEntityError } = require('../../lib/application/http-errors'); +const { difference, isEmpty } = lodash; + +const { promises } = fs; + +const { readFile, access } = promises; + +import lodash from 'lodash'; +import papa from 'papaparse'; + +import { NotFoundError, FileValidationError } from '../../lib/domain/errors.js'; +import { UnprocessableEntityError } from '../../lib/application/http-errors.js'; const ERRORS = { INVALID_FILE_EXTENSION: 'INVALID_FILE_EXTENSION', @@ -111,7 +117,7 @@ async function parseCsvWithHeaderAndRequiredFields({ filePath, requiredFieldName return csvData; } -module.exports = { +export { checkCsvHeader, readCsvFile, parseCsvData, diff --git a/api/scripts/helpers/organizations-by-external-id-helper.js b/api/scripts/helpers/organizations-by-external-id-helper.js index afcf06ff8e2..a414fadeb68 100644 --- a/api/scripts/helpers/organizations-by-external-id-helper.js +++ b/api/scripts/helpers/organizations-by-external-id-helper.js @@ -1,4 +1,4 @@ -const organizationRepository = require('../../lib/infrastructure/repositories/organization-repository'); +import * as organizationRepository from '../../lib/infrastructure/repositories/organization-repository.js'; function organizeOrganizationsByExternalId(organizations) { const organizationsByExternalId = {}; @@ -12,14 +12,11 @@ function organizeOrganizationsByExternalId(organizations) { return organizationsByExternalId; } -function findOrganizationsByExternalIds({ checkedData }) { +function findOrganizationsByExternalIds({ checkedData }, injectedOrganizationRepository = organizationRepository) { const externalIds = checkedData.map((data) => data.externalId); - return organizationRepository.findByExternalIdsFetchingIdsOnly(externalIds).then((organizations) => { + return injectedOrganizationRepository.findByExternalIdsFetchingIdsOnly(externalIds).then((organizations) => { return organizations.map((organization) => ({ id: organization.id, externalId: organization.externalId })); }); } -module.exports = { - findOrganizationsByExternalIds, - organizeOrganizationsByExternalId, -}; +export { findOrganizationsByExternalIds, organizeOrganizationsByExternalId }; diff --git a/api/scripts/logo/default-sco-agri-organization-logo-base64.js b/api/scripts/logo/default-sco-agri-organization-logo-base64.js index 88da01b215d..e6c0dfa755f 100644 --- a/api/scripts/logo/default-sco-agri-organization-logo-base64.js +++ b/api/scripts/logo/default-sco-agri-organization-logo-base64.js @@ -1,2 +1,4 @@ -module.exports = +const logoUrl = ''; + +export { logoUrl }; diff --git a/api/scripts/logo/default-sco-organization-logo-base64.js b/api/scripts/logo/default-sco-organization-logo-base64.js index 2cfc5d0e663..2c0f3c63330 100644 --- a/api/scripts/logo/default-sco-organization-logo-base64.js +++ b/api/scripts/logo/default-sco-organization-logo-base64.js @@ -1,2 +1,3 @@ -module.exports = +const logoUrl = ''; +export { logoUrl }; diff --git a/api/scripts/make-saml-env.js b/api/scripts/make-saml-env.js index 0cf772291cd..85b48ed9124 100644 --- a/api/scripts/make-saml-env.js +++ b/api/scripts/make-saml-env.js @@ -1,164 +1,8 @@ -/* +import fs from 'fs'; -# Configuration des variables d'environnement pour l'intégration SAML +const { promises } = fs; -Pix (API) utilise les variables d'environnement suivantes pour configurer -l'intégration avec un fournisseur d'identité SAML : - -## `SAML_SP_CONFIG` - -Contient un JSON décrivant (au format attendu par `samlify`) la configuration -de Pix en tant que "Service provider". - -Exemple de JSON (à mettre sur une seule ligne dans la variable d'environnement): - -``` -{ - "metadata": "", - "encPrivateKey": "-----BEGIN RSA PRIVATE KEY-----\n…\n-----END RSA PRIVATE KEY-----\n", - "relayState": "https://…" -} -``` - -Détails des clés du JSON (référence : https://samlify.js.org/#/configuration) : - - * `metadata`: métadonnées du _Service Provider_ qui seront . - * Le fournisseur d'identité utilisera ces métadonnées (servies telles quelles - sur `/api/saml/metadata.xml`pour accepter les demandes d'authentification - de Pix et générer des assertions SAML. - * L'implémentation SAML dans Pix (basée sur `samlify`) utilise également ces - métadonnées pour se configurer. - - * `encPrivateKey`: clé privée associée au certificat contenu dans les métadonnées - ci-dessus (élément X509Certificate). - - * `relayState`: paramètre qui sera ajouté aux demandes d'authentification envoyées - par Pix au fournisseur d'identité. Dans le cadre du GAR, ce paramètre doit absolument - contenir l'"URL de la ressource" (telle qu'indiquée dans la notice ScoLomFR) - sous peine de faire échouer l'authentification. - -## `SAML_IDP_CONFIG` - -Un JSON également, utilisé cette fois pour configurer le modèle du fournisseur -d'identité utilisé par `samlify` pour générer des demandes d'authentification et -interpréter les assertions. - -Exemple de JSON : - -``` -{ - "metadata":"", -} -``` - -On retrouve une clé `metadata` dans laquelle il faut inclure les métadonnées fournies par le -fournisseur d'identité. Par exemple pour le GAR en pré-production elles sont disponibles -à l'adresse https://idp-auth.partenaire.test-gar.education.fr/idp/metadata. - -Ces métadonnées sont utilisées pour configurer `samlify` ; les éléments importants sont les -certificats et l'adresse du _binding_ `HTTP-Redirect` du `SingleSignOnService`. - -Si le XML des métadonnées est trop gros pour tenir dans la variable d'environnement, il est donc -permis de ne garder que ces éléments. - -Les autres clés du JSON permettent de configurer `samlify` (cf. https://samlify.js.org/#/configuration) -pour les paramètres qui ne pourraient pas être déduits des métadonnées. - -Par exemple, nous avons constaté que pour l'intégration avec https://samlidp.io il fallait ajouter -les options suivantes : - -``` - "isAssertionEncrypted": true, - "messageSigningOrder": "encrypt-then-sign" -``` - -Pour le GAR en revanche, l'intégration semble fonctionner avec uniquement `metadata`. - -## `SAML_ATTRIBUTE_MAPPING` - -Cette variable contient encore un JSON, qui permet de configurer un mapping entre les attributs -utilisateur fournis par le fournisseur d'identité, et les champs du modèle `User` de Pix. - -Exemple : - -``` -{ - samlId: 'IDO', - firstName: 'PRE', - lastName: 'NOM', -} -``` - -# Génération du certificat de _service provider_ - -``` -openssl genrsa -out private.key 1024 -openssl req -new -x509 -key privatekey.pem -out publickey.cer -days 365 -``` - -Le contenu de `publickey.cer` (sans les lignes `BEGIN CERTIFICATE` ni `END CERTIFICATE`) -peut être utilisé dans l'élément `X509Certificate` des métadonnées de _service provider_. - -Le contenu de privatekey.pem (en gardant les lignes `BEGIN…` et `END…`) est à copier dans -la propriété `encPrivateKey` de `SAML_SP_CONFIG`. - -# Exemple de métadonnées de _service provider_ - -``` - - - - - - MIICCzCCAXQCCQD2MlHh/QmGmjANBgkqhkiG9w0BAQsFADBKMQswCQYDVQQGEwJGUjEPMA0GA1UECAwGRlJBTkNFMQ4wDAYDVQQHDAVQQVJJUzEMMAoGA1UECgwDUElYMQwwCgYDVQQLDANERVYwHhcNMTgxMDIyMTQ1MjQ5WhcNMTkxMDIyMTQ1MjQ5WjBKMQswCQYDVQQGEwJGUjEPMA0GA1UECAwGRlJBTkNFMQ4wDAYDVQQHDAVQQVJJUzEMMAoGA1UECgwDUElYMQwwCgYDVQQLDANERVYwgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAMbY6nVh9GjtlyIm6KxQ8p+2dOE+wWTRq6Kg/481ovarmJWyW10LgZirfUvKrLqK5OdJ9+svOl2/JokF8ckOQmR/VWtuwcb6EvEfIMgLwQGZYKIPrdGN56BcY0+aprp8SIMfsrtR+NrWp0QJIRc6aWd5WWQybKNwFeGz2WIWzQXRAgMBAAEwDQYJKoZIhvcNAQELBQADgYEACRHKc85tMIANiX+4agaZFPluqoo2cjk6ph6FAigNuIZZr6mEAVCUh8Pmh5fQzUP9vl6Baqw+x5RBIw919OwzwcMCN3hNTi2k4oO4Kua/DJ/1fWJRqfnAZU3M6Y7Tfjfg7yhSkHuPYVew4SHMtWSYEkP0opnxjXIiBWfhpDY8EuE= - - - - - - - urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress - - - - -``` - -Éléments notables / à personnaliser : - * L'attribut `entityID` de `EntityDescriptor` sera utilisé pour identifier ce _service provider_ - au sein du fournisseur d'identité. Le GAR exige que cet attribut ait pour valeur l'URL - où sont servies les métadonnées, soit https://…/api/saml/metadata.xml pour une instance - Pix. - * Le certificat X.509 dans `X509Certificate` doit correspondre à la clé privée contenue dans - `encPrivateKey` (voir plus haut comment le générer). Il faut bien entendu utiliser un - couple certificat/clé privée différent entre l'intégration et la production. - * L'attribut `Location` de `AssertionConsumerService` indique au fournisseur d'identité - où poster les assertions. Il doit correspondre à l'URL de l'application cible et se - terminer par `/api/saml/assert`. - * De même l'attribut `Location` de `SingleLogoutService` désigne le service de consommation - de requêtes de déconnexion, mais il n'est pas actuellement implémenté. - -# Utilisation du script `make-saml-env.js` - -La syntaxe d'une valeur de variable d'environnement contenant du XML à -l'intérieur d'un object JSON étant délicate à maintenir, ce script permet de -générer les valeurs de `SAML_SP_CONFIG` et `SAML_IDP_CONFIG` à partir de -fichiers XML. - -Le mode d'utilisation est le suivant : - * Créer dans le répertoire courant : - * un fichier `metadata_sp.xml` contenant les métadonnées du _service provider_ (voir plus haut) ; - * un fichier `metadata_idp.xml` contenant les métadonnées de l'_identity provider_ ; - * un ficher `privatekey.pem` contenant la clé privée du certificat du _service provider_. - * Lancer le script `make-saml-env.js` : deux lignes (un peu longues…) sont générées sur - la console ; - * Si besoin, ajouter les options nécessaires dans le JSON généré (ex. pour le GAR, `relayState`) ; - * Copier ces deux lignes dans la configuration de variables d'environnement de l'application - cible. - -*/ - -const { readFile } = require('fs').promises; +const { readFile } = promises; function readXml(filename) { return readFile(filename, 'utf-8').replace(/^\s+|\s+$|\n/gm, ''); diff --git a/api/scripts/mark-users-for-TermsOfService-revalidation.js b/api/scripts/mark-users-for-TermsOfService-revalidation.js index 4d761a4f97c..0414f98b2b8 100644 --- a/api/scripts/mark-users-for-TermsOfService-revalidation.js +++ b/api/scripts/mark-users-for-TermsOfService-revalidation.js @@ -1,4 +1,5 @@ -const { knex, disconnect } = require('../db/knex-database-connection'); +import { knex, disconnect } from '../db/knex-database-connection.js'; +import * as url from 'url'; async function markUsersRequiringTermsOfServiceValidationForRevalidation() { const subquery = knex.select('users.id').from('users').where({ @@ -13,7 +14,8 @@ async function markUsersRequiringTermsOfServiceValidationForRevalidation() { return result.map(({ id }) => id); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log( @@ -39,6 +41,4 @@ async function main() { } })(); -module.exports = { - markUsersRequiringTermsOfServiceValidationForRevalidation, -}; +export { markUsersRequiringTermsOfServiceValidationForRevalidation }; diff --git a/api/scripts/populate-organizations-email.js b/api/scripts/populate-organizations-email.js index 3082fafea38..fe310af020f 100644 --- a/api/scripts/populate-organizations-email.js +++ b/api/scripts/populate-organizations-email.js @@ -1,7 +1,8 @@ -const bluebird = require('bluebird'); -const { disconnect } = require('../db/knex-database-connection'); -const { parseCsvWithHeader } = require('../scripts/helpers/csvHelpers'); -const BookshelfOrganization = require('../lib/infrastructure/orm-models/Organization'); +import bluebird from 'bluebird'; +import { disconnect } from '../db/knex-database-connection.js'; +import { parseCsvWithHeader } from '../scripts/helpers/csvHelpers.js'; +import { BookshelfOrganization } from '../lib/infrastructure/orm-models/Organization.js'; +import * as url from 'url'; async function updateOrganizationEmailByExternalId(externalId, email) { return BookshelfOrganization.where({ externalId }) @@ -21,7 +22,8 @@ async function populateOrganizations(objectsFromFile) { }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log("Start populating organization's email"); @@ -54,4 +56,4 @@ async function main() { } })(); -module.exports = populateOrganizations; +export { populateOrganizations }; diff --git a/api/scripts/prod/archive-campaigns.js b/api/scripts/prod/archive-campaigns.js index 29775867786..ad3f40c2ade 100644 --- a/api/scripts/prod/archive-campaigns.js +++ b/api/scripts/prod/archive-campaigns.js @@ -1,9 +1,10 @@ -const { parseCsvWithHeader } = require('../helpers/csvHelpers'); -const archiveCampaignFromCampaignCode = require('../../lib/domain/usecases/archive-campaign-from-campaign-code'); -const campaignForArchivingRepository = require('../../lib/infrastructure/repositories/campaign/campaign-for-archiving-repository'); -const bluebird = require('bluebird'); -const ProgressionLogger = require('../../lib/infrastructure/utils/progression-logger'); -const { disconnect } = require('../../db/knex-database-connection'); +import { parseCsvWithHeader } from '../helpers/csvHelpers.js'; +import { archiveCampaignFromCampaignCode } from '../../lib/domain/usecases/archive-campaign-from-campaign-code.js'; +import * as campaignForArchivingRepository from '../../lib/infrastructure/repositories/campaign/campaign-for-archiving-repository.js'; +import bluebird from 'bluebird'; +import { ProgressionLogger } from '../../lib/infrastructure/utils/progression-logger.js'; +import { disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; async function archiveCampaign(campaignData, logger) { try { @@ -29,7 +30,8 @@ async function archiveCampaigns(file, logger, concurrency = 1) { logger.log('DONE'); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const logger = new ProgressionLogger(process.stdout); @@ -49,4 +51,4 @@ async function main() { } })(); -module.exports = archiveCampaigns; +export { archiveCampaigns }; diff --git a/api/scripts/prod/compute-badge-acquisitions.js b/api/scripts/prod/compute-badge-acquisitions.js index 125a254fa23..0373879d9f5 100644 --- a/api/scripts/prod/compute-badge-acquisitions.js +++ b/api/scripts/prod/compute-badge-acquisitions.js @@ -1,17 +1,22 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { performance } = require('perf_hooks'); -const yargs = require('yargs/yargs'); -const { hideBin } = require('yargs/helpers'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const CampaignParticipation = require('../../lib/domain/models/CampaignParticipation'); -const logger = require('../../lib/infrastructure/logger'); -const badgeAcquisitionRepository = require('../../lib/infrastructure/repositories/badge-acquisition-repository'); -const badgeForCalculationRepository = require('../../lib/infrastructure/repositories/badge-for-calculation-repository'); -const knowledgeElementRepository = require('../../lib/infrastructure/repositories/knowledge-element-repository'); -const { cache } = require('../../lib/infrastructure/caches/learning-content-cache'); +import _ from 'lodash'; +import bluebird from 'bluebird'; +import perf_hooks from 'perf_hooks'; + +const { performance } = perf_hooks; + +import yargs from 'yargs/yargs'; +import { hideBin } from 'yargs/helpers'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { CampaignParticipation } from '../../lib/domain/models/CampaignParticipation.js'; +import { logger } from '../../lib/infrastructure/logger.js'; +import * as badgeAcquisitionRepository from '../../lib/infrastructure/repositories/badge-acquisition-repository.js'; +import * as badgeForCalculationRepository from '../../lib/infrastructure/repositories/badge-for-calculation-repository.js'; +import * as knowledgeElementRepository from '../../lib/infrastructure/repositories/knowledge-element-repository.js'; +import { learningContentCache as cache } from '../../lib/infrastructure/caches/learning-content-cache.js'; +import * as url from 'url'; const MAX_RANGE_SIZE = 100_000; @@ -133,8 +138,8 @@ async function getCampaignParticipationsBetweenIds({ idMin, idMax }) { return campaignParticipations.map((campaignParticipation) => new CampaignParticipation(campaignParticipation)); } -const isLaunchedFromCommandLine = require.main === module; - +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; (async () => { if (isLaunchedFromCommandLine) { try { @@ -149,9 +154,4 @@ const isLaunchedFromCommandLine = require.main === module; } })(); -module.exports = { - normalizeRange, - computeAllBadgeAcquisitions, - computeBadgeAcquisition, - getCampaignParticipationsBetweenIds, -}; +export { normalizeRange, computeAllBadgeAcquisitions, computeBadgeAcquisition, getCampaignParticipationsBetweenIds }; diff --git a/api/scripts/prod/compute-participation-results.js b/api/scripts/prod/compute-participation-results.js index ec394492e2c..42d423b8071 100644 --- a/api/scripts/prod/compute-participation-results.js +++ b/api/scripts/prod/compute-participation-results.js @@ -1,16 +1,22 @@ // Usage: node compute-participation-results.js -require('dotenv').config({ path: `${__dirname}/../../.env` }); -const knowlegeElementSnapshotRepository = require('../../lib/infrastructure/repositories/knowledge-element-snapshot-repository'); -const campaignRepository = require('../../lib/infrastructure/repositories/campaign-repository'); -const ParticipantResultsShared = require('../../lib/domain/models/ParticipantResultsShared'); -const CampaignParticipationStatuses = require('../../lib/domain/models/CampaignParticipationStatuses'); +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../../.env` }); +import * as knowlegeElementSnapshotRepository from '../../lib/infrastructure/repositories/knowledge-element-snapshot-repository.js'; +import * as campaignRepository from '../../lib/infrastructure/repositories/campaign-repository.js'; +import { ParticipantResultsShared } from '../../lib/domain/models/ParticipantResultsShared.js'; +import { CampaignParticipationStatuses } from '../../lib/domain/models/CampaignParticipationStatuses.js'; + const { SHARED } = CampaignParticipationStatuses; -const { knex, disconnect } = require('../../db/knex-database-connection'); -const _ = require('lodash'); -const bluebird = require('bluebird'); -const { constants } = require('../../lib/infrastructure/constants'); -const placementProfileService = require('../../lib/domain/services/placement-profile-service'); -const competenceRepository = require('../../lib/infrastructure/repositories/competence-repository'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import _ from 'lodash'; +import bluebird from 'bluebird'; +import { constants } from '../../lib/infrastructure/constants.js'; +import * as placementProfileService from '../../lib/domain/services/placement-profile-service.js'; +import * as competenceRepository from '../../lib/infrastructure/repositories/competence-repository.js'; const concurrency = parseInt(process.argv[2]); let count; @@ -141,7 +147,8 @@ function _toSQLValuesWithIsCertifiable(participantsResults) { .join(', '); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { await computeParticipantResultsShared(concurrency); @@ -161,4 +168,4 @@ async function main() { } })(); -module.exports = computeParticipantResultsShared; +export { computeParticipantResultsShared }; diff --git a/api/scripts/prod/create-assessment-campaigns-for-sco.js b/api/scripts/prod/create-assessment-campaigns-for-sco.js index 98c7bd7e44e..986912ccddf 100644 --- a/api/scripts/prod/create-assessment-campaigns-for-sco.js +++ b/api/scripts/prod/create-assessment-campaigns-for-sco.js @@ -1,13 +1,12 @@ -// Usage: node create-assessment-campaigns.js path/file.csv -// To use on file with columns |targetProfileId, name, externalId, title, customLandingPageText, creatorId|, those headers included -const bluebird = require('bluebird'); -const _ = require('lodash'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const CampaignTypes = require('../../lib/domain/models/CampaignTypes'); -const campaignCodeGenerator = require('../../lib/domain/services/campaigns/campaign-code-generator'); -const campaignValidator = require('../../lib/domain/validators/campaign-validator'); -const campaignRepository = require('../../lib/infrastructure/repositories/campaign-repository'); -const { parseCsvWithHeader } = require('../helpers/csvHelpers'); +import bluebird from 'bluebird'; +import _ from 'lodash'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { CampaignTypes } from '../../lib/domain/models/CampaignTypes.js'; +import * as campaignCodeGenerator from '../../lib/domain/services/campaigns/campaign-code-generator.js'; +import * as campaignValidator from '../../lib/domain/validators/campaign-validator.js'; +import * as campaignRepository from '../../lib/infrastructure/repositories/campaign-repository.js'; +import { parseCsvWithHeader } from '../helpers/csvHelpers.js'; +import * as url from 'url'; function checkData(csvData) { return csvData.map(({ targetProfileId, name, externalId, title, customLandingPageText, creatorId }) => { @@ -47,7 +46,7 @@ async function prepareCampaigns(campaignsData) { campaignValidator.validate(campaign); campaign.code = await campaignCodeGenerator.generate(campaignRepository); - if (require.main === module) + if (isLaunchedFromCommandLine) process.stdout.write(`Campagne ${campaign.name} pour l'organisation ${campaign.organizationId} ===> ✔\n`); return campaign; }); @@ -72,7 +71,8 @@ function createAssessmentCampaignsForSco(campaigns) { return knex.batchInsert('campaigns', campaigns); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const filePath = process.argv[2]; @@ -105,8 +105,4 @@ async function main() { } })(); -module.exports = { - prepareCampaigns, - checkData, - getByExternalIdFetchingIdOnly, -}; +export { prepareCampaigns, checkData, getByExternalIdFetchingIdOnly }; diff --git a/api/scripts/prod/create-organization-places-lot.js b/api/scripts/prod/create-organization-places-lot.js index e58ca77ae69..7f0a88ee441 100644 --- a/api/scripts/prod/create-organization-places-lot.js +++ b/api/scripts/prod/create-organization-places-lot.js @@ -1,9 +1,9 @@ -// Usage: node create-organization-places-lot.js path/file.csv -// To use on file with columns |createdBy, organizationId, count, category, reference, activationDate, expirationDate|, those headers included -const { knex, disconnect } = require('../../db/knex-database-connection'); -const { parseCsvWithHeader } = require('../helpers/csvHelpers'); -const OrganizationPlacesLot = require('../../lib/domain/models/OrganizationPlacesLot'); -const categories = require('../../lib/domain/constants/organization-places-categories'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { parseCsvWithHeader } from '../helpers/csvHelpers.js'; +import { OrganizationPlacesLot } from '../../lib/domain/models/OrganizationPlacesLot.js'; +import * as categories from '../../lib/domain/constants/organization-places-categories.js'; +import * as url from 'url'; + const categoriesByCode = { [categories.T0]: categories.FREE_RATE, [categories.T1]: categories.PUBLIC_RATE, @@ -13,6 +13,7 @@ const categoriesByCode = { }; let logEnable; + async function prepareOrganizationPlacesLot(organizationPlacesLotData, log = true) { logEnable = log; const organizationPlacesLot = organizationPlacesLotData.map( @@ -44,7 +45,8 @@ function createOrganizationPlacesLots(organizationPlacesLot) { return knex.batchInsert('organization-places', organizationPlacesLot); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const filePath = process.argv[2]; @@ -85,6 +87,4 @@ function _log(message) { } } -module.exports = { - prepareOrganizationPlacesLot, -}; +export { prepareOrganizationPlacesLot }; diff --git a/api/scripts/prod/create-profiles-collection-campaigns.js b/api/scripts/prod/create-profiles-collection-campaigns.js index c3a9caa1e21..9007d127bf0 100644 --- a/api/scripts/prod/create-profiles-collection-campaigns.js +++ b/api/scripts/prod/create-profiles-collection-campaigns.js @@ -1,12 +1,11 @@ -// Usage: node create-profile-collection-campaigns.js path/file.csv -// To use on file with columns |name, organizationId, customLandingPageText, creatorId|, those headers included -const bluebird = require('bluebird'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const CampaignTypes = require('../../lib/domain/models/CampaignTypes'); -const campaignCodeGenerator = require('../../lib/domain/services/campaigns/campaign-code-generator'); -const campaignValidator = require('../../lib/domain/validators/campaign-validator'); -const campaignRepository = require('../../lib/infrastructure/repositories/campaign-repository'); -const { parseCsvWithHeader } = require('../helpers/csvHelpers'); +import bluebird from 'bluebird'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { CampaignTypes } from '../../lib/domain/models/CampaignTypes.js'; +import * as campaignCodeGenerator from '../../lib/domain/services/campaigns/campaign-code-generator.js'; +import * as campaignValidator from '../../lib/domain/validators/campaign-validator.js'; +import * as campaignRepository from '../../lib/infrastructure/repositories/campaign-repository.js'; +import { parseCsvWithHeader } from '../helpers/csvHelpers.js'; +import * as url from 'url'; function checkData(campaignData) { return campaignData.map(({ name, organizationId, customLandingPageText, creatorId }, index) => { @@ -44,7 +43,7 @@ async function prepareCampaigns(campaignsData) { campaign.code = await campaignCodeGenerator.generate(campaignRepository, generatedList); generatedList.push(campaign.code); - if (require.main === module) + if (isLaunchedFromCommandLine) process.stdout.write( `Campagne de collecte de profils ${campaign.name} pour l'organisation ${campaign.organizationId} ===> ✔\n` ); @@ -60,7 +59,8 @@ function createProfilesCollectionCampaigns(campaigns) { return knex.batchInsert('campaigns', campaigns); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const filePath = process.argv[2]; @@ -93,7 +93,4 @@ async function main() { } })(); -module.exports = { - prepareCampaigns, - checkData, -}; +export { prepareCampaigns, checkData }; diff --git a/api/scripts/prod/generate-knowledge-element-snapshots-for-campaigns.js b/api/scripts/prod/generate-knowledge-element-snapshots-for-campaigns.js index 9f0a072fdd1..f5c670ea37f 100644 --- a/api/scripts/prod/generate-knowledge-element-snapshots-for-campaigns.js +++ b/api/scripts/prod/generate-knowledge-element-snapshots-for-campaigns.js @@ -1,9 +1,10 @@ -const yargs = require('yargs'); -const bluebird = require('bluebird'); -const { knex, disconnect } = require('../../db/knex-database-connection'); -const knowledgeElementRepository = require('../../lib/infrastructure/repositories/knowledge-element-repository'); -const knowledgeElementSnapshotRepository = require('../../lib/infrastructure/repositories/knowledge-element-snapshot-repository'); -const { AlreadyExistingEntityError } = require('../../lib/domain/errors'); +import yargs from 'yargs'; +import bluebird from 'bluebird'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as knowledgeElementRepository from '../../lib/infrastructure/repositories/knowledge-element-repository.js'; +import * as knowledgeElementSnapshotRepository from '../../lib/infrastructure/repositories/knowledge-element-snapshot-repository.js'; +import { AlreadyExistingEntityError } from '../../lib/domain/errors.js'; +import * as url from 'url'; const DEFAULT_MAX_SNAPSHOT_COUNT = 5000; const DEFAULT_CONCURRENCY = 3; @@ -60,14 +61,21 @@ async function getEligibleCampaignParticipations(maxSnapshotCount) { .limit(maxSnapshotCount); } -async function generateKnowledgeElementSnapshots(campaignParticipationData, concurrency) { +async function generateKnowledgeElementSnapshots( + campaignParticipationData, + concurrency, + dependencies = { knowledgeElementRepository, knowledgeElementSnapshotRepository } +) { return bluebird.map( campaignParticipationData, async (campaignParticipation) => { const { userId, sharedAt } = campaignParticipation; - const knowledgeElements = await knowledgeElementRepository.findUniqByUserId({ userId, limitDate: sharedAt }); + const knowledgeElements = await dependencies.knowledgeElementRepository.findUniqByUserId({ + userId, + limitDate: sharedAt, + }); try { - await knowledgeElementSnapshotRepository.save({ userId, snappedAt: sharedAt, knowledgeElements }); + await dependencies.knowledgeElementSnapshotRepository.save({ userId, snappedAt: sharedAt, knowledgeElements }); } catch (err) { if (!(err instanceof AlreadyExistingEntityError)) { throw err; @@ -78,7 +86,8 @@ async function generateKnowledgeElementSnapshots(campaignParticipationData, conc ); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const commandLineArgs = yargs @@ -114,7 +123,4 @@ async function main() { } })(); -module.exports = { - getEligibleCampaignParticipations, - generateKnowledgeElementSnapshots, -}; +export { getEligibleCampaignParticipations, generateKnowledgeElementSnapshots }; diff --git a/api/scripts/prod/hide-skills-in-csv-export.js b/api/scripts/prod/hide-skills-in-csv-export.js index d94e2ef5f22..e217f43c982 100644 --- a/api/scripts/prod/hide-skills-in-csv-export.js +++ b/api/scripts/prod/hide-skills-in-csv-export.js @@ -1,10 +1,12 @@ -const { knex, disconnect } = require('../../db/knex-database-connection'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; async function hideSkills() { await knex('organizations').where('showSkills', true).update({ showSkills: false }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { await hideSkills(); @@ -23,6 +25,4 @@ async function main() { } })(); -module.exports = { - hideSkills, -}; +export { hideSkills }; diff --git a/api/scripts/prod/select-category-for-target-profiles.js b/api/scripts/prod/select-category-for-target-profiles.js index f76d67f1d96..ce74a1e12c9 100644 --- a/api/scripts/prod/select-category-for-target-profiles.js +++ b/api/scripts/prod/select-category-for-target-profiles.js @@ -1,16 +1,14 @@ -#! /usr/bin/env node -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const bluebird = require('bluebird'); -const groupBy = require('lodash/groupBy'); -const sum = require('lodash/sum'); -const has = require('lodash/has'); -const partition = require('lodash/partition'); -const negate = require('lodash/negate'); +import bluebird from 'bluebird'; +import lodash from 'lodash'; +const { groupBy, sum, has, partition, negate } = lodash; -const { readCsvFile, parseCsvData } = require('../helpers/csvHelpers'); -const { categories } = require('../../lib/domain/models/TargetProfile'); -const { knex, disconnect } = require('../../db/knex-database-connection'); +import { readCsvFile, parseCsvData } from '../helpers/csvHelpers.js'; +import { categories } from '../../lib/domain/models/TargetProfile.js'; +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; const TARGET_PROFILE_ID_COLUMN = 'targetProfileId'; const CATEGORY_COLUMN = 'category'; @@ -58,7 +56,8 @@ function _isSupportedCategory(category) { return supportedCategories.includes(category); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting script select-category-for-target-profiles'); @@ -95,7 +94,4 @@ async function main() { } })(); -module.exports = { - setCategoriesToTargetProfiles, - setCategoryToTargetProfiles, -}; +export { setCategoriesToTargetProfiles, setCategoryToTargetProfiles }; diff --git a/api/scripts/prod/swap-campaign-codes.js b/api/scripts/prod/swap-campaign-codes.js index 79ef20d76e2..19a3740f550 100644 --- a/api/scripts/prod/swap-campaign-codes.js +++ b/api/scripts/prod/swap-campaign-codes.js @@ -1,8 +1,8 @@ -const { knex } = require('../../db/knex-database-connection'); -const { generate } = require('../../lib/domain/services/campaigns/campaign-code-generator'); -const DomainTransaction = require('../../lib/infrastructure/DomainTransaction'); -const campaignRepository = require('../../lib/infrastructure/repositories/campaign-repository'); -const { disconnect } = require('../../db/knex-database-connection'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import { generate } from '../../lib/domain/services/campaigns/campaign-code-generator.js'; +import { DomainTransaction } from '../../lib/infrastructure/DomainTransaction.js'; +import * as campaignRepository from '../../lib/infrastructure/repositories/campaign-repository.js'; +import * as url from 'url'; async function swapCampaignCodes(campaignId, otherCampaignId) { const temporaryCode = await generate(campaignRepository); @@ -16,7 +16,8 @@ async function swapCampaignCodes(campaignId, otherCampaignId) { }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; (async () => { if (isLaunchedFromCommandLine) { @@ -32,4 +33,4 @@ const isLaunchedFromCommandLine = require.main === module; } })(); -module.exports = { swapCampaignCodes }; +export { swapCampaignCodes }; diff --git a/api/scripts/prod/target-profile-migrations/common.js b/api/scripts/prod/target-profile-migrations/common.js index b9922318559..db971707fcd 100644 --- a/api/scripts/prod/target-profile-migrations/common.js +++ b/api/scripts/prod/target-profile-migrations/common.js @@ -1,41 +1,42 @@ -const _ = require('lodash'); +import _ from 'lodash'; +import * as skillRepository from '../../../lib/infrastructure/repositories/skill-repository.js'; +import * as tubeRepository from '../../../lib/infrastructure/repositories/tube-repository.js'; let allSkills; let allTubes; async function _cacheLearningContentData() { - const skillRepository = require('../../../lib/infrastructure/repositories/skill-repository'); allSkills = await skillRepository.list(); - const tubeRepository = require('../../../lib/infrastructure/repositories/tube-repository'); allTubes = await tubeRepository.list(); } let cached = false; -module.exports = { - async autoMigrateTargetProfile(id, trx) { - if (!cached) await _cacheLearningContentData(); - cached = true; - const skillIds = await trx('target-profiles_skills').pluck('skillId').where({ targetProfileId: id }); - if (skillIds.length === 0) throw new Error("Le profil cible n'a pas d'acquis."); - const skills = skillIds.map((skillId) => { - const foundSkill = allSkills.find((skill) => skill.id === skillId); - if (!foundSkill) return null; - if (!foundSkill.tubeId) throw new Error(`L'acquis "${skillId}" n'appartient à aucun sujet.`); - const tubeExists = Boolean(allTubes.find((tube) => tube.id === foundSkill.tubeId)); - if (!tubeExists) throw new Error(`Le sujet "${foundSkill.tubeId}" n'existe pas dans le référentiel.`); - return foundSkill; - }); - const skillsGroupedByTubeId = _.groupBy(_.compact(skills), 'tubeId'); - const tubes = []; - for (const [tubeId, skills] of Object.entries(skillsGroupedByTubeId)) { - const skillWithHighestDifficulty = _.maxBy(skills, 'difficulty'); - tubes.push({ - tubeId, - level: skillWithHighestDifficulty.difficulty, - }); - } - const completeTubes = tubes.map((tube) => { - return { ...tube, targetProfileId: id }; + +const autoMigrateTargetProfile = async function (id, trx) { + if (!cached) await _cacheLearningContentData(); + cached = true; + const skillIds = await trx('target-profiles_skills').pluck('skillId').where({ targetProfileId: id }); + if (skillIds.length === 0) throw new Error("Le profil cible n'a pas d'acquis."); + const skills = skillIds.map((skillId) => { + const foundSkill = allSkills.find((skill) => skill.id === skillId); + if (!foundSkill) return null; + if (!foundSkill.tubeId) throw new Error(`L'acquis "${skillId}" n'appartient à aucun sujet.`); + const tubeExists = Boolean(allTubes.find((tube) => tube.id === foundSkill.tubeId)); + if (!tubeExists) throw new Error(`Le sujet "${foundSkill.tubeId}" n'existe pas dans le référentiel.`); + return foundSkill; + }); + const skillsGroupedByTubeId = _.groupBy(_.compact(skills), 'tubeId'); + const tubes = []; + for (const [tubeId, skills] of Object.entries(skillsGroupedByTubeId)) { + const skillWithHighestDifficulty = _.maxBy(skills, 'difficulty'); + tubes.push({ + tubeId, + level: skillWithHighestDifficulty.difficulty, }); - await trx('target-profiles').update({ migration_status: 'AUTO' }).where({ id }); - await trx.batchInsert('target-profile_tubes', completeTubes); - }, + } + const completeTubes = tubes.map((tube) => { + return { ...tube, targetProfileId: id }; + }); + await trx('target-profiles').update({ migration_status: 'AUTO' }).where({ id }); + await trx.batchInsert('target-profile_tubes', completeTubes); }; + +export { autoMigrateTargetProfile }; diff --git a/api/scripts/prod/target-profile-migrations/convert-badges.js b/api/scripts/prod/target-profile-migrations/convert-badges.js index a06c255ec3d..0d194f5f355 100644 --- a/api/scripts/prod/target-profile-migrations/convert-badges.js +++ b/api/scripts/prod/target-profile-migrations/convert-badges.js @@ -1,15 +1,19 @@ -require('dotenv').config(); -const _ = require('lodash'); -const { knex, disconnect } = require('../../../db/knex-database-connection'); -const logger = require('../../../lib/infrastructure/logger'); -const cache = require('../../../lib/infrastructure/caches/learning-content-cache'); +import * as dotenv from 'dotenv'; + +dotenv.config(); +import _ from 'lodash'; +import { knex, disconnect } from '../../../db/knex-database-connection.js'; +import { logger } from '../../../lib/infrastructure/logger.js'; +import { learningContentCache as cache } from '../../../lib/infrastructure/caches/learning-content-cache.js'; +import * as skillRepository from '../../../lib/infrastructure/repositories/skill-repository.js'; +import * as tubeRepository from '../../../lib/infrastructure/repositories/tube-repository.js'; +import * as url from 'url'; let allSkills; let allTubes; + async function _cacheLearningContentData() { - const skillRepository = require('../../../lib/infrastructure/repositories/skill-repository'); allSkills = await skillRepository.list(); - const tubeRepository = require('../../../lib/infrastructure/repositories/tube-repository'); allTubes = await tubeRepository.list(); } @@ -130,10 +134,11 @@ async function _deleteSkillSetCriteria(badgeId, trx) { await trx('badge-criteria').where({ badgeId, scope: 'SkillSet' }).del(); } -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; + +if (isLaunchedFromCommandLine) { main(); } -module.exports = { - doJob, -}; +export { doJob }; diff --git a/api/scripts/prod/target-profile-migrations/convert-target-profiles-into-new-format.js b/api/scripts/prod/target-profile-migrations/convert-target-profiles-into-new-format.js index 015c5d80113..d79bf07f1ee 100644 --- a/api/scripts/prod/target-profile-migrations/convert-target-profiles-into-new-format.js +++ b/api/scripts/prod/target-profile-migrations/convert-target-profiles-into-new-format.js @@ -1,10 +1,12 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const _ = require('lodash'); -const { knex, disconnect } = require('../../../db/knex-database-connection'); -const logger = require('../../../lib/infrastructure/logger'); -const { learningContentCache } = require('../../../lib/infrastructure/caches/learning-content-cache'); -const { autoMigrateTargetProfile } = require('./common'); +import _ from 'lodash'; +import { knex, disconnect } from '../../../db/knex-database-connection.js'; +import { logger } from '../../../lib/infrastructure/logger.js'; +import { learningContentCache } from '../../../lib/infrastructure/caches/learning-content-cache.js'; +import { autoMigrateTargetProfile } from './common.js'; +import * as url from 'url'; async function main() { try { @@ -52,10 +54,10 @@ async function _convertTargetProfile(targetProfileId, trx) { return autoMigrateTargetProfile(targetProfileId, trx); } -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +if (isLaunchedFromCommandLine) { main(); } -module.exports = { - doJob, -}; +export { doJob }; diff --git a/api/scripts/prod/target-profile-migrations/extract-need-stages-migration.js b/api/scripts/prod/target-profile-migrations/extract-need-stages-migration.js index f453140c01a..e4c5b758a8a 100644 --- a/api/scripts/prod/target-profile-migrations/extract-need-stages-migration.js +++ b/api/scripts/prod/target-profile-migrations/extract-need-stages-migration.js @@ -1,11 +1,21 @@ -require('dotenv').config({ +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../../../.env`, }); -const { resolve } = require('path'); -const { performance } = require('perf_hooks'); -const XLSX = require('xlsx'); -const logger = require('../../../lib/infrastructure/logger'); -const { writeFile } = require('fs/promises'); +import path from 'path'; +import { writeFile } from 'fs/promises'; + +const { performance } = perf_hooks; + +const { resolve } = path; + +import perf_hooks from 'perf_hooks'; +import XLSX from 'xlsx'; +import { logger } from '../../../lib/infrastructure/logger.js'; async function doJob(multiFormFiles) { const targetProfiles = Object.entries( @@ -64,8 +74,10 @@ function containsOnlyLevelStages(stageRows) { ); return levelStageRows.length === stageRows.length; } +const modulePath = url.fileURLToPath(import.meta.url); +const __filename = modulePath; -const isLaunchedFromCommandLine = require.main === module; +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { const startTime = performance.now(); @@ -88,4 +100,4 @@ async function main() { } })(); -module.exports = { doJob }; +export { doJob }; diff --git a/api/scripts/prod/target-profile-migrations/parse-xls-files-for-target-profiles-migration.js b/api/scripts/prod/target-profile-migrations/parse-xls-files-for-target-profiles-migration.js index 60ec36f08af..868fb007244 100644 --- a/api/scripts/prod/target-profile-migrations/parse-xls-files-for-target-profiles-migration.js +++ b/api/scripts/prod/target-profile-migrations/parse-xls-files-for-target-profiles-migration.js @@ -1,21 +1,31 @@ -require('dotenv').config({ +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../../../.env`, }); -const _ = require('lodash'); -const { performance } = require('perf_hooks'); -const XLSX = require('xlsx'); -const logger = require('../../../lib/infrastructure/logger'); -const { cache } = require('../../../lib/infrastructure/caches/learning-content-cache'); -const { knex, disconnect } = require('../../../db/knex-database-connection'); -const { normalizeAndRemoveAccents } = require('../../../lib/domain/services/validation-treatments'); -const { autoMigrateTargetProfile } = require('./common'); +import _ from 'lodash'; +import perf_hooks from 'perf_hooks'; + +const { performance } = perf_hooks; + +import XLSX from 'xlsx'; +import { logger } from '../../../lib/infrastructure/logger.js'; +import { learningContentCache as cache } from '../../../lib/infrastructure/caches/learning-content-cache.js'; +import { knex, disconnect } from '../../../db/knex-database-connection.js'; +import { normalizeAndRemoveAccents } from '../../../lib/domain/services/validation-treatments.js'; +import { autoMigrateTargetProfile } from './common.js'; +import * as tubeRepository from '../../../lib/infrastructure/repositories/tube-repository.js'; let allTubes; + async function _cacheLearningContentData() { - const tubeRepository = require('../../../lib/infrastructure/repositories/tube-repository'); const tubes = await tubeRepository.list(); allTubes = tubes.map((tube) => ({ ...tube, normalizedName: normalizeAndRemoveAccents(tube.name) })); } + const report = []; async function doJob(mainFile, multiFormFiles, dryRun) { @@ -284,7 +294,9 @@ function _checkIfTPHasUnexpectedMultiformInstructions(id, multiFormData) { throw new Error(`Une feuille d'instructions "multiforme" existe pour ce profil cible.`); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +const __filename = modulePath; async function main() { const startTime = performance.now(); @@ -311,4 +323,4 @@ async function main() { } })(); -module.exports = { doJob }; +export { doJob }; diff --git a/api/scripts/prod/target-profile-migrations/replace-threshold1-with-first-skill-stage.js b/api/scripts/prod/target-profile-migrations/replace-threshold1-with-first-skill-stage.js index 9733ebfc249..b3c00cec731 100644 --- a/api/scripts/prod/target-profile-migrations/replace-threshold1-with-first-skill-stage.js +++ b/api/scripts/prod/target-profile-migrations/replace-threshold1-with-first-skill-stage.js @@ -1,10 +1,17 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; dotenv.config(); -const { performance } = require('perf_hooks'); -const logger = require('../../../lib/infrastructure/logger'); -const { cache } = require('../../../lib/infrastructure/caches/learning-content-cache'); +import perf_hooks from 'perf_hooks'; -const { knex, disconnect } = require('../../../db/knex-database-connection'); +const { performance } = perf_hooks; + +import { logger } from '../../../lib/infrastructure/logger.js'; +import { learningContentCache as cache } from '../../../lib/infrastructure/caches/learning-content-cache.js'; +import { knex, disconnect } from '../../../db/knex-database-connection.js'; +import * as url from 'url'; + +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +const __filename = modulePath; const replaceThreshold = async () => { const results = await knex('stages').select('*').where('threshold', 1); @@ -17,8 +24,6 @@ const replaceThreshold = async () => { logger.info(`${ids.length} paliers convertis...`); }; -const isLaunchedFromCommandLine = require.main === module; - async function main() { const startTime = performance.now(); logger.info(`Script ${__filename} has started`); @@ -42,4 +47,4 @@ async function main() { } })(); -module.exports = { main }; +export { main }; diff --git a/api/scripts/prod/target-profile-migrations/update-pix-plus-edu-badges.js b/api/scripts/prod/target-profile-migrations/update-pix-plus-edu-badges.js index 0736b0b435c..e1ebe440865 100644 --- a/api/scripts/prod/target-profile-migrations/update-pix-plus-edu-badges.js +++ b/api/scripts/prod/target-profile-migrations/update-pix-plus-edu-badges.js @@ -1,16 +1,23 @@ -require('dotenv').config({ - path: `${__dirname}/../../../.env`, -}); -const { performance } = require('perf_hooks'); -const XLSX = require('xlsx'); -const logger = require('../../../lib/infrastructure/logger'); -const { cache } = require('../../../lib/infrastructure/caches/learning-content-cache'); -const { knex, disconnect } = require('../../../db/knex-database-connection'); -const { normalizeAndRemoveAccents } = require('../../../lib/domain/services/validation-treatments'); +// Usage: node compute-participation-results.js +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../../../.env` }); +import perf_hooks from 'perf_hooks'; + +const { performance } = perf_hooks; + +import XLSX from 'xlsx'; +import { logger } from '../../../lib/infrastructure/logger.js'; +import { learningContentCache as cache } from '../../../lib/infrastructure/caches/learning-content-cache.js'; +import { knex, disconnect } from '../../../db/knex-database-connection.js'; +import { normalizeAndRemoveAccents } from '../../../lib/domain/services/validation-treatments.js'; +import * as tubeRepository from '../../../lib/infrastructure/repositories/tube-repository.js'; let allTubes; async function _cacheLearningContentData() { - const tubeRepository = require('../../../lib/infrastructure/repositories/tube-repository'); const tubes = await tubeRepository.list(); allTubes = tubes.map((tube) => ({ ...tube, normalizedName: normalizeAndRemoveAccents(tube.name) })); } @@ -167,7 +174,9 @@ async function _writeCriteriaInDB(badgeId, criterionName, criterionThreshold, ta }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +const __filename = modulePath; async function main() { const startTime = performance.now(); @@ -194,4 +203,4 @@ async function main() { } })(); -module.exports = { doJob }; +export { doJob }; diff --git a/api/scripts/prod/update-documentation-url.js b/api/scripts/prod/update-documentation-url.js index e9b87e0d04a..d53249737e7 100644 --- a/api/scripts/prod/update-documentation-url.js +++ b/api/scripts/prod/update-documentation-url.js @@ -1,4 +1,5 @@ -const { knex, disconnect } = require('../../db/knex-database-connection'); +import { knex, disconnect } from '../../db/knex-database-connection.js'; +import * as url from 'url'; async function updateDocumentationUrl() { await _updateProOrganizations(); @@ -53,10 +54,7 @@ const URL = { PIXTERRITOIRES: 'https://cloud.pix.fr/s/deploiement_pixterritoires', }; -module.exports = { - updateDocumentationUrl, - URL, -}; +export { updateDocumentationUrl, URL }; async function _updateProOrganizations() { await knex('organizations').where('type', 'PRO').update({ documentationUrl: URL.PRO }); @@ -231,7 +229,8 @@ async function _updateAGRIOrganizations() { await knex('organizations').whereIn('id', ids).update({ documentationUrl: URL.AGRI }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { await updateDocumentationUrl(); diff --git a/api/scripts/refresh-cache.js b/api/scripts/refresh-cache.js index e427808e650..31978b7f5d8 100755 --- a/api/scripts/refresh-cache.js +++ b/api/scripts/refresh-cache.js @@ -1,11 +1,10 @@ -#! /usr/bin/env node -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const logger = require('../lib/infrastructure/logger'); -const { learningContentCache } = require('../lib/infrastructure/caches/learning-content-cache'); +import { logger } from '../lib/infrastructure/logger.js'; +import { learningContentCache } from '../lib/infrastructure/caches/learning-content-cache.js'; -const learningContentDatasource = require('../lib/infrastructure/datasources/learning-content/datasource'); +import * as learningContentDatasource from '../lib/infrastructure/datasources/learning-content/datasource.js'; logger.info('Starting refreshing Learning Content'); learningContentDatasource diff --git a/api/scripts/send-invitations-to-sco-organizations.js b/api/scripts/send-invitations-to-sco-organizations.js index 97fdc4a4604..3cd5852fb2a 100644 --- a/api/scripts/send-invitations-to-sco-organizations.js +++ b/api/scripts/send-invitations-to-sco-organizations.js @@ -1,17 +1,16 @@ -const bluebird = require('bluebird'); +import bluebird from 'bluebird'; -const { NotFoundError } = require('../lib/domain/errors'); +import { NotFoundError } from '../lib/domain/errors.js'; +import { parseCsvWithHeader } from '../scripts/helpers/csvHelpers.js'; +import { disconnect } from '../db/knex-database-connection.js'; -const { parseCsvWithHeader } = require('../scripts/helpers/csvHelpers'); -const { disconnect } = require('../db/knex-database-connection'); +import * as bookshelfToDomainConverter from '../lib/infrastructure/utils/bookshelf-to-domain-converter.js'; +import { BookshelfOrganization } from '../lib/infrastructure/orm-models/Organization.js'; -const bookshelfToDomainConverter = require('../lib/infrastructure/utils/bookshelf-to-domain-converter'); -const BookshelfOrganization = require('../lib/infrastructure/orm-models/Organization'); - -const organizationInvitationService = require('../lib/domain/services/organization-invitation-service'); - -const organizationRepository = require('../lib/infrastructure/repositories/organization-repository'); -const organizationInvitationRepository = require('../lib/infrastructure/repositories/organization-invitation-repository'); +import * as organizationInvitationService from '../lib/domain/services/organization-invitation-service.js'; +import * as organizationRepository from '../lib/infrastructure/repositories/organization-repository.js'; +import * as organizationInvitationRepository from '../lib/infrastructure/repositories/organization-invitation-repository.js'; +import * as url from 'url'; const TAGS = ['JOIN_ORGA']; @@ -40,7 +39,7 @@ async function prepareDataForSending(objectsFromFile) { async function sendJoinOrganizationInvitations(invitations, tags) { return bluebird.mapSeries(invitations, ({ organizationId, email }, index) => { - if (require.main === module) { + if (isLaunchedFromCommandLine) { process.stdout.write(`${index}/${invitations.length}\r`); } @@ -54,7 +53,8 @@ async function sendJoinOrganizationInvitations(invitations, tags) { }); } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Start sending "join SCO organization" invitations to users.'); @@ -89,9 +89,4 @@ async function main() { } })(); -module.exports = { - getOrganizationByExternalId, - buildInvitation, - prepareDataForSending, - sendJoinOrganizationInvitations, -}; +export { getOrganizationByExternalId, buildInvitation, prepareDataForSending, sendJoinOrganizationInvitations }; diff --git a/api/scripts/switch-campaign-to-flash.js b/api/scripts/switch-campaign-to-flash.js index 372ac9d5888..d68c66aeeed 100644 --- a/api/scripts/switch-campaign-to-flash.js +++ b/api/scripts/switch-campaign-to-flash.js @@ -1,9 +1,10 @@ -'use strict'; -const _ = require('lodash'); -const dotenv = require('dotenv'); +import _ from 'lodash'; +import dotenv from 'dotenv'; + dotenv.config(); -const { knex } = require('../db/knex-database-connection'); -const Assessment = require('../lib/domain/models/Assessment'); +import { knex } from '../db/knex-database-connection.js'; +import { Assessment } from '../lib/domain/models/Assessment.js'; +import * as url from 'url'; async function switchCampaignToFlash(id) { await knex('campaigns').update({ assessmentMethod: Assessment.methods.FLASH }).where({ id }); @@ -17,7 +18,9 @@ async function main(id) { await switchCampaignToFlash(id); } -if (require.main === module) { +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +if (isLaunchedFromCommandLine) { const id = parseInt(process.argv[2]); main(id).catch((err) => { @@ -26,4 +29,4 @@ if (require.main === module) { }); } -module.exports = { switchCampaignToFlash }; +export { switchCampaignToFlash }; diff --git a/api/scripts/toggle-is-for-absolute-novice-campaign-attribute.js b/api/scripts/toggle-is-for-absolute-novice-campaign-attribute.js index c6c77b47874..0428080c6ef 100644 --- a/api/scripts/toggle-is-for-absolute-novice-campaign-attribute.js +++ b/api/scripts/toggle-is-for-absolute-novice-campaign-attribute.js @@ -1,10 +1,13 @@ -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const { performance } = require('perf_hooks'); -const logger = require('../lib/infrastructure/logger'); -const { cache } = require('../lib/infrastructure/caches/learning-content-cache'); +import perf_hooks from 'perf_hooks'; + +const { performance } = perf_hooks; -const { knex, disconnect } = require('../db/knex-database-connection'); +import { logger } from '../lib/infrastructure/logger.js'; +import { learningContentCache as cache } from '../lib/infrastructure/caches/learning-content-cache.js'; +import { knex, disconnect } from '../db/knex-database-connection.js'; async function toggleIsForAbsoluteNoviceCampaignAttribute(campaignId) { const campaign = await knex.select('isForAbsoluteNovice').from('campaigns').where({ id: campaignId }).first(); @@ -14,7 +17,11 @@ async function toggleIsForAbsoluteNoviceCampaignAttribute(campaignId) { await knex('campaigns').update({ isForAbsoluteNovice: !campaign.isForAbsoluteNovice }).where({ id: campaignId }); } -const isLaunchedFromCommandLine = require.main === module; +import * as url from 'url'; + +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; +const __filename = modulePath; async function main() { const startTime = performance.now(); @@ -40,4 +47,4 @@ async function main() { } })(); -module.exports = { toggleIsForAbsoluteNoviceCampaignAttribute }; +export { toggleIsForAbsoluteNoviceCampaignAttribute }; diff --git a/api/scripts/update-sco-organizations-with-is-managing-students-to-true.js b/api/scripts/update-sco-organizations-with-is-managing-students-to-true.js index 9d2e3b13d67..91a458862e5 100644 --- a/api/scripts/update-sco-organizations-with-is-managing-students-to-true.js +++ b/api/scripts/update-sco-organizations-with-is-managing-students-to-true.js @@ -1,16 +1,17 @@ // Usage: BASE_URL=... PIXMASTER_EMAIL=... PIXMASTER_PASSWORD=... node update-sco-organizations-with-is-managing-students-to-true.js path/file.csv // To use on file with columns |externalId| -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const { disconnect } = require('../db/knex-database-connection'); -const request = require('request-promise-native'); -const { +import { disconnect } from '../db/knex-database-connection.js'; +import request from 'request-promise-native'; +import { findOrganizationsByExternalIds, organizeOrganizationsByExternalId, -} = require('./helpers/organizations-by-external-id-helper'); -const { parseCsv } = require('./helpers/csvHelpers'); +} from './helpers/organizations-by-external-id-helper.js'; +import { parseCsv } from './helpers/csvHelpers.js'; +import * as url from 'url'; const baseUrl = process.env.BASE_URL || 'http://localhost:3000'; @@ -20,7 +21,7 @@ function checkData({ csvData }) { const [externalIdLowerCase] = data; if (!externalIdLowerCase) { - if (require.main === module) process.stdout.write('Found empty line in input file.'); + if (isLaunchedFromCommandLine) process.stdout.write('Found empty line in input file.'); return null; } const externalId = externalIdLowerCase.toUpperCase(); @@ -32,7 +33,7 @@ function checkData({ csvData }) { async function updateOrganizations({ accessToken, organizationsByExternalId, checkedData }) { for (let i = 0; i < checkedData.length; i++) { - if (require.main === module) process.stdout.write(`\n${i + 1}/${checkedData.length} `); + if (isLaunchedFromCommandLine) process.stdout.write(`\n${i + 1}/${checkedData.length} `); const { externalId } = checkedData[i]; const organization = organizationsByExternalId[externalId]; @@ -81,7 +82,8 @@ function _buildPatchOrganizationRequestObject(accessToken, organization) { }; } -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; async function main() { console.log('Starting setting is-managing-students to true.'); @@ -123,7 +125,4 @@ async function main() { } })(); -module.exports = { - checkData, - updateOrganizations, -}; +export { checkData, updateOrganizations }; diff --git a/api/scripts/update-sco-organizations-with-province-code-and-external-id.js b/api/scripts/update-sco-organizations-with-province-code-and-external-id.js index fa6a0f924c5..025734ba444 100644 --- a/api/scripts/update-sco-organizations-with-province-code-and-external-id.js +++ b/api/scripts/update-sco-organizations-with-province-code-and-external-id.js @@ -1,12 +1,14 @@ -'use strict'; -const dotenv = require('dotenv'); +import dotenv from 'dotenv'; + dotenv.config(); -const path = require('path'); -const fs = require('fs'); -const { access } = require('fs').promises; -const request = require('request-promise-native'); -const papa = require('papaparse'); -const { disconnect } = require('../db/knex-database-connection'); +import path from 'path'; +import fs from 'fs'; +import { access } from 'fs/promises'; + +import request from 'request-promise-native'; +import papa from 'papaparse'; +import { disconnect } from '../db/knex-database-connection.js'; +import * as url from 'url'; const CSV_HEADERS = { ID: 'Orga_ID', @@ -111,7 +113,9 @@ function _logErrorObjects(errorObjects) { * Usage: BASE_URL='url' (...) node update-sco-organizations-with-province-code-and-external-id.js my_file.csv */ -const isLaunchedFromCommandLine = require.main === module; +const modulePath = url.fileURLToPath(import.meta.url); +const isLaunchedFromCommandLine = process.argv[1] === modulePath; + async function main() { console.log("Début du script de mise à jour des Organisations avec l'ID externe et le département"); const filePath = process.argv[2]; @@ -155,8 +159,4 @@ async function main() { } })(); -module.exports = { - assertFileValidity, - convertCSVDataIntoOrganizations, - saveOrganizations, -}; +export { assertFileValidity, convertCSVDataIntoOrganizations, saveOrganizations }; diff --git a/api/server.js b/api/server.js index ff54ccfc77d..71410be3bb9 100644 --- a/api/server.js +++ b/api/server.js @@ -1,28 +1,24 @@ -const dotenv = require('dotenv'); -dotenv.config(); -const Hapi = require('@hapi/hapi'); -const Oppsy = require('oppsy'); - -const settings = require('./lib/config'); -const preResponseUtils = require('./lib/application/pre-response-utils'); - -const { routes } = require('./lib/routes'); -const plugins = require('./lib/infrastructure/plugins'); -const swaggers = require('./lib/swaggers'); -const authentication = require('./lib/infrastructure/authentication'); - -const { handleFailAction } = require('./lib/validate'); -const monitoringTools = require('./lib/infrastructure/monitoring-tools'); -const deserializer = require('./lib/infrastructure/serializers/jsonapi/deserializer'); -const { knex } = require('./db/knex-database-connection'); -const { port, logging } = require('./lib/config'); +import Hapi from '@hapi/hapi'; +import Oppsy from 'oppsy'; + +import { config } from './lib/config.js'; +import * as preResponseUtils from './lib/application/pre-response-utils.js'; +import { routes } from './lib/routes.js'; +import { plugins } from './lib/infrastructure/plugins/index.js'; +import { swaggers } from './lib/swaggers.js'; +import { authentication } from './lib/infrastructure/authentication.js'; +import { handleFailAction } from './lib/validate.js'; +import { monitoringTools } from './lib/infrastructure/monitoring-tools.js'; +import { deserializer } from './lib/infrastructure/serializers/jsonapi/deserializer.js'; +import { knex } from './db/knex-database-connection.js'; monitoringTools.installHapiHook(); +const { logOpsMetrics, port, logging } = config; const createServer = async () => { const server = createBareServer(); - if (settings.logOpsMetrics) await enableOpsMetrics(server); + if (logOpsMetrics) await enableOpsMetrics(server); setupErrorHandling(server); @@ -115,4 +111,4 @@ const setupOpenApiSpecification = async function (server) { } }; -module.exports = createServer; +export { createServer }; diff --git a/api/tests/.eslintrc.yaml b/api/tests/.eslintrc.yaml index b03cc9766eb..aeb9692a855 100644 --- a/api/tests/.eslintrc.yaml +++ b/api/tests/.eslintrc.yaml @@ -6,3 +6,5 @@ env: rules: no-console: - error + mocha/no-setup-in-describe: + - warn diff --git a/api/tests/acceptance/application/account-recovery/account-recovery-route-get_test.js b/api/tests/acceptance/application/account-recovery/account-recovery-route-get_test.js index 25f4fb892d4..0a5d0d84826 100644 --- a/api/tests/acceptance/application/account-recovery/account-recovery-route-get_test.js +++ b/api/tests/acceptance/application/account-recovery/account-recovery-route-get_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Application | Account-Recovery | Routes', function () { describe('GET /api/account-recovery/{temporaryKey}', function () { diff --git a/api/tests/acceptance/application/account-recovery/account-recovery-route-patch_test.js b/api/tests/acceptance/application/account-recovery/account-recovery-route-patch_test.js index 98e1344857c..cf6482c8c06 100644 --- a/api/tests/acceptance/application/account-recovery/account-recovery-route-patch_test.js +++ b/api/tests/acceptance/application/account-recovery/account-recovery-route-patch_test.js @@ -1,5 +1,5 @@ -const { databaseBuilder, expect, knex } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { databaseBuilder, expect, knex } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Account-recovery', function () { describe('PATCH /api/account-recovery', function () { diff --git a/api/tests/acceptance/application/account-recovery/account-recovery-route_test.js b/api/tests/acceptance/application/account-recovery/account-recovery-route_test.js index 4c1628bbd67..e6b202a9e0d 100644 --- a/api/tests/acceptance/application/account-recovery/account-recovery-route_test.js +++ b/api/tests/acceptance/application/account-recovery/account-recovery-route_test.js @@ -1,5 +1,5 @@ -const { databaseBuilder, expect } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { databaseBuilder, expect } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Account-recovery', function () { describe('POST /api/account-recovery', function () { diff --git a/api/tests/acceptance/application/admin-members/admin-members-routes_test.js b/api/tests/acceptance/application/admin-members/admin-members-routes_test.js index 026f4b4252f..19a8aaaa777 100644 --- a/api/tests/acceptance/application/admin-members/admin-members-routes_test.js +++ b/api/tests/acceptance/application/admin-members/admin-members-routes_test.js @@ -1,11 +1,14 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; describe('Acceptance | Application | Admin-members | Routes', function () { describe('GET /api/admin/admin-members/me', function () { diff --git a/api/tests/acceptance/application/answers/answer-controller-find_test.js b/api/tests/acceptance/application/answers/answer-controller-find_test.js index d214ff8c4be..5d6cd201727 100644 --- a/api/tests/acceptance/application/answers/answer-controller-find_test.js +++ b/api/tests/acceptance/application/answers/answer-controller-find_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | answer-controller-find', function () { describe('GET /api/answers?challengeId=Y&assessmentId=Z', function () { diff --git a/api/tests/acceptance/application/answers/answer-controller-get-correction_test.js b/api/tests/acceptance/application/answers/answer-controller-get-correction_test.js index 9d75dae2178..3e06f391ee4 100644 --- a/api/tests/acceptance/application/answers/answer-controller-get-correction_test.js +++ b/api/tests/acceptance/application/answers/answer-controller-get-correction_test.js @@ -1,11 +1,14 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, mockLearningContent, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { FRENCH_FRANCE } = require('../../../../lib/domain/constants').LOCALE; +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_FRANCE } = LOCALE; describe('Acceptance | Controller | answer-controller-get-correction', function () { let server; diff --git a/api/tests/acceptance/application/answers/answer-controller-get_test.js b/api/tests/acceptance/application/answers/answer-controller-get_test.js index bb2aece3398..0764819b6ff 100644 --- a/api/tests/acceptance/application/answers/answer-controller-get_test.js +++ b/api/tests/acceptance/application/answers/answer-controller-get_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | answer-controller-get', function () { describe('GET /api/answers/:id', function () { diff --git a/api/tests/acceptance/application/answers/answer-controller-save_test.js b/api/tests/acceptance/application/answers/answer-controller-save_test.js index 7b24e98d426..6f7b0dbccb8 100644 --- a/api/tests/acceptance/application/answers/answer-controller-save_test.js +++ b/api/tests/acceptance/application/answers/answer-controller-save_test.js @@ -1,12 +1,15 @@ -const { +import { expect, knex, databaseBuilder, mockLearningContent, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { FRENCH_FRANCE, ENGLISH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_FRANCE, ENGLISH_SPOKEN } = LOCALE; describe('Acceptance | Controller | answer-controller-save', function () { let server; diff --git a/api/tests/acceptance/application/answers/answer-controller-update_test.js b/api/tests/acceptance/application/answers/answer-controller-update_test.js index a7a067f4626..24857beae23 100644 --- a/api/tests/acceptance/application/answers/answer-controller-update_test.js +++ b/api/tests/acceptance/application/answers/answer-controller-update_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | answer-controller-update', function () { describe('PATCH /api/answers/:id', function () { diff --git a/api/tests/acceptance/application/assessment-results/assessment-result-admin-controller_test.js b/api/tests/acceptance/application/assessment-results/assessment-result-admin-controller_test.js index fceb7bd995e..d5263c7853b 100644 --- a/api/tests/acceptance/application/assessment-results/assessment-result-admin-controller_test.js +++ b/api/tests/acceptance/application/assessment-results/assessment-result-admin-controller_test.js @@ -1,13 +1,13 @@ -const { +import { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Acceptance | Controller | assessment-results-controller', function () { let server; diff --git a/api/tests/acceptance/application/assessments/assessment-controller-auto-validate-next-challenge_test.js b/api/tests/acceptance/application/assessments/assessment-controller-auto-validate-next-challenge_test.js index 4d1da65cd64..ff28f167f4b 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-auto-validate-next-challenge_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-auto-validate-next-challenge_test.js @@ -1,4 +1,4 @@ -const { +import { expect, databaseBuilder, knex, @@ -6,10 +6,11 @@ const { learningContentBuilder, insertUserWithRoleSuperAdmin, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const settings = require('../../../../lib/config'); -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +} from '../../../test-helper.js'; + +import { config as settings } from '../../../../lib/config.js'; +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; const lastChallengeAnswer = 'last challenge answer'; const lastChallengeId = 'lastChallengeId'; @@ -55,7 +56,7 @@ describe('Acceptance | API | assessment-controller-auto-validate-next-challenge' settings.featureToggles.isAlwaysOkValidateNextChallengeEndpointEnabled = true; server = await createServer(); - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/assessments/assessment-controller-complete-assessment_test.js b/api/tests/acceptance/application/assessments/assessment-controller-complete-assessment_test.js index 4e2c0db7e46..c8041c8af87 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-complete-assessment_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-complete-assessment_test.js @@ -1,15 +1,16 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, knex, mockLearningContent, learningContentBuilder, -} = require('../../../test-helper'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const badgeAcquisitionRepository = require('../../../../lib/infrastructure/repositories/badge-acquisition-repository'); -const createServer = require('../../../../server'); -const TrainingTrigger = require('../../../../lib/domain/models/TrainingTrigger'); +} from '../../../test-helper.js'; + +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import * as badgeAcquisitionRepository from '../../../../lib/infrastructure/repositories/badge-acquisition-repository.js'; +import { createServer } from '../../../../server.js'; +import { TrainingTrigger } from '../../../../lib/domain/models/TrainingTrigger.js'; describe('Acceptance | Controller | assessment-controller-complete-assessment', function () { let options; @@ -150,7 +151,7 @@ describe('Acceptance | Controller | assessment-controller-complete-assessment', ]; beforeEach(async function () { - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); server = await createServer(); diff --git a/api/tests/acceptance/application/assessments/assessment-controller-find-competence-evaluations_test.js b/api/tests/acceptance/application/assessments/assessment-controller-find-competence-evaluations_test.js index 5af1ae471d0..f1c03e56f88 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-find-competence-evaluations_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-find-competence-evaluations_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | API | assessment-controller-find-competence-evaluations', function () { let server; diff --git a/api/tests/acceptance/application/assessments/assessment-controller-get-challenge-for-pix-button_test.js b/api/tests/acceptance/application/assessments/assessment-controller-get-challenge-for-pix-button_test.js index 263c4377ae2..31f9caee1f2 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-get-challenge-for-pix-button_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-get-challenge-for-pix-button_test.js @@ -1,4 +1,4 @@ -const { +import { expect, databaseBuilder, knex, @@ -6,9 +6,10 @@ const { learningContentBuilder, insertUserWithRoleSuperAdmin, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; const lastChallengeAnswer = 'last challenge answer'; const lastChallengeId = 'lastChallengeId'; @@ -50,7 +51,8 @@ describe('Acceptance | API | assessment-controller-get-challenge-answer-for-pix- beforeEach(async function () { server = await createServer(); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + learningContentBuilder.fromAreas; + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/assessments/assessment-controller-get-last-challenge-id_test.js b/api/tests/acceptance/application/assessments/assessment-controller-get-last-challenge-id_test.js index 787ab6fb214..27bdb49d011 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-get-last-challenge-id_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-get-last-challenge-id_test.js @@ -1,12 +1,13 @@ -const { +import { expect, databaseBuilder, knex, insertUserWithRoleSuperAdmin, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Acceptance | API | assessment-controller-get-last-challenge-id', function () { let server; diff --git a/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-campaign-assessment_test.js b/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-campaign-assessment_test.js index 39ae4dff0cc..7346d30857e 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-campaign-assessment_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-campaign-assessment_test.js @@ -1,4 +1,4 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, @@ -6,9 +6,10 @@ const { learningContentBuilder, knex, sinon, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; const competenceId = 'recCompetence'; const skillWeb1Id = 'recAcquisWeb1'; @@ -69,7 +70,7 @@ describe('Acceptance | API | assessment-controller-get-next-challenge-for-campai beforeEach(async function () { server = await createServer(); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-competence-evaluation_test.js b/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-competence-evaluation_test.js index 56964525c1a..e82e1b512f1 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-competence-evaluation_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-competence-evaluation_test.js @@ -1,4 +1,4 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, @@ -6,10 +6,11 @@ const { learningContentBuilder, knex, sinon, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; const competenceId = 'recCompetence'; const skillWeb1Id = 'recAcquisWeb1'; @@ -70,7 +71,7 @@ describe('Acceptance | API | assessment-controller-get-next-challenge-for-compet beforeEach(async function () { server = await createServer(); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-demo_test.js b/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-demo_test.js index f56ff4bf0e4..03b99b3d6e0 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-demo_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-for-demo_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, mockLearningContent, learningContentBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, mockLearningContent, learningContentBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | API | assessment-controller-get-next-challenge-for-demo', function () { let server; @@ -40,7 +40,7 @@ describe('Acceptance | API | assessment-controller-get-next-challenge-for-demo', }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-locale-management.js b/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-locale-management.js index 0e9b603abe6..066bb5bc9bb 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-locale-management.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-get-next-challenge-locale-management.js @@ -1,14 +1,16 @@ -const { +import { learningContentBuilder, mockLearningContent, databaseBuilder, expect, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { FRENCH_FRANCE } = require('../../../../lib/domain/constants').LOCALE; +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_FRANCE } = LOCALE; const competenceId = 'recCompetence'; const frenchSpokenChallengeId = 'recFrenchSpokenChallengeId'; @@ -68,7 +70,7 @@ describe('Acceptance | API | assessment-controller-get-next-challenge-locale-man context('when assessment is a competence evaluation', function () { context('when there is one challenge in the accepted language (fr-fr)', function () { beforeEach(async function () { - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildUser({ id: userId }); diff --git a/api/tests/acceptance/application/assessments/assessment-controller-get_test.js b/api/tests/acceptance/application/assessments/assessment-controller-get_test.js index e2a5acd90f0..8be93c86252 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-get_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-get_test.js @@ -1,7 +1,10 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_SPOKEN } = LOCALE; + +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Acceptance | API | assessment-controller-get', function () { let server; diff --git a/api/tests/acceptance/application/assessments/assessment-controller-post_test.js b/api/tests/acceptance/application/assessments/assessment-controller-post_test.js index 78fcc6fad52..b1d663cf513 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-post_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-post_test.js @@ -1,6 +1,6 @@ -const { expect, knex, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const BookshelfAssessment = require('../../../../lib/infrastructure/orm-models/Assessment'); +import { expect, knex, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { BookshelfAssessment } from '../../../../lib/infrastructure/orm-models/Assessment.js'; describe('Acceptance | API | Assessments POST', function () { let server; diff --git a/api/tests/acceptance/application/assessments/assessment-controller-update-last-challenge-state_test.js b/api/tests/acceptance/application/assessments/assessment-controller-update-last-challenge-state_test.js index 79aba94e817..5fa969b9e54 100644 --- a/api/tests/acceptance/application/assessments/assessment-controller-update-last-challenge-state_test.js +++ b/api/tests/acceptance/application/assessments/assessment-controller-update-last-challenge-state_test.js @@ -1,13 +1,14 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, mockLearningContent, learningContentBuilder, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; const competenceId = 'recCompetence'; const skillWeb2Id = 'recAcquisWeb2'; @@ -56,7 +57,7 @@ describe('Acceptance | API | assessment-controller-update-last-challenge-state', beforeEach(async function () { server = await createServer(); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/authentication/authentication-route_test.js b/api/tests/acceptance/application/authentication/authentication-route_test.js index ab8cca963b5..1dbf616480d 100644 --- a/api/tests/acceptance/application/authentication/authentication-route_test.js +++ b/api/tests/acceptance/application/authentication/authentication-route_test.js @@ -1,10 +1,12 @@ -const querystring = require('querystring'); -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const tokenService = require('../../../../lib/domain/services/token-service'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; +import querystring from 'querystring'; +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; -const createServer = require('../../../../server'); +const { ROLES } = PIX_ADMIN; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | authentication-controller', function () { afterEach(async function () { diff --git a/api/tests/acceptance/application/authentication/oidc/authentication-url-route-get_test.js b/api/tests/acceptance/application/authentication/oidc/authentication-url-route-get_test.js index 75e61cd3194..4d0fb49793d 100644 --- a/api/tests/acceptance/application/authentication/oidc/authentication-url-route-get_test.js +++ b/api/tests/acceptance/application/authentication/oidc/authentication-url-route-get_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../test-helper'); -const createServer = require('../../../../../server'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); -const querystring = require('querystring'); +import { expect } from '../../../../test-helper.js'; +import { createServer } from '../../../../../server.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; +import querystring from 'querystring'; describe('Acceptance | Route | oidc authentication url', function () { let server; diff --git a/api/tests/acceptance/application/authentication/oidc/check-reconciliation-route-post_test.js b/api/tests/acceptance/application/authentication/oidc/check-reconciliation-route-post_test.js index f995c112aea..8f453af9419 100644 --- a/api/tests/acceptance/application/authentication/oidc/check-reconciliation-route-post_test.js +++ b/api/tests/acceptance/application/authentication/oidc/check-reconciliation-route-post_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, knex } = require('../../../../test-helper'); -const createServer = require('../../../../../server'); -const jsonwebtoken = require('jsonwebtoken'); -const authenticationSessionService = require('../../../../../lib/domain/services/authentication/authentication-session-service'); +import { expect, databaseBuilder, knex } from '../../../../test-helper.js'; +import { createServer } from '../../../../../server.js'; +import jsonwebtoken from 'jsonwebtoken'; +import * as authenticationSessionService from '../../../../../lib/domain/services/authentication/authentication-session-service.js'; describe('Acceptance | Application | Oidc | Routes', function () { describe('POST /api/oidc/user/check-reconciliation', function () { diff --git a/api/tests/acceptance/application/authentication/oidc/reconcile-route-post_test.js b/api/tests/acceptance/application/authentication/oidc/reconcile-route-post_test.js index 186dc6490b5..65ee08b5925 100644 --- a/api/tests/acceptance/application/authentication/oidc/reconcile-route-post_test.js +++ b/api/tests/acceptance/application/authentication/oidc/reconcile-route-post_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder } = require('../../../../test-helper'); -const createServer = require('../../../../../server'); -const jsonwebtoken = require('jsonwebtoken'); -const authenticationSessionService = require('../../../../../lib/domain/services/authentication/authentication-session-service'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); +import { expect, databaseBuilder } from '../../../../test-helper.js'; +import { createServer } from '../../../../../server.js'; +import jsonwebtoken from 'jsonwebtoken'; +import * as authenticationSessionService from '../../../../../lib/domain/services/authentication/authentication-session-service.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; describe('Acceptance | Application | Oidc | Routes', function () { describe('POST /api/oidc/user/reconcile', function () { diff --git a/api/tests/acceptance/application/authentication/oidc/token-route-post_test.js b/api/tests/acceptance/application/authentication/oidc/token-route-post_test.js index c0063ef5dee..29ca83db740 100644 --- a/api/tests/acceptance/application/authentication/oidc/token-route-post_test.js +++ b/api/tests/acceptance/application/authentication/oidc/token-route-post_test.js @@ -1,18 +1,19 @@ -const jsonwebtoken = require('jsonwebtoken'); -const { +import jsonwebtoken from 'jsonwebtoken'; + +import { expect, databaseBuilder, knex, nock, sinon, generateValidRequestAuthorizationHeader, -} = require('../../../../test-helper'); +} from '../../../../test-helper.js'; -const createServer = require('../../../../../server'); -const settings = require('../../../../../lib/config'); -const AuthenticationSessionContent = require('../../../../../lib/domain/models/AuthenticationSessionContent'); -const authenticationSessionService = require('../../../../../lib/domain/services/authentication/authentication-session-service'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); +import { createServer } from '../../../../../server.js'; +import { config as settings } from '../../../../../lib/config.js'; +import { AuthenticationSessionContent } from '../../../../../lib/domain/models/AuthenticationSessionContent.js'; +import * as authenticationSessionService from '../../../../../lib/domain/services/authentication/authentication-session-service.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; const uuidPattern = new RegExp(/^[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i); diff --git a/api/tests/acceptance/application/authentication/oidc/users-route-post_test.js b/api/tests/acceptance/application/authentication/oidc/users-route-post_test.js index 3c83ed744bf..6b34c186828 100644 --- a/api/tests/acceptance/application/authentication/oidc/users-route-post_test.js +++ b/api/tests/acceptance/application/authentication/oidc/users-route-post_test.js @@ -1,9 +1,9 @@ -const jsonwebtoken = require('jsonwebtoken'); -const { expect, knex } = require('../../../../test-helper'); -const authenticationSessionService = require('../../../../../lib/domain/services/authentication/authentication-session-service'); -const createServer = require('../../../../../server'); -const AuthenticationSessionContent = require('../../../../../lib/domain/models/AuthenticationSessionContent'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); +import jsonwebtoken from 'jsonwebtoken'; +import { expect, knex } from '../../../../test-helper.js'; +import * as authenticationSessionService from '../../../../../lib/domain/services/authentication/authentication-session-service.js'; +import { createServer } from '../../../../../server.js'; +import { AuthenticationSessionContent } from '../../../../../lib/domain/models/AuthenticationSessionContent.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; describe('Acceptance | Route | oidc users', function () { let server; diff --git a/api/tests/acceptance/application/badges/badge-controller_test.js b/api/tests/acceptance/application/badges/badge-controller_test.js index 7d05afe3f97..7ec7731073c 100644 --- a/api/tests/acceptance/application/badges/badge-controller_test.js +++ b/api/tests/acceptance/application/badges/badge-controller_test.js @@ -1,11 +1,12 @@ -const createServer = require('../../../../server'); -const { +import { createServer } from '../../../../server.js'; + +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; describe('Acceptance | API | Badges', function () { let server, options, userId, badge; diff --git a/api/tests/acceptance/application/cache/cache-controller_test.js b/api/tests/acceptance/application/cache/cache-controller_test.js index f52d61eb3c2..18adf6b06f5 100644 --- a/api/tests/acceptance/application/cache/cache-controller_test.js +++ b/api/tests/acceptance/application/cache/cache-controller_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | cache-controller', function () { let server; diff --git a/api/tests/acceptance/application/campaign-administration/archive-campaigns_test.js b/api/tests/acceptance/application/campaign-administration/archive-campaigns_test.js index 942f19a3d85..e8b57319d88 100644 --- a/api/tests/acceptance/application/campaign-administration/archive-campaigns_test.js +++ b/api/tests/acceptance/application/campaign-administration/archive-campaigns_test.js @@ -1,7 +1,9 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; -const createServer = require('../../../../server'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; let server; describe('Acceptance | Application | campaign-controller-archive-campaigns', function () { diff --git a/api/tests/acceptance/application/campaign-participations/campaign-participation-controller_test.js b/api/tests/acceptance/application/campaign-participations/campaign-participation-controller_test.js index 686c15a4578..8a083abbdab 100644 --- a/api/tests/acceptance/application/campaign-participations/campaign-participation-controller_test.js +++ b/api/tests/acceptance/application/campaign-participations/campaign-participation-controller_test.js @@ -1,7 +1,8 @@ -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const { +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; + +import { expect, databaseBuilder, mockLearningContent, @@ -9,7 +10,7 @@ const { generateValidRequestAuthorizationHeader, knex, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; const { SHARED, STARTED } = CampaignParticipationStatuses; @@ -53,7 +54,7 @@ describe('Acceptance | API | Campaign Participations', function () { ], }, ]; - const learningObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningObjects); options = { @@ -309,7 +310,7 @@ describe('Acceptance | API | Campaign Participations', function () { describe('GET /api/campaigns/{campaignId}/profiles-collection-participations/{campaignParticipationId}', function () { beforeEach(function () { - const learningObjects = learningContentBuilder.buildLearningContent.fromAreas([]); + const learningObjects = learningContentBuilder.fromAreas([]); mockLearningContent(learningObjects); }); diff --git a/api/tests/acceptance/application/campaign-participations/campaign-participations-controller-analyses_test.js b/api/tests/acceptance/application/campaign-participations/campaign-participations-controller-analyses_test.js index 63042cb9322..b8e2abb245f 100644 --- a/api/tests/acceptance/application/campaign-participations/campaign-participations-controller-analyses_test.js +++ b/api/tests/acceptance/application/campaign-participations/campaign-participations-controller-analyses_test.js @@ -1,12 +1,13 @@ -const createServer = require('../../../../server'); -const Membership = require('../../../../lib/domain/models/Membership'); -const { +import { createServer } from '../../../../server.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; + +import { expect, databaseBuilder, mockLearningContent, learningContentBuilder, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; describe('Acceptance | API | Campaign Participations | Analyses', function () { let server, options, userId, organization, campaign, campaignParticipation; @@ -82,7 +83,7 @@ describe('Acceptance | API | Campaign Participations | Analyses', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/campaign-participations/campaign-participations-controller-find-shared-participations_test.js b/api/tests/acceptance/application/campaign-participations/campaign-participations-controller-find-shared-participations_test.js index 9bb6ddcccfc..e200293db75 100644 --- a/api/tests/acceptance/application/campaign-participations/campaign-participations-controller-find-shared-participations_test.js +++ b/api/tests/acceptance/application/campaign-participations/campaign-participations-controller-find-shared-participations_test.js @@ -1,11 +1,12 @@ -const createServer = require('../../../../server'); -const { +import { createServer } from '../../../../server.js'; + +import { expect, databaseBuilder, mockLearningContent, learningContentBuilder, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; describe('Acceptance | API | Campaign Participations | Results', function () { let server; @@ -45,7 +46,7 @@ describe('Acceptance | API | Campaign Participations | Results', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); campaign = databaseBuilder.factory.buildAssessmentCampaignForSkills({ organizationId: organization.id }, [skill]); diff --git a/api/tests/acceptance/application/campaigns/campaign-controller_test.js b/api/tests/acceptance/application/campaigns/campaign-controller_test.js index 9b5c02d64de..c68cdeda842 100644 --- a/api/tests/acceptance/application/campaigns/campaign-controller_test.js +++ b/api/tests/acceptance/application/campaigns/campaign-controller_test.js @@ -1,21 +1,21 @@ -const jwt = require('jsonwebtoken'); +import jwt from 'jsonwebtoken'; -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, knex, learningContentBuilder, mockLearningContent, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const settings = require('../../../../lib/config'); -const Membership = require('../../../../lib/domain/models/Membership'); -const createServer = require('../../../../server'); +import { config as settings } from '../../../../lib/config.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | API | Campaign Controller', function () { let campaign; @@ -136,7 +136,7 @@ describe('Acceptance | API | Campaign Controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -250,7 +250,7 @@ describe('Acceptance | API | Campaign Controller', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -339,7 +339,7 @@ describe('Acceptance | API | Campaign Controller', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -437,7 +437,7 @@ describe('Acceptance | API | Campaign Controller', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -579,7 +579,7 @@ describe('Acceptance | API | Campaign Controller', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -691,7 +691,7 @@ describe('Acceptance | API | Campaign Controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); // when @@ -815,7 +815,7 @@ describe('Acceptance | API | Campaign Controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); // when @@ -882,7 +882,7 @@ describe('Acceptance | API | Campaign Controller', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -1297,7 +1297,7 @@ describe('Acceptance | API | Campaign Controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/campaigns/campaign-management-controller_test.js b/api/tests/acceptance/application/campaigns/campaign-management-controller_test.js index 5623a659757..44daa54808c 100644 --- a/api/tests/acceptance/application/campaigns/campaign-management-controller_test.js +++ b/api/tests/acceptance/application/campaigns/campaign-management-controller_test.js @@ -1,5 +1,5 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader, knex } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, knex } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | API | Campaign Management Controller', function () { let server; diff --git a/api/tests/acceptance/application/campaigns/campaign-stats-controller_test.js b/api/tests/acceptance/application/campaigns/campaign-stats-controller_test.js index d2bcdd4ad3f..11d7e735141 100644 --- a/api/tests/acceptance/application/campaigns/campaign-stats-controller_test.js +++ b/api/tests/acceptance/application/campaigns/campaign-stats-controller_test.js @@ -1,12 +1,12 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, learningContentBuilder, mockLearningContent, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); +import { createServer } from '../../../../server.js'; describe('Acceptance | API | Campaign Stats Controller', function () { let server; @@ -18,7 +18,7 @@ describe('Acceptance | API | Campaign Stats Controller', function () { describe('GET /api/campaigns/{id}/stats/participations-by-stage', function () { it('should return the campaign by id', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContentObjects = learningContentBuilder.fromAreas([ { id: 'recArea1', title_i18n: { diff --git a/api/tests/acceptance/application/certification-candidates/certification-candidates-controller_test.js b/api/tests/acceptance/application/certification-candidates/certification-candidates-controller_test.js index 09f26cb91d1..6db296bfd5f 100644 --- a/api/tests/acceptance/application/certification-candidates/certification-candidates-controller_test.js +++ b/api/tests/acceptance/application/certification-candidates/certification-candidates-controller_test.js @@ -1,6 +1,6 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const ComplementaryCertification = require('../../../../lib/domain/models/ComplementaryCertification'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { ComplementaryCertification } from '../../../../lib/domain/models/ComplementaryCertification.js'; describe('Acceptance | API | Certifications candidates', function () { describe('POST /api/certification-candidates/:id/authorize-to-start', function () { diff --git a/api/tests/acceptance/application/certification-center-invitations/index_test.js b/api/tests/acceptance/application/certification-center-invitations/index_test.js index 3473daa4107..3663479a3d3 100644 --- a/api/tests/acceptance/application/certification-center-invitations/index_test.js +++ b/api/tests/acceptance/application/certification-center-invitations/index_test.js @@ -1,12 +1,13 @@ -const { +import { databaseBuilder, expect, knex, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | API | Certification center invitations', function () { let server; diff --git a/api/tests/acceptance/application/certification-center-memberships/certification-center-membership-controller_test.js b/api/tests/acceptance/application/certification-center-memberships/certification-center-membership-controller_test.js index a7952dc36f1..c40962b3dba 100644 --- a/api/tests/acceptance/application/certification-center-memberships/certification-center-membership-controller_test.js +++ b/api/tests/acceptance/application/certification-center-memberships/certification-center-membership-controller_test.js @@ -1,11 +1,12 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, databaseBuilder, sinon, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | API | Certification Center Membership', function () { let server; diff --git a/api/tests/acceptance/application/certification-centers/certification-center-controller-get-import-template_test.js b/api/tests/acceptance/application/certification-centers/certification-center-controller-get-import-template_test.js index bab6a504560..1b8e1a3bab3 100644 --- a/api/tests/acceptance/application/certification-centers/certification-center-controller-get-import-template_test.js +++ b/api/tests/acceptance/application/certification-centers/certification-center-controller-get-import-template_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | certification-center-controller-get-import-template', function () { let server; diff --git a/api/tests/acceptance/application/certification-centers/certification-center-controller_test.js b/api/tests/acceptance/application/certification-centers/certification-center-controller_test.js index dfaab8e2aae..dd474b392a1 100644 --- a/api/tests/acceptance/application/certification-centers/certification-center-controller_test.js +++ b/api/tests/acceptance/application/certification-centers/certification-center-controller_test.js @@ -1,14 +1,14 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); +import { createServer } from '../../../../server.js'; describe('Acceptance | API | Certification Center', function () { let server, request; diff --git a/api/tests/acceptance/application/certification-centers/certification-centers-route-get_test.js b/api/tests/acceptance/application/certification-centers/certification-centers-route-get_test.js index a2fdfd33e98..5751ec0d15a 100644 --- a/api/tests/acceptance/application/certification-centers/certification-centers-route-get_test.js +++ b/api/tests/acceptance/application/certification-centers/certification-centers-route-get_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Application | Certification-centers | Routes', function () { describe('GET /api/certification-centers/{certificationCenterId}/members', function () { diff --git a/api/tests/acceptance/application/certification-centers/certification-centers-route-post-session_test.js b/api/tests/acceptance/application/certification-centers/certification-centers-route-post-session_test.js index 3a49e5f31ff..e149e12e0d0 100644 --- a/api/tests/acceptance/application/certification-centers/certification-centers-route-post-session_test.js +++ b/api/tests/acceptance/application/certification-centers/certification-centers-route-post-session_test.js @@ -1,5 +1,5 @@ -const { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | certification-centers-controller-post-session', function () { let server; diff --git a/api/tests/acceptance/application/certification-centers/index_test.js b/api/tests/acceptance/application/certification-centers/index_test.js index 747ac513852..76306e40e19 100644 --- a/api/tests/acceptance/application/certification-centers/index_test.js +++ b/api/tests/acceptance/application/certification-centers/index_test.js @@ -1,12 +1,13 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, sinon, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Certification Centers', function () { let server; diff --git a/api/tests/acceptance/application/certification-centers/sessions-mass-import/certification-centers-controller-post-create-sessions_test.js b/api/tests/acceptance/application/certification-centers/sessions-mass-import/certification-centers-controller-post-create-sessions_test.js index f9fbeaff618..5eeff4a422e 100644 --- a/api/tests/acceptance/application/certification-centers/sessions-mass-import/certification-centers-controller-post-create-sessions_test.js +++ b/api/tests/acceptance/application/certification-centers/sessions-mass-import/certification-centers-controller-post-create-sessions_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, knex, generateValidRequestAuthorizationHeader } = require('../../../../test-helper'); -const createServer = require('../../../../../server'); -const temporarySessionsStorageForMassImportService = require('../../../../../lib/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service'); +import { expect, databaseBuilder, knex, generateValidRequestAuthorizationHeader } from '../../../../test-helper.js'; +import { createServer } from '../../../../../server.js'; +import * as temporarySessionsStorageForMassImportService from '../../../../../lib/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service.js'; describe('Acceptance | Controller | certification-centers-controller-post-create-sessions', function () { describe('POST /api/certification-centers/{certificationCenterId}/sessions/confirm-for-mass-import', function () { diff --git a/api/tests/acceptance/application/certification-centers/sessions-mass-import/certification-centers-controller-post-validate-sessions_test.js b/api/tests/acceptance/application/certification-centers/sessions-mass-import/certification-centers-controller-post-validate-sessions_test.js index 1b58613fe12..630dd452a24 100644 --- a/api/tests/acceptance/application/certification-centers/sessions-mass-import/certification-centers-controller-post-validate-sessions_test.js +++ b/api/tests/acceptance/application/certification-centers/sessions-mass-import/certification-centers-controller-post-validate-sessions_test.js @@ -1,12 +1,15 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, knex, sinon, -} = require('../../../../test-helper'); -const createServer = require('../../../../../server'); -const { omit } = require('lodash'); +} from '../../../../test-helper.js'; + +import { createServer } from '../../../../../server.js'; +import lodash from 'lodash'; + +const { omit } = lodash; describe('Acceptance | Controller | certification-centers-controller-post-validate-sessions', function () { let server; diff --git a/api/tests/acceptance/application/certification-courses/certification-course-controller_test.js b/api/tests/acceptance/application/certification-courses/certification-course-controller_test.js index 37159ff3cb0..deebd91e88b 100644 --- a/api/tests/acceptance/application/certification-courses/certification-course-controller_test.js +++ b/api/tests/acceptance/application/certification-courses/certification-course-controller_test.js @@ -1,4 +1,4 @@ -const { +import { expect, databaseBuilder, knex, @@ -6,14 +6,13 @@ const { mockLearningContent, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { - CertificationIssueReportCategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); -const CertificationAssessment = require('../../../../lib/domain/models/CertificationAssessment'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { CertificationIssueReportCategory } from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; +import { CertificationAssessment } from '../../../../lib/domain/models/CertificationAssessment.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; describe('Acceptance | API | Certification Course', function () { let server; @@ -58,7 +57,7 @@ describe('Acceptance | API | Certification Course', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildCertificationCourse({ id: 1234, isV2Certification: true }); @@ -133,7 +132,7 @@ describe('Acceptance | API | Certification Course', function () { const user = databaseBuilder.factory.buildUser({}); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildCertificationCourse({ id: 1234, isV2Certification: true, userId: user.id }); @@ -535,7 +534,7 @@ describe('Acceptance | API | Certification Course', function () { userId = certificationCourse.userId; databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId: certificationCourse.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, description: "il s'est enfuit de la session", }); @@ -841,7 +840,7 @@ describe('Acceptance | API | Certification Course', function () { context('when locale is fr-fr', function () { beforeEach(async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); certificationCandidate = databaseBuilder.factory.buildCertificationCandidate({ sessionId, @@ -902,7 +901,7 @@ describe('Acceptance | API | Certification Course', function () { context('when locale is en', function () { beforeEach(async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); certificationCandidate = databaseBuilder.factory.buildCertificationCandidate({ sessionId, diff --git a/api/tests/acceptance/application/certification-issue-reports/certification-issue-report-controller_test.js b/api/tests/acceptance/application/certification-issue-reports/certification-issue-report-controller_test.js index faff0888786..d3c43dfe3d5 100644 --- a/api/tests/acceptance/application/certification-issue-reports/certification-issue-report-controller_test.js +++ b/api/tests/acceptance/application/certification-issue-reports/certification-issue-report-controller_test.js @@ -1,11 +1,12 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | certification-issue-report-controller', function () { describe('DELETE /api/certification-issue-reports/{id}', function () { diff --git a/api/tests/acceptance/application/certification-point-of-contacts/certification-point-of-contacts_test.js b/api/tests/acceptance/application/certification-point-of-contacts/certification-point-of-contacts_test.js index 8d91e96c22c..debbed8a847 100644 --- a/api/tests/acceptance/application/certification-point-of-contacts/certification-point-of-contacts_test.js +++ b/api/tests/acceptance/application/certification-point-of-contacts/certification-point-of-contacts_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | CertificationPointOfContact', function () { let server; diff --git a/api/tests/acceptance/application/certification-reports/certification-report-controller_test.js b/api/tests/acceptance/application/certification-reports/certification-report-controller_test.js index ae284c92481..b38dd62e6ce 100644 --- a/api/tests/acceptance/application/certification-reports/certification-report-controller_test.js +++ b/api/tests/acceptance/application/certification-reports/certification-report-controller_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, knex, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | certification-report-controller', function () { let server, certificationCourseId, userId, sessionId, certificationCenterId; diff --git a/api/tests/acceptance/application/certifications-livret-scolaire/certification-controller_test.js b/api/tests/acceptance/application/certifications-livret-scolaire/certification-controller_test.js index 236742395eb..4365a52fa14 100644 --- a/api/tests/acceptance/application/certifications-livret-scolaire/certification-controller_test.js +++ b/api/tests/acceptance/application/certifications-livret-scolaire/certification-controller_test.js @@ -1,18 +1,20 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, generateValidRequestAuthorizationHeaderForApplication, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; + +import { buildOrganization, buildValidatedPublishedCertificationData, mockLearningContentCompetences, buildUser, buildOrganizationLearner, -} = require('../../../../tests/tooling/domain-builder/factory/build-certifications-results-for-ls'); +} from '../../../../tests/tooling/domain-builder/factory/build-certifications-results-for-ls.js'; describe('Acceptance | API | Certifications', function () { let server, options; diff --git a/api/tests/acceptance/application/certifications/index_test.js b/api/tests/acceptance/application/certifications/index_test.js index 9b3adb4dc95..f5eb4d6ff94 100644 --- a/api/tests/acceptance/application/certifications/index_test.js +++ b/api/tests/acceptance/application/certifications/index_test.js @@ -1,17 +1,16 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, mockLearningContent, learningContentBuilder, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { - generateCertificateVerificationCode, -} = require('../../../../lib/domain/services/verify-certificate-code-service'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { generateCertificateVerificationCode } from '../../../../lib/domain/services/verify-certificate-code-service.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; describe('Acceptance | API | Certifications', function () { let server, options; @@ -138,7 +137,7 @@ describe('Acceptance | API | Certifications', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); return databaseBuilder.commit(); diff --git a/api/tests/acceptance/application/challenges/challenge-controller_test.js b/api/tests/acceptance/application/challenges/challenge-controller_test.js index a39698f2330..c544ebf5b76 100644 --- a/api/tests/acceptance/application/challenges/challenge-controller_test.js +++ b/api/tests/acceptance/application/challenges/challenge-controller_test.js @@ -1,5 +1,5 @@ -const { learningContentBuilder, expect, mockLearningContent } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { learningContentBuilder, expect, mockLearningContent } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | API | ChallengeController', function () { let server; @@ -51,7 +51,7 @@ describe('Acceptance | API | ChallengeController', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/competence-evaluations/competence-evaluation-controller_test.js b/api/tests/acceptance/application/competence-evaluations/competence-evaluation-controller_test.js index 822d704e819..2fe8245c532 100644 --- a/api/tests/acceptance/application/competence-evaluations/competence-evaluation-controller_test.js +++ b/api/tests/acceptance/application/competence-evaluations/competence-evaluation-controller_test.js @@ -1,13 +1,15 @@ -const createServer = require('../../../../server'); -const { +import { createServer } from '../../../../server.js'; + +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, knex, mockLearningContent, learningContentBuilder, -} = require('../../../test-helper'); -const { MAX_REACHABLE_PIX_BY_COMPETENCE } = require('../../../../lib/domain/constants'); +} from '../../../test-helper.js'; + +import { MAX_REACHABLE_PIX_BY_COMPETENCE } from '../../../../lib/domain/constants.js'; describe('Acceptance | API | Competence Evaluations', function () { let server; @@ -36,7 +38,7 @@ describe('Acceptance | API | Competence Evaluations', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/complementary-certification-course-results/complementary-certification-course-results-controller_test.js b/api/tests/acceptance/application/complementary-certification-course-results/complementary-certification-course-results-controller_test.js index 26b84646909..d1c664965a7 100644 --- a/api/tests/acceptance/application/complementary-certification-course-results/complementary-certification-course-results-controller_test.js +++ b/api/tests/acceptance/application/complementary-certification-course-results/complementary-certification-course-results-controller_test.js @@ -1,11 +1,12 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; describe('Acceptance | API | Certifications', function () { describe('POST /api/admin/complementary-certification-course-results', function () { diff --git a/api/tests/acceptance/application/complementary-certifications/complementary-certification-controller_test.js b/api/tests/acceptance/application/complementary-certifications/complementary-certification-controller_test.js index 7fd01541829..ac6da6f18d9 100644 --- a/api/tests/acceptance/application/complementary-certifications/complementary-certification-controller_test.js +++ b/api/tests/acceptance/application/complementary-certifications/complementary-certification-controller_test.js @@ -1,11 +1,12 @@ -const { +import { expect, databaseBuilder, insertUserWithRoleSuperAdmin, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { CLEA, PIX_PLUS_EDU_1ER_DEGRE } = require('../../../../lib/domain/models/ComplementaryCertification'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { CLEA, PIX_PLUS_EDU_1ER_DEGRE } from '../../../../lib/domain/models/ComplementaryCertification.js'; describe('Acceptance | API | complementary-certification-controller', function () { let server; diff --git a/api/tests/acceptance/application/countries/countries-controller_test.js b/api/tests/acceptance/application/countries/countries-controller_test.js index ec0b87fd1db..077779f182c 100644 --- a/api/tests/acceptance/application/countries/countries-controller_test.js +++ b/api/tests/acceptance/application/countries/countries-controller_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | API | countries-controller', function () { let server; diff --git a/api/tests/acceptance/application/courses/course-controller_test.js b/api/tests/acceptance/application/courses/course-controller_test.js index 9ed94ef7c18..e4e93be81fc 100644 --- a/api/tests/acceptance/application/courses/course-controller_test.js +++ b/api/tests/acceptance/application/courses/course-controller_test.js @@ -1,11 +1,12 @@ -const { +import { expect, nock, generateValidRequestAuthorizationHeader, mockLearningContent, learningContentBuilder, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | API | Courses', function () { let server; @@ -47,7 +48,7 @@ describe('Acceptance | API | Courses', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/feature-toggles/feature-toggle-controller_test.js b/api/tests/acceptance/application/feature-toggles/feature-toggle-controller_test.js index 91f27b7f13e..c3133d7e9e8 100644 --- a/api/tests/acceptance/application/feature-toggles/feature-toggle-controller_test.js +++ b/api/tests/acceptance/application/feature-toggles/feature-toggle-controller_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../../test-helper'); - -const createServer = require('../../../../server'); +import { expect } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | feature-toggle-controller', function () { let server; diff --git a/api/tests/acceptance/application/feedbacks/feedback-controller_test.js b/api/tests/acceptance/application/feedbacks/feedback-controller_test.js index 8b7d5699be9..0105f9b63b8 100644 --- a/api/tests/acceptance/application/feedbacks/feedback-controller_test.js +++ b/api/tests/acceptance/application/feedbacks/feedback-controller_test.js @@ -1,6 +1,6 @@ -const { expect, knex, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Feedback = require('../../../../lib/infrastructure/orm-models/Feedback'); +import { expect, knex, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { Feedback } from '../../../../lib/infrastructure/orm-models/Feedback.js'; describe('Acceptance | Controller | feedback-controller', function () { let server; diff --git a/api/tests/acceptance/application/finalized-session/finalized-session-controller-find-finalized-sessions-to-publish_test.js b/api/tests/acceptance/application/finalized-session/finalized-session-controller-find-finalized-sessions-to-publish_test.js index b0d27f0de95..75f90031464 100644 --- a/api/tests/acceptance/application/finalized-session/finalized-session-controller-find-finalized-sessions-to-publish_test.js +++ b/api/tests/acceptance/application/finalized-session/finalized-session-controller-find-finalized-sessions-to-publish_test.js @@ -1,10 +1,11 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | finalized-session-controller-find-finalized-sessions-to-publish', function () { let server, options; diff --git a/api/tests/acceptance/application/finalized-session/finalized-session-controller-find-finalized-sessions-with-required-action_test.js b/api/tests/acceptance/application/finalized-session/finalized-session-controller-find-finalized-sessions-with-required-action_test.js index 5a33ac5d2b5..54c81bd9403 100644 --- a/api/tests/acceptance/application/finalized-session/finalized-session-controller-find-finalized-sessions-with-required-action_test.js +++ b/api/tests/acceptance/application/finalized-session/finalized-session-controller-find-finalized-sessions-with-required-action_test.js @@ -1,10 +1,11 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | finalized-session-controller-find-finalized-sessions-with-required-action', function () { describe('GET /api/admin/sessions/with-required-action', function () { diff --git a/api/tests/acceptance/application/frameworks/frameworks-controller_test.js b/api/tests/acceptance/application/frameworks/frameworks-controller_test.js index 60b2e0f4907..6e428f9e85d 100644 --- a/api/tests/acceptance/application/frameworks/frameworks-controller_test.js +++ b/api/tests/acceptance/application/frameworks/frameworks-controller_test.js @@ -1,10 +1,11 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, mockLearningContent, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | frameworks-controller', function () { let server; diff --git a/api/tests/acceptance/application/memberships/membership-controller_test.js b/api/tests/acceptance/application/memberships/membership-controller_test.js index 842b978555f..119420d8195 100644 --- a/api/tests/acceptance/application/memberships/membership-controller_test.js +++ b/api/tests/acceptance/application/memberships/membership-controller_test.js @@ -1,8 +1,7 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader, knex } = require('../../../test-helper'); - -const createServer = require('../../../../server'); -const Membership = require('../../../../lib/domain/models/Membership'); +import _ from 'lodash'; +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, knex } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; describe('Acceptance | Controller | membership-controller', function () { let server; diff --git a/api/tests/acceptance/application/organization-invitations/organization-invitation-controller_test.js b/api/tests/acceptance/application/organization-invitations/organization-invitation-controller_test.js index 1c6c20eff93..8a3790ec369 100644 --- a/api/tests/acceptance/application/organization-invitations/organization-invitation-controller_test.js +++ b/api/tests/acceptance/application/organization-invitations/organization-invitation-controller_test.js @@ -1,9 +1,7 @@ -const { expect, knex, databaseBuilder } = require('../../../test-helper'); - -const Membership = require('../../../../lib/domain/models/Membership'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); - -const createServer = require('../../../../server'); +import { expect, knex, databaseBuilder } from '../../../test-helper.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Application | organization-invitation-controller', function () { let server; diff --git a/api/tests/acceptance/application/organization-learners/organization-learner-controller_test.js b/api/tests/acceptance/application/organization-learners/organization-learner-controller_test.js index f90b6657638..425cf4a27d9 100644 --- a/api/tests/acceptance/application/organization-learners/organization-learner-controller_test.js +++ b/api/tests/acceptance/application/organization-learners/organization-learner-controller_test.js @@ -1,12 +1,12 @@ -const { +import { databaseBuilder, expect, insertUserWithRoleSuperAdmin, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); -const Membership = require('../../../../lib/domain/models/Membership'); +import { createServer } from '../../../../server.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; describe('Acceptance | Controller | organization-learner', function () { let server; diff --git a/api/tests/acceptance/application/organizations-administration/organization-administration-get_test.js b/api/tests/acceptance/application/organizations-administration/organization-administration-get_test.js index 81af934311f..5658d311a26 100644 --- a/api/tests/acceptance/application/organizations-administration/organization-administration-get_test.js +++ b/api/tests/acceptance/application/organizations-administration/organization-administration-get_test.js @@ -1,11 +1,11 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); +import { createServer } from '../../../../server.js'; describe('Acceptance | Routes | organization-administration-controller', function () { let server; diff --git a/api/tests/acceptance/application/organizations-administration/organization-administration-patch_test.js b/api/tests/acceptance/application/organizations-administration/organization-administration-patch_test.js index 578b6bb0b50..65caaf0a0c5 100644 --- a/api/tests/acceptance/application/organizations-administration/organization-administration-patch_test.js +++ b/api/tests/acceptance/application/organizations-administration/organization-administration-patch_test.js @@ -1,12 +1,12 @@ -const { +import { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); +import { createServer } from '../../../../server.js'; describe('Acceptance | Routes | organization-administration-controller', function () { let server; diff --git a/api/tests/acceptance/application/organizations/cancel-organization-invitation-delete_test.js b/api/tests/acceptance/application/organizations/cancel-organization-invitation-delete_test.js index fcef19cebf2..b07190b33b3 100644 --- a/api/tests/acceptance/application/organizations/cancel-organization-invitation-delete_test.js +++ b/api/tests/acceptance/application/organizations/cancel-organization-invitation-delete_test.js @@ -1,12 +1,13 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertOrganizationUserWithRoleAdmin, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; describe('Acceptance | Route | Organizations', function () { describe('DELETE /api/organizations/{id}/invitations/{invitationId}', function () { diff --git a/api/tests/acceptance/application/organizations/create-organization-places-lot_test.js b/api/tests/acceptance/application/organizations/create-organization-places-lot_test.js index 6c504d49c18..20edf59c0e4 100644 --- a/api/tests/acceptance/application/organizations/create-organization-places-lot_test.js +++ b/api/tests/acceptance/application/organizations/create-organization-places-lot_test.js @@ -1,12 +1,13 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const organizationPlacesCategories = require('../../../../lib/domain/constants/organization-places-categories'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import * as organizationPlacesCategories from '../../../../lib/domain/constants/organization-places-categories.js'; describe('Acceptance | Route | Organizations', function () { describe('POST /api/admin/organizations/{id}/places', function () { diff --git a/api/tests/acceptance/application/organizations/delete-organization-places-lot_test.js b/api/tests/acceptance/application/organizations/delete-organization-places-lot_test.js index c2a65f40067..760a83fc930 100644 --- a/api/tests/acceptance/application/organizations/delete-organization-places-lot_test.js +++ b/api/tests/acceptance/application/organizations/delete-organization-places-lot_test.js @@ -1,10 +1,11 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Organizations', function () { describe('DELETE /api/admin/organizations/{id}/places/{placeId}', function () { diff --git a/api/tests/acceptance/application/organizations/find-organization-places_test.js b/api/tests/acceptance/application/organizations/find-organization-places_test.js index 0eed3db688e..67458f9115d 100644 --- a/api/tests/acceptance/application/organizations/find-organization-places_test.js +++ b/api/tests/acceptance/application/organizations/find-organization-places_test.js @@ -1,11 +1,12 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const organizationPlacesLotCategories = require('../../../../lib/domain/constants/organization-places-categories'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import * as organizationPlacesLotCategories from '../../../../lib/domain/constants/organization-places-categories.js'; describe('Acceptance | Route | Organizations', function () { describe('GET /api/admin/organizations/{id}/places', function () { diff --git a/api/tests/acceptance/application/organizations/get-organization-places-capacity_test.js b/api/tests/acceptance/application/organizations/get-organization-places-capacity_test.js index e5a943ec2bd..0796900102a 100644 --- a/api/tests/acceptance/application/organizations/get-organization-places-capacity_test.js +++ b/api/tests/acceptance/application/organizations/get-organization-places-capacity_test.js @@ -1,11 +1,12 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const categories = require('../../../../lib/domain/constants/organization-places-categories'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import * as categories from '../../../../lib/domain/constants/organization-places-categories.js'; describe('Acceptance | Route | Organizations', function () { describe('GET /api/admin/organizations/{id}/places/capacity', function () { diff --git a/api/tests/acceptance/application/organizations/organization-controller-import-sco-organization-learners_test.js b/api/tests/acceptance/application/organizations/organization-controller-import-sco-organization-learners_test.js index 22ec2820ae8..1ec9cb9c11a 100644 --- a/api/tests/acceptance/application/organizations/organization-controller-import-sco-organization-learners_test.js +++ b/api/tests/acceptance/application/organizations/organization-controller-import-sco-organization-learners_test.js @@ -1,13 +1,13 @@ -const _ = require('lodash'); -const iconv = require('iconv-lite'); -const { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); - -const createServer = require('../../../../server'); -require('events').EventEmitter.defaultMaxListeners = 60; - -const Membership = require('../../../../lib/domain/models/Membership'); -const OrganizationLearnerImportHeader = require('../../../../lib/infrastructure/serializers/csv/organization-learner-import-header'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import _ from 'lodash'; +import iconv from 'iconv-lite'; +import { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { EventEmitter } from 'events'; +EventEmitter.defaultMaxListeners = 60; + +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { OrganizationLearnerImportHeader } from '../../../../lib/infrastructure/serializers/csv/organization-learner-import-header.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; const i18n = getI18n(); const organizationLearnerCsvColumns = new OrganizationLearnerImportHeader(i18n).columns diff --git a/api/tests/acceptance/application/organizations/organization-controller-import-sup-organization-learners_test.js b/api/tests/acceptance/application/organizations/organization-controller-import-sup-organization-learners_test.js index 7fae2079789..58ffa4eccf3 100644 --- a/api/tests/acceptance/application/organizations/organization-controller-import-sup-organization-learners_test.js +++ b/api/tests/acceptance/application/organizations/organization-controller-import-sup-organization-learners_test.js @@ -1,9 +1,8 @@ -const { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const Membership = require('../../../../lib/domain/models/Membership'); -const SupOrganizationLearnerImportHeader = require('../../../../lib/infrastructure/serializers/csv/sup-organization-learner-import-header'); - -const { getI18n } = require('../../../../tests/tooling/i18n/i18n'); -const createServer = require('../../../../server'); +import { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { SupOrganizationLearnerImportHeader } from '../../../../lib/infrastructure/serializers/csv/sup-organization-learner-import-header.js'; +import { getI18n } from '../../../../tests/tooling/i18n/i18n.js'; +import { createServer } from '../../../../server.js'; const i18n = getI18n(); const supOrganizationLearnerImportHeader = new SupOrganizationLearnerImportHeader(i18n).columns diff --git a/api/tests/acceptance/application/organizations/organization-controller-replace-sup-organization-learners_test.js b/api/tests/acceptance/application/organizations/organization-controller-replace-sup-organization-learners_test.js index 594d1595039..cea666894b6 100644 --- a/api/tests/acceptance/application/organizations/organization-controller-replace-sup-organization-learners_test.js +++ b/api/tests/acceptance/application/organizations/organization-controller-replace-sup-organization-learners_test.js @@ -1,9 +1,8 @@ -const { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const Membership = require('../../../../lib/domain/models/Membership'); -const SupOrganizationLearnerImportHeader = require('../../../../lib/infrastructure/serializers/csv/sup-organization-learner-import-header'); - -const { getI18n } = require('../../../../tests/tooling/i18n/i18n'); -const createServer = require('../../../../server'); +import { expect, knex, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { SupOrganizationLearnerImportHeader } from '../../../../lib/infrastructure/serializers/csv/sup-organization-learner-import-header.js'; +import { getI18n } from '../../../../tests/tooling/i18n/i18n.js'; +import { createServer } from '../../../../server.js'; const i18n = getI18n(); const supOrganizationLearnerImportHeader = new SupOrganizationLearnerImportHeader(i18n).columns diff --git a/api/tests/acceptance/application/organizations/organization-controller_test.js b/api/tests/acceptance/application/organizations/organization-controller_test.js index 0ba56270e25..5b59150d86a 100644 --- a/api/tests/acceptance/application/organizations/organization-controller_test.js +++ b/api/tests/acceptance/application/organizations/organization-controller_test.js @@ -1,7 +1,7 @@ -const _map = require('lodash/map'); -const _omit = require('lodash/omit'); +import lodash from 'lodash'; +const { map: _map, omit: _omit } = lodash; -const { +import { expect, knex, learningContentBuilder, @@ -10,15 +10,14 @@ const { generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, sinon, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); - -const Membership = require('../../../../lib/domain/models/Membership'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); +import { createServer } from '../../../../server.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; describe('Acceptance | Application | organization-controller', function () { let server; @@ -1537,7 +1536,7 @@ describe('Acceptance | Application | organization-controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); user = databaseBuilder.factory.buildUser({}); @@ -1821,7 +1820,7 @@ describe('Acceptance | Application | organization-controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/organizations/send-invitation-by-lang-and-role-route-post_test.js b/api/tests/acceptance/application/organizations/send-invitation-by-lang-and-role-route-post_test.js index f9f6f7f0734..90bc2eeecd7 100644 --- a/api/tests/acceptance/application/organizations/send-invitation-by-lang-and-role-route-post_test.js +++ b/api/tests/acceptance/application/organizations/send-invitation-by-lang-and-role-route-post_test.js @@ -1,12 +1,13 @@ -const { +import { databaseBuilder, expect, knex, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const Membership = require('../../../../lib/domain/models/Membership'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; describe('Acceptance | Route | Organizations', function () { describe('POST /api/admin/organizations/{id}/invitations', function () { diff --git a/api/tests/acceptance/application/passwords/password-controller_test.js b/api/tests/acceptance/application/passwords/password-controller_test.js index c616c288380..be58d8e14ee 100644 --- a/api/tests/acceptance/application/passwords/password-controller_test.js +++ b/api/tests/acceptance/application/passwords/password-controller_test.js @@ -1,11 +1,9 @@ -const { databaseBuilder, expect, knex, sinon } = require('../../../test-helper'); -const tokenService = require('../../../../lib/domain/services/token-service'); -const resetPasswordService = require('../../../../lib/domain/services/reset-password-service'); -const resetPasswordDemandRepository = require('../../../../lib/infrastructure/repositories/reset-password-demands-repository'); +import { databaseBuilder, expect, knex } from '../../../test-helper.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import * as resetPasswordService from '../../../../lib/domain/services/reset-password-service.js'; -const config = require('../../../../lib/config'); - -const createServer = require('../../../../server'); +import { config } from '../../../../lib/config.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | password-controller', function () { const email = 'user@example.net'; @@ -63,19 +61,6 @@ describe('Acceptance | Controller | password-controller', function () { expect(response.statusCode).to.equal(201); }); }); - - context('when existing email is provided, but some internal error has occurred', function () { - it('should reply with 500', async function () { - // given - sinon.stub(resetPasswordDemandRepository, 'create').rejects(new Error()); - - // when - const response = await server.inject(options); - - // then - expect(response.statusCode).to.equal(500); - }); - }); }); describe('GET /api/password-reset-demands/{temporaryKey}', function () { @@ -115,19 +100,6 @@ describe('Acceptance | Controller | password-controller', function () { }); }); - context('when something going wrong', function () { - it('should reply with 500 status code', async function () { - // given - sinon.stub(resetPasswordService, 'verifyDemand').rejects(new Error()); - - // when - const response = await server.inject(options); - - // then - expect(response.statusCode).to.equal(500); - }); - }); - context('when temporaryKey is linked to a password reset demand', function () { beforeEach(async function () { databaseBuilder.factory.buildUser({ email }); diff --git a/api/tests/acceptance/application/pole-emploi/envois-route-get_test.js b/api/tests/acceptance/application/pole-emploi/envois-route-get_test.js index 17043745aab..fc41d9f2ad3 100644 --- a/api/tests/acceptance/application/pole-emploi/envois-route-get_test.js +++ b/api/tests/acceptance/application/pole-emploi/envois-route-get_test.js @@ -1,13 +1,14 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeaderForApplication, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; + const poleEmploiSendingFactory = databaseBuilder.factory.poleEmploiSendingFactory; -const createServer = require('../../../../server'); -const settings = require('../../../../lib/config'); +import { createServer } from '../../../../server.js'; +import { config as settings } from '../../../../lib/config.js'; describe('Acceptance | API | Pole Emploi envois', function () { let server, options; diff --git a/api/tests/acceptance/application/prescribers/prescriber-controller_test.js b/api/tests/acceptance/application/prescribers/prescriber-controller_test.js index bf728d62171..ca416717375 100644 --- a/api/tests/acceptance/application/prescribers/prescriber-controller_test.js +++ b/api/tests/acceptance/application/prescribers/prescriber-controller_test.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | Prescriber-controller', function () { let user; diff --git a/api/tests/acceptance/application/progressions/progression-controller_test.js b/api/tests/acceptance/application/progressions/progression-controller_test.js index 4cf2fa72285..ecdf83d8eab 100644 --- a/api/tests/acceptance/application/progressions/progression-controller_test.js +++ b/api/tests/acceptance/application/progressions/progression-controller_test.js @@ -1,11 +1,12 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, mockLearningContent, learningContentBuilder, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | API | Progressions', function () { let server; @@ -41,7 +42,7 @@ describe('Acceptance | API | Progressions', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); userId = databaseBuilder.factory.buildUser({}).id; diff --git a/api/tests/acceptance/application/saml/saml-controller_test.js b/api/tests/acceptance/application/saml/saml-controller_test.js index fdeb76c5a15..e245ded67c6 100644 --- a/api/tests/acceptance/application/saml/saml-controller_test.js +++ b/api/tests/acceptance/application/saml/saml-controller_test.js @@ -1,10 +1,10 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { databaseBuilder, expect, sinon } = require('../../../test-helper'); +import { databaseBuilder, expect, sinon } from '../../../test-helper.js'; -const samlify = require('samlify'); -const createServer = require('../../../../server'); -const settings = require('../../../../lib/config'); +import samlify from 'samlify'; +import { createServer } from '../../../../server.js'; +import { config as settings } from '../../../../lib/config.js'; const testCertificate = `MIICCzCCAXQCCQD2MlHh/QmGmjANBgkqhkiG9w0BAQsFADBKMQswCQYDVQQGEwJG UjEPMA0GA1UECAwGRlJBTkNFMQ4wDAYDVQQHDAVQQVJJUzEMMAoGA1UECgwDUElY diff --git a/api/tests/acceptance/application/sco-organization-learners/sco-organization-learner-controller_test.js b/api/tests/acceptance/application/sco-organization-learners/sco-organization-learner-controller_test.js index 29fa9d04005..1a02b5f7e99 100644 --- a/api/tests/acceptance/application/sco-organization-learners/sco-organization-learner-controller_test.js +++ b/api/tests/acceptance/application/sco-organization-learners/sco-organization-learner-controller_test.js @@ -1,13 +1,13 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, knex, generateIdTokenForExternalUser, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); +import { createServer } from '../../../../server.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; describe('Acceptance | Controller | sco-organization-learners', function () { let server; diff --git a/api/tests/acceptance/application/scorecards/scorecard-controller_test.js b/api/tests/acceptance/application/scorecards/scorecard-controller_test.js index 91c1a332b49..0a84d709092 100644 --- a/api/tests/acceptance/application/scorecards/scorecard-controller_test.js +++ b/api/tests/acceptance/application/scorecards/scorecard-controller_test.js @@ -1,14 +1,17 @@ -const { +import { databaseBuilder, expect, knex, generateValidRequestAuthorizationHeader, mockLearningContent, -} = require('../../../test-helper'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_SPOKEN } = LOCALE; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | scorecard-controller', function () { let options; diff --git a/api/tests/acceptance/application/scoring-simulator/scoring-simulator-controller_test.js b/api/tests/acceptance/application/scoring-simulator/scoring-simulator-controller_test.js index 3af35bc07dc..1d8af0b10e5 100644 --- a/api/tests/acceptance/application/scoring-simulator/scoring-simulator-controller_test.js +++ b/api/tests/acceptance/application/scoring-simulator/scoring-simulator-controller_test.js @@ -1,13 +1,14 @@ -const { expect } = require('chai'); -const createServer = require('../../../../server'); -const { - databaseBuilder, - generateValidRequestAuthorizationHeader, - mockLearningContent, -} = require('../../../test-helper'); -const { - ROLES: { SUPER_ADMIN }, -} = require('../../../../lib/domain/constants').PIX_ADMIN; +import chai from 'chai'; + +const { expect } = chai; + +import { createServer } from '../../../../server.js'; + +import { databaseBuilder, generateValidRequestAuthorizationHeader, mockLearningContent } from '../../../test-helper.js'; + +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; const isoDateFormat = /^\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d\.\d\d\d.*$/; @@ -19,7 +20,7 @@ describe('Acceptance | Controller | scoring-simulator-controller', function () { server = await createServer(); const { id: adminId } = databaseBuilder.factory.buildUser.withRole({ - role: SUPER_ADMIN, + role: ROLES.SUPER_ADMIN, }); adminAuthorization = generateValidRequestAuthorizationHeader(adminId); await databaseBuilder.commit(); diff --git a/api/tests/acceptance/application/security-pre-handlers_test.js b/api/tests/acceptance/application/security-pre-handlers_test.js index 11e97f46a8f..088a65ec57c 100644 --- a/api/tests/acceptance/application/security-pre-handlers_test.js +++ b/api/tests/acceptance/application/security-pre-handlers_test.js @@ -1,7 +1,7 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../test-helper'); -const createServer = require('../../../server'); -const Membership = require('../../../lib/domain/models/Membership'); -const securityPreHandlers = require('../../../lib/application/security-pre-handlers'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../test-helper.js'; +import { createServer } from '../../../server.js'; +import { Membership } from '../../../lib/domain/models/Membership.js'; +import { securityPreHandlers } from '../../../lib/application/security-pre-handlers.js'; describe('Acceptance | Application | SecurityPreHandlers', function () { const jsonApiError403 = { diff --git a/api/tests/acceptance/application/session/session-controller-create-certification-candidate-participation_test.js b/api/tests/acceptance/application/session/session-controller-create-certification-candidate-participation_test.js index e5e7b773873..e61b380baa4 100644 --- a/api/tests/acceptance/application/session/session-controller-create-certification-candidate-participation_test.js +++ b/api/tests/acceptance/application/session/session-controller-create-certification-candidate-participation_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const _ = require('lodash'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import _ from 'lodash'; describe('Acceptance | Controller | session-controller-create-certification-candidate-participation', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-delete-certification-candidate_test.js b/api/tests/acceptance/application/session/session-controller-delete-certification-candidate_test.js index 94223657349..1765d46a3e7 100644 --- a/api/tests/acceptance/application/session/session-controller-delete-certification-candidate_test.js +++ b/api/tests/acceptance/application/session/session-controller-delete-certification-candidate_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-delete-certification-candidate', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-delete-comment_test.js b/api/tests/acceptance/application/session/session-controller-delete-comment_test.js index dd67d721f1f..90a92cdb12b 100644 --- a/api/tests/acceptance/application/session/session-controller-delete-comment_test.js +++ b/api/tests/acceptance/application/session/session-controller-delete-comment_test.js @@ -1,10 +1,11 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | sessions-controller', function () { describe('DELETE /sessions/{id}/comment', function () { diff --git a/api/tests/acceptance/application/session/session-controller-delete_test.js b/api/tests/acceptance/application/session/session-controller-delete_test.js index d52d25b5672..1a5b4288726 100644 --- a/api/tests/acceptance/application/session/session-controller-delete_test.js +++ b/api/tests/acceptance/application/session/session-controller-delete_test.js @@ -1,5 +1,5 @@ -const { knex, expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { knex, expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | sessions-controller', function () { describe('DELETE /sessions/{id}', function () { diff --git a/api/tests/acceptance/application/session/session-controller-enroll-students_test.js b/api/tests/acceptance/application/session/session-controller-enroll-students_test.js index 055afc01c45..495471b686d 100644 --- a/api/tests/acceptance/application/session/session-controller-enroll-students_test.js +++ b/api/tests/acceptance/application/session/session-controller-enroll-students_test.js @@ -1,11 +1,6 @@ -const { - sinon, - expect, - databaseBuilder, - generateValidRequestAuthorizationHeader, - knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { sinon, expect, databaseBuilder, generateValidRequestAuthorizationHeader, knex } from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-enrol-students-to-session', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-generate-session-results-download-link_test.js b/api/tests/acceptance/application/session/session-controller-generate-session-results-download-link_test.js index a6653f7e9e0..81cac1a5481 100644 --- a/api/tests/acceptance/application/session/session-controller-generate-session-results-download-link_test.js +++ b/api/tests/acceptance/application/session/session-controller-generate-session-results-download-link_test.js @@ -1,10 +1,11 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-generate-session-results-download-link', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-get-attendance-sheet_test.js b/api/tests/acceptance/application/session/session-controller-get-attendance-sheet_test.js index 293b9590477..da2d83fe5c3 100644 --- a/api/tests/acceptance/application/session/session-controller-get-attendance-sheet_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-attendance-sheet_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-get-attendance-sheet', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-get-candidates-import-sheet_test.js b/api/tests/acceptance/application/session/session-controller-get-candidates-import-sheet_test.js index 82266b12ed2..915dbbbb58d 100644 --- a/api/tests/acceptance/application/session/session-controller-get-candidates-import-sheet_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-candidates-import-sheet_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-get-candidates-import-sheet', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-get-certification-candidates_test.js b/api/tests/acceptance/application/session/session-controller-get-certification-candidates_test.js index 8dcbe312c9c..2a12d350efc 100644 --- a/api/tests/acceptance/application/session/session-controller-get-certification-candidates_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-certification-candidates_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const _ = require('lodash'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import _ from 'lodash'; describe('Acceptance | Controller | session-controller-get-certification-candidates', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-get-certification-reports_test.js b/api/tests/acceptance/application/session/session-controller-get-certification-reports_test.js index 4b18d176e8a..f5e81bc0f60 100644 --- a/api/tests/acceptance/application/session/session-controller-get-certification-reports_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-certification-reports_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-get-certification-reports', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-get-jury-certification-summaries_test.js b/api/tests/acceptance/application/session/session-controller-get-jury-certification-summaries_test.js index 78330b9e6e8..04bb1a32852 100644 --- a/api/tests/acceptance/application/session/session-controller-get-jury-certification-summaries_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-jury-certification-summaries_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { CLEA } = require('../../../../lib/domain/models/ComplementaryCertification'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { CLEA } from '../../../../lib/domain/models/ComplementaryCertification.js'; describe('Acceptance | Controller | session-controller-get-jury-certification-summaries', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-get-jury-session_test.js b/api/tests/acceptance/application/session/session-controller-get-jury-session_test.js index bacb8773b85..7f5e7efaf26 100644 --- a/api/tests/acceptance/application/session/session-controller-get-jury-session_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-jury-session_test.js @@ -1,10 +1,11 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-get-jury-session', function () { let server, options; diff --git a/api/tests/acceptance/application/session/session-controller-get-session-results-by-result-recipient-email_test.js b/api/tests/acceptance/application/session/session-controller-get-session-results-by-result-recipient-email_test.js index 22d46532759..8e85d40ebff 100644 --- a/api/tests/acceptance/application/session/session-controller-get-session-results-by-result-recipient-email_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-session-results-by-result-recipient-email_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const jsonwebtoken = require('jsonwebtoken'); -const settings = require('../../../../lib/config'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import jsonwebtoken from 'jsonwebtoken'; +import { config as settings } from '../../../../lib/config.js'; describe('Acceptance | Controller | session-controller-get-session-results-by-result-recipient-email', function () { describe('GET /api/sessions/download-results/{token}', function () { diff --git a/api/tests/acceptance/application/session/session-controller-get-session-results-to-download_test.js b/api/tests/acceptance/application/session/session-controller-get-session-results-to-download_test.js index fb277e14e69..129b82d7f89 100644 --- a/api/tests/acceptance/application/session/session-controller-get-session-results-to-download_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-session-results-to-download_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const jsonwebtoken = require('jsonwebtoken'); -const settings = require('../../../../lib/config'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import jsonwebtoken from 'jsonwebtoken'; +import { config as settings } from '../../../../lib/config.js'; describe('Acceptance | Controller | session-controller-get-session-results-to-download', function () { describe('GET /api/sessions/download-all-results/{token}', function () { diff --git a/api/tests/acceptance/application/session/session-controller-get-supervisor-kit-PDF_test.js b/api/tests/acceptance/application/session/session-controller-get-supervisor-kit-PDF_test.js index 2fb7b47e5a2..838a0e3f88c 100644 --- a/api/tests/acceptance/application/session/session-controller-get-supervisor-kit-PDF_test.js +++ b/api/tests/acceptance/application/session/session-controller-get-supervisor-kit-PDF_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-get-supervisor-kit-pdf', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-get_test.js b/api/tests/acceptance/application/session/session-controller-get_test.js index a7024046173..3a2a06d2e25 100644 --- a/api/tests/acceptance/application/session/session-controller-get_test.js +++ b/api/tests/acceptance/application/session/session-controller-get_test.js @@ -1,10 +1,11 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-get', function () { let server, options; diff --git a/api/tests/acceptance/application/session/session-controller-import-certification-candidates-from-attendance-sheet_reports_categorization_test.js b/api/tests/acceptance/application/session/session-controller-import-certification-candidates-from-attendance-sheet_reports_categorization_test.js index 4c60671cb6e..84fa9a3f973 100644 --- a/api/tests/acceptance/application/session/session-controller-import-certification-candidates-from-attendance-sheet_reports_categorization_test.js +++ b/api/tests/acceptance/application/session/session-controller-import-certification-candidates-from-attendance-sheet_reports_categorization_test.js @@ -1,6 +1,8 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader, knex } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const fs = require('fs'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, knex } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import fs from 'fs'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Acceptance | Controller | session-controller-import-certification-candidates-from-attendance-sheet', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-patch-publish-session_test.js b/api/tests/acceptance/application/session/session-controller-patch-publish-session_test.js index f900dfb24a7..373054d96cc 100644 --- a/api/tests/acceptance/application/session/session-controller-patch-publish-session_test.js +++ b/api/tests/acceptance/application/session/session-controller-patch-publish-session_test.js @@ -1,6 +1,6 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder, knex } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { status } = require('../../../../lib/domain/models/AssessmentResult'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, knex } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { status } from '../../../../lib/domain/models/AssessmentResult.js'; describe('PATCH /api/admin/sessions/:id/publish', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-patch-unpublish-session_test.js b/api/tests/acceptance/application/session/session-controller-patch-unpublish-session_test.js index 5f2be18441a..0a06167b272 100644 --- a/api/tests/acceptance/application/session/session-controller-patch-unpublish-session_test.js +++ b/api/tests/acceptance/application/session/session-controller-patch-unpublish-session_test.js @@ -1,6 +1,6 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder, knex } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { status } = require('../../../../lib/domain/models/AssessmentResult'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, knex } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { status } from '../../../../lib/domain/models/AssessmentResult.js'; describe('PATCH /api/admin/sessions/:id/unpublish', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-patch-user-assignment_test.js b/api/tests/acceptance/application/session/session-controller-patch-user-assignment_test.js index d35fea1e6be..7ac6a87674c 100644 --- a/api/tests/acceptance/application/session/session-controller-patch-user-assignment_test.js +++ b/api/tests/acceptance/application/session/session-controller-patch-user-assignment_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('PATCH /api/admin/sessions/:id/certification-officer-assignment', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-patch_test.js b/api/tests/acceptance/application/session/session-controller-patch_test.js index 2f9e4fcb643..a289622100c 100644 --- a/api/tests/acceptance/application/session/session-controller-patch_test.js +++ b/api/tests/acceptance/application/session/session-controller-patch_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-patch', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-post-certification-candidates_test.js b/api/tests/acceptance/application/session/session-controller-post-certification-candidates_test.js index 08b5f532315..7448f826d3f 100644 --- a/api/tests/acceptance/application/session/session-controller-post-certification-candidates_test.js +++ b/api/tests/acceptance/application/session/session-controller-post-certification-candidates_test.js @@ -1,12 +1,14 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { expect, databaseBuilder, domainBuilder, generateValidRequestAuthorizationHeader, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-controller-post-certification-candidates', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-publish-session-in-batch_test.js b/api/tests/acceptance/application/session/session-controller-publish-session-in-batch_test.js index 5f2b97fd839..a4d13120b80 100644 --- a/api/tests/acceptance/application/session/session-controller-publish-session-in-batch_test.js +++ b/api/tests/acceptance/application/session/session-controller-publish-session-in-batch_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('POST /api/admin/sessions/publish-in-batch', function () { let server; diff --git a/api/tests/acceptance/application/session/session-controller-put-comment_test.js b/api/tests/acceptance/application/session/session-controller-put-comment_test.js index af9be2eea20..f47872e95ca 100644 --- a/api/tests/acceptance/application/session/session-controller-put-comment_test.js +++ b/api/tests/acceptance/application/session/session-controller-put-comment_test.js @@ -1,10 +1,11 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | sessions-controller', function () { describe('PUT /sessions/{id}/comment', function () { diff --git a/api/tests/acceptance/application/session/session-controller-put-finalization_test.js b/api/tests/acceptance/application/session/session-controller-put-finalization_test.js index 3a561866f18..cf1d4530978 100644 --- a/api/tests/acceptance/application/session/session-controller-put-finalization_test.js +++ b/api/tests/acceptance/application/session/session-controller-put-finalization_test.js @@ -1,18 +1,19 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, knex, learningContentBuilder, mockLearningContent, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { - CertificationIssueReportCategories, +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { + CertificationIssueReportCategory, CertificationIssueReportSubcategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const CertificationResult = require('../../../../lib/domain/models/CertificationResult'); +} from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { CertificationResult } from '../../../../lib/domain/models/CertificationResult.js'; describe('Acceptance | Controller | sessions-controller', function () { let options; @@ -149,7 +150,7 @@ describe('Acceptance | Controller | sessions-controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); const userId = databaseBuilder.factory.buildUser().id; @@ -167,7 +168,7 @@ describe('Acceptance | Controller | sessions-controller', function () { const assessmentId = databaseBuilder.factory.buildAssessment({ certificationCourseId }).id; databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, description: '', subcategory: CertificationIssueReportSubcategories.WEBSITE_BLOCKED, questionNumber: 1, @@ -265,7 +266,7 @@ describe('Acceptance | Controller | sessions-controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); const userId = databaseBuilder.factory.buildUser().id; @@ -286,7 +287,7 @@ describe('Acceptance | Controller | sessions-controller', function () { const assessmentId = databaseBuilder.factory.buildAssessment({ certificationCourseId }).id; databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, description: '', subcategory: CertificationIssueReportSubcategories.WEBSITE_BLOCKED, questionNumber: 1, @@ -371,7 +372,7 @@ describe('Acceptance | Controller | sessions-controller', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); const userId = databaseBuilder.factory.buildUser().id; @@ -394,7 +395,7 @@ describe('Acceptance | Controller | sessions-controller', function () { const assessmentId = databaseBuilder.factory.buildAssessment({ certificationCourseId, userId }).id; databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, description: '', subcategory: CertificationIssueReportSubcategories.WEBSITE_BLOCKED, questionNumber: 1, diff --git a/api/tests/acceptance/application/session/session-controller-put-results-sent-to-prescriber_test.js b/api/tests/acceptance/application/session/session-controller-put-results-sent-to-prescriber_test.js index eee7df249dc..544c503a46b 100644 --- a/api/tests/acceptance/application/session/session-controller-put-results-sent-to-prescriber_test.js +++ b/api/tests/acceptance/application/session/session-controller-put-results-sent-to-prescriber_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('PUT /api/admin/sessions/:id/results-sent-to-prescriber', function () { let server; diff --git a/api/tests/acceptance/application/session/session-for-supervising-controller-get_test.js b/api/tests/acceptance/application/session/session-for-supervising-controller-get_test.js index 45f95c58c8e..8b8c4ea083b 100644 --- a/api/tests/acceptance/application/session/session-for-supervising-controller-get_test.js +++ b/api/tests/acceptance/application/session/session-for-supervising-controller-get_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-for-supervising-controller-get', function () { let server; diff --git a/api/tests/acceptance/application/session/session-for-supervising-controller-supervise_test.js b/api/tests/acceptance/application/session/session-for-supervising-controller-supervise_test.js index 8b3bb070131..722be8562ee 100644 --- a/api/tests/acceptance/application/session/session-for-supervising-controller-supervise_test.js +++ b/api/tests/acceptance/application/session/session-for-supervising-controller-supervise_test.js @@ -1,11 +1,12 @@ -const { +import { expect, databaseBuilder, domainBuilder, generateValidRequestAuthorizationHeader, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | session-for-supervising-controller-supervise', function () { let server; diff --git a/api/tests/acceptance/application/session/session-with-clea-certified-candidate-controller-get-clea-certified-candidate-data-csv.js b/api/tests/acceptance/application/session/session-with-clea-certified-candidate-controller-get-clea-certified-candidate-data-csv.js index b241435d5bd..52a67de537a 100644 --- a/api/tests/acceptance/application/session/session-with-clea-certified-candidate-controller-get-clea-certified-candidate-data-csv.js +++ b/api/tests/acceptance/application/session/session-with-clea-certified-candidate-controller-get-clea-certified-candidate-data-csv.js @@ -1,6 +1,6 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { CLEA } = require('../../../../lib/domain/models/ComplementaryCertification'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { CLEA } from '../../../../lib/domain/models/ComplementaryCertification.js'; describe('Acceptance | Controller | session-with-clea-certified-candidate', function () { describe('GET /api/sessions/{id}/certified-clea-candidate-data', function () { diff --git a/api/tests/acceptance/application/sup-organization-learners/sup-organization-learner-controller_test.js b/api/tests/acceptance/application/sup-organization-learners/sup-organization-learner-controller_test.js index 1faa567e682..915d9ff1667 100644 --- a/api/tests/acceptance/application/sup-organization-learners/sup-organization-learner-controller_test.js +++ b/api/tests/acceptance/application/sup-organization-learners/sup-organization-learner-controller_test.js @@ -1,7 +1,6 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); - -const createServer = require('../../../../server'); -const Membership = require('../../../../lib/domain/models/Membership'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; describe('Acceptance | Controller | sup-organization-learners', function () { let server; diff --git a/api/tests/acceptance/application/swagger_test.js b/api/tests/acceptance/application/swagger_test.js index b56a8319c16..3b8ec3df66c 100644 --- a/api/tests/acceptance/application/swagger_test.js +++ b/api/tests/acceptance/application/swagger_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../test-helper'); -const createServer = require('../../../server'); +import { expect } from '../../test-helper.js'; +import { createServer } from '../../../server.js'; describe('Acceptance | Controller | swagger', function () { let server; diff --git a/api/tests/acceptance/application/tags/tag-api_test.js b/api/tests/acceptance/application/tags/tag-api_test.js index bd7614e19a1..9707b793c55 100644 --- a/api/tests/acceptance/application/tags/tag-api_test.js +++ b/api/tests/acceptance/application/tags/tag-api_test.js @@ -1,13 +1,15 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, insertUserWithRoleCertif, databaseBuilder, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | tag-router', function () { describe('POST /api/admin/tags', function () { diff --git a/api/tests/acceptance/application/target-profiles/index_test.js b/api/tests/acceptance/application/target-profiles/index_test.js index e774b84a74f..53e0c3879a7 100644 --- a/api/tests/acceptance/application/target-profiles/index_test.js +++ b/api/tests/acceptance/application/target-profiles/index_test.js @@ -1,4 +1,4 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, @@ -6,9 +6,11 @@ const { mockLearningContent, learningContentBuilder, MockDate, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const omit = require('lodash/omit'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import lodash from 'lodash'; +const { omit } = lodash; describe('Acceptance | Route | target-profiles', function () { let server; @@ -168,7 +170,7 @@ describe('Acceptance | Route | target-profiles', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); targetProfileId = databaseBuilder.factory.buildTargetProfile().id; user = databaseBuilder.factory.buildUser.withRole(); diff --git a/api/tests/acceptance/application/target-profiles/simplified-access-route-put_test.js b/api/tests/acceptance/application/target-profiles/simplified-access-route-put_test.js index c9dcfd90cb6..17557c78a17 100644 --- a/api/tests/acceptance/application/target-profiles/simplified-access-route-put_test.js +++ b/api/tests/acceptance/application/target-profiles/simplified-access-route-put_test.js @@ -1,10 +1,11 @@ -const { +import { databaseBuilder, expect, insertUserWithRoleSuperAdmin, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Target-profiles', function () { describe('PUT /api/admin/target-profiles/{id}/simplified-access', function () { diff --git a/api/tests/acceptance/application/trainings/training-controller_test.js b/api/tests/acceptance/application/trainings/training-controller_test.js index 79053571c5e..6242bc39280 100644 --- a/api/tests/acceptance/application/trainings/training-controller_test.js +++ b/api/tests/acceptance/application/trainings/training-controller_test.js @@ -1,4 +1,4 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, @@ -6,8 +6,9 @@ const { knex, learningContentBuilder, mockLearningContent, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | training-controller', function () { let server; @@ -66,7 +67,7 @@ describe('Acceptance | Controller | training-controller', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); }); @@ -370,7 +371,7 @@ describe('Acceptance | Controller | training-controller', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/acceptance/application/tutorials/tutorial-evaluations-controller_test.js b/api/tests/acceptance/application/tutorials/tutorial-evaluations-controller_test.js index 8b5d84a08e4..7f608629737 100644 --- a/api/tests/acceptance/application/tutorials/tutorial-evaluations-controller_test.js +++ b/api/tests/acceptance/application/tutorials/tutorial-evaluations-controller_test.js @@ -1,12 +1,13 @@ -const { +import { mockLearningContent, databaseBuilder, expect, knex, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const TutorialEvaluation = require('../../../../lib/domain/models/TutorialEvaluation'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { TutorialEvaluation } from '../../../../lib/domain/models/TutorialEvaluation.js'; describe('Acceptance | Controller | tutorial-evaluations-controller', function () { let server; diff --git a/api/tests/acceptance/application/tutorials/user-tutorials-controller_test.js b/api/tests/acceptance/application/tutorials/user-tutorials-controller_test.js index 4055e0dc20f..a8b9088a485 100644 --- a/api/tests/acceptance/application/tutorials/user-tutorials-controller_test.js +++ b/api/tests/acceptance/application/tutorials/user-tutorials-controller_test.js @@ -1,15 +1,16 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, mockLearningContent, learningContentBuilder, databaseBuilder, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const { learningContentCache } = require('../../../../lib/infrastructure/caches/learning-content-cache'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const nock = require('nock'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { learningContentCache } from '../../../../lib/infrastructure/caches/learning-content-cache.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import nock from 'nock'; describe('Acceptance | Controller | user-tutorial-controller', function () { let server; @@ -160,7 +161,7 @@ describe('Acceptance | Controller | user-tutorial-controller', function () { }, }; - learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + learningContentObjects = learningContentBuilder.fromAreas([ { id: 'recArea1', title_i18n: { diff --git a/api/tests/acceptance/application/user-orga-settings/user-orga-settings-controller_test.js b/api/tests/acceptance/application/user-orga-settings/user-orga-settings-controller_test.js index 81f06045a52..a1a66df3c52 100644 --- a/api/tests/acceptance/application/user-orga-settings/user-orga-settings-controller_test.js +++ b/api/tests/acceptance/application/user-orga-settings/user-orga-settings-controller_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, generateValidRequestAuthorizationHeader, knex } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, knex } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | user-orga-settings-controller', function () { let server; diff --git a/api/tests/acceptance/application/users/accept-pix-certif-terms-of-service_test.js b/api/tests/acceptance/application/users/accept-pix-certif-terms-of-service_test.js index 9263562b11b..1e66f4bbcc1 100644 --- a/api/tests/acceptance/application/users/accept-pix-certif-terms-of-service_test.js +++ b/api/tests/acceptance/application/users/accept-pix-certif-terms-of-service_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-accept-pix-certif-terms-of-service', function () { let server; diff --git a/api/tests/acceptance/application/users/accept-pix-orga-terms-of-service_test.js b/api/tests/acceptance/application/users/accept-pix-orga-terms-of-service_test.js index fd12bdd958d..9cf40d2ab99 100644 --- a/api/tests/acceptance/application/users/accept-pix-orga-terms-of-service_test.js +++ b/api/tests/acceptance/application/users/accept-pix-orga-terms-of-service_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-accept-pix-orga-terms-of-service', function () { let server; diff --git a/api/tests/acceptance/application/users/accept-pix-terms-of-service_test.js b/api/tests/acceptance/application/users/accept-pix-terms-of-service_test.js index 1e2a0ba5b9f..599023a5fd0 100644 --- a/api/tests/acceptance/application/users/accept-pix-terms-of-service_test.js +++ b/api/tests/acceptance/application/users/accept-pix-terms-of-service_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-accept-pix-terms-of-service', function () { let server; diff --git a/api/tests/acceptance/application/users/add-pix-authentication-method-by-email-route-post_test.js b/api/tests/acceptance/application/users/add-pix-authentication-method-by-email-route-post_test.js index adc9e9908b2..1b68b71cea4 100644 --- a/api/tests/acceptance/application/users/add-pix-authentication-method-by-email-route-post_test.js +++ b/api/tests/acceptance/application/users/add-pix-authentication-method-by-email-route-post_test.js @@ -1,11 +1,12 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Users', function () { afterEach(function () { diff --git a/api/tests/acceptance/application/users/change-lang_test.js b/api/tests/acceptance/application/users/change-lang_test.js index 188be6b7039..365e950ffa0 100644 --- a/api/tests/acceptance/application/users/change-lang_test.js +++ b/api/tests/acceptance/application/users/change-lang_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | change-lang', function () { let server; diff --git a/api/tests/acceptance/application/users/find-campaign-participations-for-user-management_test.js b/api/tests/acceptance/application/users/find-campaign-participations-for-user-management_test.js index 39de2b6ffaa..0e5b6127434 100644 --- a/api/tests/acceptance/application/users/find-campaign-participations-for-user-management_test.js +++ b/api/tests/acceptance/application/users/find-campaign-participations-for-user-management_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | GET /api/admin/users/{id}/participations', function () { let server; diff --git a/api/tests/acceptance/application/users/find-user-certification-centers-for-admin-route-get_test.js b/api/tests/acceptance/application/users/find-user-certification-centers-for-admin-route-get_test.js index b04e3069598..e69cbf7eb38 100644 --- a/api/tests/acceptance/application/users/find-user-certification-centers-for-admin-route-get_test.js +++ b/api/tests/acceptance/application/users/find-user-certification-centers-for-admin-route-get_test.js @@ -1,5 +1,5 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Users', function () { describe('GET /api/admin/users/{id}/certification-center-memberships', function () { diff --git a/api/tests/acceptance/application/users/find-user-organizations-for-admin-route-get_test.js b/api/tests/acceptance/application/users/find-user-organizations-for-admin-route-get_test.js index a07c71f7e6d..cb487ffe24c 100644 --- a/api/tests/acceptance/application/users/find-user-organizations-for-admin-route-get_test.js +++ b/api/tests/acceptance/application/users/find-user-organizations-for-admin-route-get_test.js @@ -1,5 +1,5 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Users', function () { describe('GET /api/admin/users/{id}/organizations', function () { diff --git a/api/tests/acceptance/application/users/get-user-authentication-methods-route-get_test.js b/api/tests/acceptance/application/users/get-user-authentication-methods-route-get_test.js index 4c13ae11059..1ade35798e6 100644 --- a/api/tests/acceptance/application/users/get-user-authentication-methods-route-get_test.js +++ b/api/tests/acceptance/application/users/get-user-authentication-methods-route-get_test.js @@ -1,6 +1,6 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const createServer = require('../../../../server'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Users', function () { describe('GET /api/users/{id}/authentication-methods', function () { diff --git a/api/tests/acceptance/application/users/get-user-campaign-assessment-result_test.js b/api/tests/acceptance/application/users/get-user-campaign-assessment-result_test.js index 295cdd70bdf..6fec55df14a 100644 --- a/api/tests/acceptance/application/users/get-user-campaign-assessment-result_test.js +++ b/api/tests/acceptance/application/users/get-user-campaign-assessment-result_test.js @@ -1,13 +1,15 @@ -const createServer = require('../../../../server'); -const { +import { createServer } from '../../../../server.js'; + +import { expect, databaseBuilder, mockLearningContent, learningContentBuilder, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const _ = require('lodash'); -const BadgeCriterion = require('../../../../lib/domain/models/BadgeCriterion'); +} from '../../../test-helper.js'; + +import _ from 'lodash'; +import { BadgeCriterion } from '../../../../lib/domain/models/BadgeCriterion.js'; describe('Acceptance | API | Campaign Assessment Result', function () { const JAFFA_COLOR = 'jaffa'; @@ -172,7 +174,7 @@ describe('Acceptance | API | Campaign Assessment Result', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); await databaseBuilder.commit(); }); diff --git a/api/tests/acceptance/application/users/get-user-campaign-participation-to-campaign_test.js b/api/tests/acceptance/application/users/get-user-campaign-participation-to-campaign_test.js index 7e7be65bd14..0d51ca77f49 100644 --- a/api/tests/acceptance/application/users/get-user-campaign-participation-to-campaign_test.js +++ b/api/tests/acceptance/application/users/get-user-campaign-participation-to-campaign_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | GET /users/id/campaigns/id/campaign-participations', function () { let userId; diff --git a/api/tests/acceptance/application/users/reassign-authentication-methods-route-put_test.js b/api/tests/acceptance/application/users/reassign-authentication-methods-route-put_test.js index 1445885eb9b..130edc937d3 100644 --- a/api/tests/acceptance/application/users/reassign-authentication-methods-route-put_test.js +++ b/api/tests/acceptance/application/users/reassign-authentication-methods-route-put_test.js @@ -1,11 +1,12 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; describe('Acceptance | Route | Users', function () { describe('POST /api/admin/users/{userId}/authentication-methods/{authenticationMethodId}', function () { diff --git a/api/tests/acceptance/application/users/remember-user-has-seen-assessment-instructions_test.js b/api/tests/acceptance/application/users/remember-user-has-seen-assessment-instructions_test.js index 44d7409988a..c2cd14ba7f9 100644 --- a/api/tests/acceptance/application/users/remember-user-has-seen-assessment-instructions_test.js +++ b/api/tests/acceptance/application/users/remember-user-has-seen-assessment-instructions_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-remember-user-has-seen-assessment-instructions', function () { let server; diff --git a/api/tests/acceptance/application/users/remember-user-has-seen-challenge-tooltip_test.js b/api/tests/acceptance/application/users/remember-user-has-seen-challenge-tooltip_test.js index e82851bf246..44fe296caa6 100644 --- a/api/tests/acceptance/application/users/remember-user-has-seen-challenge-tooltip_test.js +++ b/api/tests/acceptance/application/users/remember-user-has-seen-challenge-tooltip_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-has-seen-challenge-tooltip', function () { let server; diff --git a/api/tests/acceptance/application/users/remember-user-has-seen-last-data-protection-policy-information_test.js b/api/tests/acceptance/application/users/remember-user-has-seen-last-data-protection-policy-information_test.js index 17162622467..112fee54395 100644 --- a/api/tests/acceptance/application/users/remember-user-has-seen-last-data-protection-policy-information_test.js +++ b/api/tests/acceptance/application/users/remember-user-has-seen-last-data-protection-policy-information_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder, sinon } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, sinon } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | remember-user-has-seen-last-data-protection-policy-information', function () { describe('Success case', function () { diff --git a/api/tests/acceptance/application/users/remember-user-has-seen-new-dashboard-info_test.js b/api/tests/acceptance/application/users/remember-user-has-seen-new-dashboard-info_test.js index a9925ee7c89..4abd178f74e 100644 --- a/api/tests/acceptance/application/users/remember-user-has-seen-new-dashboard-info_test.js +++ b/api/tests/acceptance/application/users/remember-user-has-seen-new-dashboard-info_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-has-seen-new-dashboard-info', function () { let server; diff --git a/api/tests/acceptance/application/users/send-verification-code-route-put_test.js b/api/tests/acceptance/application/users/send-verification-code-route-put_test.js index 5ca6cff7ab3..3575305a797 100644 --- a/api/tests/acceptance/application/users/send-verification-code-route-put_test.js +++ b/api/tests/acceptance/application/users/send-verification-code-route-put_test.js @@ -1,5 +1,5 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | Users', function () { describe('PUT /api/users/{id}/email/verification-code', function () { diff --git a/api/tests/acceptance/application/users/update-user-details-for-administration_test.js b/api/tests/acceptance/application/users/update-user-details-for-administration_test.js index e5becc0eda6..152139ee338 100644 --- a/api/tests/acceptance/application/users/update-user-details-for-administration_test.js +++ b/api/tests/acceptance/application/users/update-user-details-for-administration_test.js @@ -1,12 +1,12 @@ -const { +import { expect, databaseBuilder, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-update-user-details-for-administration', function () { let server; diff --git a/api/tests/acceptance/application/users/update-user-email-with-validation-route-post_test.js b/api/tests/acceptance/application/users/update-user-email-with-validation-route-post_test.js index 1c63e2e4da3..95f5ae469c3 100644 --- a/api/tests/acceptance/application/users/update-user-email-with-validation-route-post_test.js +++ b/api/tests/acceptance/application/users/update-user-email-with-validation-route-post_test.js @@ -1,6 +1,6 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const createServer = require('../../../../server'); -const userEmailRepository = require('../../../../lib/infrastructure/repositories/user-email-repository'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import * as userEmailRepository from '../../../../lib/infrastructure/repositories/user-email-repository.js'; describe('Acceptance | Route | Users', function () { describe('POST /api/users/{id}/update-email', function () { diff --git a/api/tests/acceptance/application/users/users-controller-find-paginated-user-recommended-trainings_test.js b/api/tests/acceptance/application/users/users-controller-find-paginated-user-recommended-trainings_test.js index eacdcc6ecb6..8dd448c01eb 100644 --- a/api/tests/acceptance/application/users/users-controller-find-paginated-user-recommended-trainings_test.js +++ b/api/tests/acceptance/application/users/users-controller-find-paginated-user-recommended-trainings_test.js @@ -1,6 +1,5 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); - -const createServer = require('../../../../server'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-find-paginated-user-recommended-trainings', function () { let options; diff --git a/api/tests/acceptance/application/users/users-controller-find-users_test.js b/api/tests/acceptance/application/users/users-controller-find-users_test.js index 07e7c15a7a0..3217caff779 100644 --- a/api/tests/acceptance/application/users/users-controller-find-users_test.js +++ b/api/tests/acceptance/application/users/users-controller-find-users_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | users-controller-find-users', function () { let server; diff --git a/api/tests/acceptance/application/users/users-controller-get-campaign-participation-overviews_test.js b/api/tests/acceptance/application/users/users-controller-get-campaign-participation-overviews_test.js index 41da6079579..5b7db86f542 100644 --- a/api/tests/acceptance/application/users/users-controller-get-campaign-participation-overviews_test.js +++ b/api/tests/acceptance/application/users/users-controller-get-campaign-participation-overviews_test.js @@ -1,11 +1,12 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, mockLearningContent, learningContentBuilder, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-get-campaign-participation-overviews', function () { let server; @@ -42,7 +43,7 @@ describe('Acceptance | Controller | users-controller-get-campaign-participation- ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); return databaseBuilder.commit(); diff --git a/api/tests/acceptance/application/users/users-controller-get-campaign-participations_test.js b/api/tests/acceptance/application/users/users-controller-get-campaign-participations_test.js index 1c3cd03114e..0bce96693da 100644 --- a/api/tests/acceptance/application/users/users-controller-get-campaign-participations_test.js +++ b/api/tests/acceptance/application/users/users-controller-get-campaign-participations_test.js @@ -1,5 +1,5 @@ -const { expect, generateValidRequestAuthorizationHeader, databaseBuilder } = require('../../../test-helper'); -const createServer = require('../../../../server'); +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | GET /user/id/campaign-participations', function () { let userId; diff --git a/api/tests/acceptance/application/users/users-controller-get-current-user_test.js b/api/tests/acceptance/application/users/users-controller-get-current-user_test.js index dfef382c874..6c3a5a5595d 100644 --- a/api/tests/acceptance/application/users/users-controller-get-current-user_test.js +++ b/api/tests/acceptance/application/users/users-controller-get-current-user_test.js @@ -1,6 +1,5 @@ -const { databaseBuilder, expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); - -const createServer = require('../../../../server'); +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-get-current-user', function () { let options; diff --git a/api/tests/acceptance/application/users/users-controller-get-user-details-for-admin_test.js b/api/tests/acceptance/application/users/users-controller-get-user-details-for-admin_test.js index a6fc13af51f..63b143b2290 100644 --- a/api/tests/acceptance/application/users/users-controller-get-user-details-for-admin_test.js +++ b/api/tests/acceptance/application/users/users-controller-get-user-details-for-admin_test.js @@ -1,12 +1,12 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, sinon, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-get-user-details-for-admin', function () { let clock; diff --git a/api/tests/acceptance/application/users/users-controller-get-user-profile-for-admin_test.js b/api/tests/acceptance/application/users/users-controller-get-user-profile-for-admin_test.js index 33c92c2b957..c0e81c8c720 100644 --- a/api/tests/acceptance/application/users/users-controller-get-user-profile-for-admin_test.js +++ b/api/tests/acceptance/application/users/users-controller-get-user-profile-for-admin_test.js @@ -1,13 +1,13 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, mockLearningContent, insertUserWithRoleSuperAdmin, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); -const { constants } = require('../../../../lib/domain/constants'); +import { createServer } from '../../../../server.js'; +import { constants } from '../../../../lib/domain/constants.js'; describe('Acceptance | Controller | users-controller-get-user-profile-for-admin', function () { let options; diff --git a/api/tests/acceptance/application/users/users-controller-get-user-profile_test.js b/api/tests/acceptance/application/users/users-controller-get-user-profile_test.js index e00221bac9a..336b1de05b7 100644 --- a/api/tests/acceptance/application/users/users-controller-get-user-profile_test.js +++ b/api/tests/acceptance/application/users/users-controller-get-user-profile_test.js @@ -1,12 +1,12 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, mockLearningContent, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; -const createServer = require('../../../../server'); -const { constants } = require('../../../../lib/domain/constants'); +import { createServer } from '../../../../server.js'; +import { constants } from '../../../../lib/domain/constants.js'; describe('Acceptance | Controller | users-controller-get-user-profile', function () { let options; diff --git a/api/tests/acceptance/application/users/users-controller-is-certifiable_test.js b/api/tests/acceptance/application/users/users-controller-is-certifiable_test.js index 870e2f0feeb..1c491870524 100644 --- a/api/tests/acceptance/application/users/users-controller-is-certifiable_test.js +++ b/api/tests/acceptance/application/users/users-controller-is-certifiable_test.js @@ -1,11 +1,12 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, mockLearningContent, learningContentBuilder, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | users-controller-is-certifiable', function () { let server; @@ -17,7 +18,7 @@ describe('Acceptance | users-controller-is-certifiable', function () { user = databaseBuilder.factory.buildUser(); - const learningContent = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContent = learningContentBuilder.fromAreas([ { id: 'recvoGdo7z2z7pXWa', title_i18n: { diff --git a/api/tests/acceptance/application/users/users-controller-remove-authentication-method_test.js b/api/tests/acceptance/application/users/users-controller-remove-authentication-method_test.js index 39386e52c8f..5330f127e51 100644 --- a/api/tests/acceptance/application/users/users-controller-remove-authentication-method_test.js +++ b/api/tests/acceptance/application/users/users-controller-remove-authentication-method_test.js @@ -1,12 +1,13 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; describe('Acceptance | Controller | users-controller-remove-authentication-method', function () { let server; diff --git a/api/tests/acceptance/application/users/users-controller-reset-scorecard_test.js b/api/tests/acceptance/application/users/users-controller-reset-scorecard_test.js index c829a199dae..05a19322062 100644 --- a/api/tests/acceptance/application/users/users-controller-reset-scorecard_test.js +++ b/api/tests/acceptance/application/users/users-controller-reset-scorecard_test.js @@ -1,5 +1,6 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { knex, databaseBuilder, expect, @@ -7,9 +8,10 @@ const { sinon, mockLearningContent, learningContentBuilder, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; @@ -98,7 +100,7 @@ describe('Acceptance | Controller | users-controller-reset-scorecard', function ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); server = await createServer(); diff --git a/api/tests/acceptance/application/users/users-controller-save_test.js b/api/tests/acceptance/application/users/users-controller-save_test.js index de0a6e49933..e09f374fc91 100644 --- a/api/tests/acceptance/application/users/users-controller-save_test.js +++ b/api/tests/acceptance/application/users/users-controller-save_test.js @@ -1,10 +1,11 @@ -const pick = require('lodash/pick'); +import lodash from 'lodash'; +const { pick } = lodash; -const { domainBuilder, expect, knex, nock } = require('../../../test-helper'); +import { domainBuilder, expect, knex, nock } from '../../../test-helper.js'; -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; -const createServer = require('../../../../server'); +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller', function () { let server; diff --git a/api/tests/acceptance/application/users/users-controller-update-password_test.js b/api/tests/acceptance/application/users/users-controller-update-password_test.js index 2510a485c5e..f38e0ac8020 100644 --- a/api/tests/acceptance/application/users/users-controller-update-password_test.js +++ b/api/tests/acceptance/application/users/users-controller-update-password_test.js @@ -1,7 +1,6 @@ -const { expect, hFake, knex, databaseBuilder } = require('../../../test-helper'); - -const authenticationController = require('../../../../lib/application/authentication/authentication-controller'); -const createServer = require('../../../../server'); +import { expect, hFake, knex, databaseBuilder } from '../../../test-helper.js'; +import { authenticationController } from '../../../../lib/application/authentication/authentication-controller.js'; +import { createServer } from '../../../../server.js'; describe('Acceptance | Controller | users-controller-update-password', function () { const temporaryKey = 'good-temporary-key'; diff --git a/api/tests/acceptance/application/users/users-get-shared-profile-for-campaign_test.js b/api/tests/acceptance/application/users/users-get-shared-profile-for-campaign_test.js index e55c7ae888a..5d131b2b602 100644 --- a/api/tests/acceptance/application/users/users-get-shared-profile-for-campaign_test.js +++ b/api/tests/acceptance/application/users/users-get-shared-profile-for-campaign_test.js @@ -1,11 +1,13 @@ -const _ = require('lodash'); -const { +import _ from 'lodash'; + +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, mockLearningContent, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | GET /users/{userId}/campaigns/{campaignId}/profile', function () { const userId = 100; diff --git a/api/tests/acceptance/application/users/users-route_test.js b/api/tests/acceptance/application/users/users-route_test.js index 0e5de982c03..ab057c17f99 100644 --- a/api/tests/acceptance/application/users/users-route_test.js +++ b/api/tests/acceptance/application/users/users-route_test.js @@ -1,11 +1,12 @@ -const { +import { databaseBuilder, expect, generateValidRequestAuthorizationHeader, insertUserWithRoleSuperAdmin, knex, -} = require('../../../test-helper'); -const createServer = require('../../../../server'); +} from '../../../test-helper.js'; + +import { createServer } from '../../../../server.js'; describe('Acceptance | Route | users', function () { describe('POST /admin/users/:id/anonymize', function () { let server; diff --git a/api/tests/acceptance/database/configuration.js b/api/tests/acceptance/database/configuration.cjs similarity index 92% rename from api/tests/acceptance/database/configuration.js rename to api/tests/acceptance/database/configuration.cjs index c2aad7876f8..e3bfe01afb0 100644 --- a/api/tests/acceptance/database/configuration.js +++ b/api/tests/acceptance/database/configuration.cjs @@ -1,5 +1,4 @@ -const dotenv = require('dotenv'); -dotenv.config(); +require('dotenv').config(); const parsePostgresqlConnectionString = require('pg-connection-string').parse; const databaseToLint = { diff --git a/api/tests/acceptance/db/migrations/20220721115757_alter-answers-id-from-int-to-bigint_test.js b/api/tests/acceptance/db/migrations/20220721115757_alter-answers-id-from-int-to-bigint_test.js index f9d4e722772..7726c08c9ce 100644 --- a/api/tests/acceptance/db/migrations/20220721115757_alter-answers-id-from-int-to-bigint_test.js +++ b/api/tests/acceptance/db/migrations/20220721115757_alter-answers-id-from-int-to-bigint_test.js @@ -1,4 +1,4 @@ -const { expect, knex, databaseBuilder } = require('../../../test-helper'); +import { expect, knex, databaseBuilder } from '../../../test-helper.js'; describe('#changeAnswerIdTypeToBigint', function () { it('should insert answer with an id bigger than the maximum integer type value', async function () { diff --git a/api/tests/acceptance/scripts/_template.test.js b/api/tests/acceptance/scripts/_template.test.js index 4b225cdc10e..8ecc203aaf8 100644 --- a/api/tests/acceptance/scripts/_template.test.js +++ b/api/tests/acceptance/scripts/_template.test.js @@ -1,5 +1,5 @@ -const { expect, catchErr, databaseBuilder } = require('../../test-helper'); -const { doSomething } = require('../../../scripts/_template'); +import { expect, catchErr, databaseBuilder } from '../../test-helper.js'; +import { doSomething } from '../../../scripts/_template.js'; describe('#doSomething', function () { describe('#if throwError is false', function () { diff --git a/api/tests/acceptance/scripts/add-many-divisions-and-students-to-sco-organization_test.js b/api/tests/acceptance/scripts/add-many-divisions-and-students-to-sco-organization_test.js index 7a0610e267e..976ee9199ac 100644 --- a/api/tests/acceptance/scripts/add-many-divisions-and-students-to-sco-organization_test.js +++ b/api/tests/acceptance/scripts/add-many-divisions-and-students-to-sco-organization_test.js @@ -1,13 +1,8 @@ -const { expect } = require('../../test-helper'); -const { SCO_MIDDLE_SCHOOL_ID } = require('../../../db/seeds/data/organizations-sco-builder'); - -const { knex } = require('../../../lib/infrastructure/bookshelf'); -const BookshelfOrganizationLearner = require('../../../lib/infrastructure/orm-models/OrganizationLearner'); -const { databaseBuilder } = require('../../test-helper'); - -const { - addManyDivisionsAndStudentsToScoCertificationCenter, -} = require('../../../scripts/data-generation/add-many-divisions-and-students-to-sco-organization'); +import { expect, databaseBuilder } from '../../test-helper.js'; +import { SCO_MIDDLE_SCHOOL_ID } from '../../../db/seeds/data/organizations-sco-builder.js'; +import { knex } from '../../../lib/infrastructure/bookshelf.js'; +import { BookshelfOrganizationLearner } from '../../../lib/infrastructure/orm-models/OrganizationLearner.js'; +import { addManyDivisionsAndStudentsToScoCertificationCenter } from '../../../scripts/data-generation/add-many-divisions-and-students-to-sco-organization.js'; describe('Acceptance | Scripts | add-many-divisions-and-students-to-sco-organization', function () { describe('#addManyDivisionsAndStudentsToScoCertificationCenter', function () { diff --git a/api/tests/acceptance/scripts/add-many-fake-members-related-to-one-organization_test.js b/api/tests/acceptance/scripts/add-many-fake-members-related-to-one-organization_test.js index f87855151b3..762dde54e39 100644 --- a/api/tests/acceptance/scripts/add-many-fake-members-related-to-one-organization_test.js +++ b/api/tests/acceptance/scripts/add-many-fake-members-related-to-one-organization_test.js @@ -1,8 +1,6 @@ -const { expect, sinon, knex, databaseBuilder, catchErr } = require('../../test-helper'); -const { - addManyMembersToExistingOrganization, -} = require('../../../scripts/data-generation/add-many-fake-members-related-to-one-organization'); -const { ForbiddenAccess } = require('../../../lib/domain/errors'); +import { expect, sinon, knex, databaseBuilder, catchErr } from '../../test-helper.js'; +import { addManyMembersToExistingOrganization } from '../../../scripts/data-generation/add-many-fake-members-related-to-one-organization.js'; +import { ForbiddenAccess } from '../../../lib/domain/errors.js'; describe('Acceptance | Scripts | add-many-divisions-and-students-to-sco-organization', function () { it('should throw an error when env is production', async function () { diff --git a/api/tests/acceptance/scripts/add-many-students-to-sco-certification-center_test.js b/api/tests/acceptance/scripts/add-many-students-to-sco-certification-center_test.js index 7a82a413f65..1510d59cc63 100644 --- a/api/tests/acceptance/scripts/add-many-students-to-sco-certification-center_test.js +++ b/api/tests/acceptance/scripts/add-many-students-to-sco-certification-center_test.js @@ -1,13 +1,8 @@ -const { expect } = require('../../test-helper'); -const { SCO_MIDDLE_SCHOOL_ID } = require('../../../db/seeds/data/organizations-sco-builder'); - -const { knex } = require('../../../lib/infrastructure/bookshelf'); -const BookshelfOrganizationLearner = require('../../../lib/infrastructure/orm-models/OrganizationLearner'); -const { databaseBuilder } = require('../../test-helper'); - -const { - addManyStudentsToScoCertificationCenter, -} = require('../../../scripts/data-generation/add-many-students-to-sco-certification-center'); +import { expect, databaseBuilder } from '../../test-helper.js'; +import { SCO_MIDDLE_SCHOOL_ID } from '../../../db/seeds/data/organizations-sco-builder.js'; +import { knex } from '../../../lib/infrastructure/bookshelf.js'; +import { BookshelfOrganizationLearner } from '../../../lib/infrastructure/orm-models/OrganizationLearner.js'; +import { addManyStudentsToScoCertificationCenter } from '../../../scripts/data-generation/add-many-students-to-sco-certification-center.js'; describe('Acceptance | Scripts | add-many-students-to-sco-certification-centers.js', function () { describe('#addManyStudentsToScoCertificationCenter', function () { diff --git a/api/tests/acceptance/scripts/certification/import-certifications-from-csv_test.js b/api/tests/acceptance/scripts/certification/import-certifications-from-csv_test.js index 50e15ed3ca1..566e2a8278e 100644 --- a/api/tests/acceptance/scripts/certification/import-certifications-from-csv_test.js +++ b/api/tests/acceptance/scripts/certification/import-certifications-from-csv_test.js @@ -1,5 +1,8 @@ -const { expect, nock } = require('../../../test-helper'); -const script = require('../../../../scripts/certification/import-certifications-from-csv'); +import { expect, nock } from '../../../test-helper.js'; +import * as script from '../../../../scripts/certification/import-certifications-from-csv.js'; +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Acceptance | Scripts | import-certifications-from-csv.js', function () { describe('#assertFileValidity', function () { diff --git a/api/tests/acceptance/scripts/certification/update-certification-infos_test.js b/api/tests/acceptance/scripts/certification/update-certification-infos_test.js index cf6fff837ac..32dc1434e2d 100644 --- a/api/tests/acceptance/scripts/certification/update-certification-infos_test.js +++ b/api/tests/acceptance/scripts/certification/update-certification-infos_test.js @@ -1,8 +1,12 @@ -const { expect, databaseBuilder, knex, sinon } = require('../../../test-helper'); -const { writeFile, rm } = require('fs/promises'); -const values = require('lodash/values'); -const logger = require('../../../../lib/infrastructure/logger'); -const { updateCertificationInfos, headers } = require('../../../../scripts/certification/update-certification-infos'); +import { expect, databaseBuilder, knex, sinon } from '../../../test-helper.js'; +import { writeFile, rm } from 'fs/promises'; +import lodash from 'lodash'; +const { values } = lodash; +import { logger } from '../../../../lib/infrastructure/logger.js'; +import { updateCertificationInfos, headers } from '../../../../scripts/certification/update-certification-infos.js'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); + const dataFile = `${__dirname}/data.csv`; const sessionIdsFile = `${__dirname}/sessionIds.csv`; diff --git a/api/tests/acceptance/scripts/create-or-update-sco-organizations_test.js b/api/tests/acceptance/scripts/create-or-update-sco-organizations_test.js index 5570148e4ef..a89daabf2fe 100644 --- a/api/tests/acceptance/scripts/create-or-update-sco-organizations_test.js +++ b/api/tests/acceptance/scripts/create-or-update-sco-organizations_test.js @@ -1,7 +1,6 @@ -const { expect, nock } = require('../../test-helper'); - -const { checkData, createOrUpdateOrganizations } = require('../../../scripts/create-or-update-sco-organizations'); -const logoUrl = require('../../../scripts/logo/default-sco-organization-logo-base64'); +import { expect, nock } from '../../test-helper.js'; +import { checkData, createOrUpdateOrganizations } from '../../../scripts/create-or-update-sco-organizations.js'; +import { logoUrl } from '../../../scripts/logo/default-sco-organization-logo-base64.js'; describe('Acceptance | Scripts | create-or-update-sco-organizations.js', function () { describe('#createOrUpdateOrganizations', function () { diff --git a/api/tests/acceptance/scripts/create-sco-certification-centers_test.js b/api/tests/acceptance/scripts/create-sco-certification-centers_test.js index 69525014d1e..5a9a573b505 100644 --- a/api/tests/acceptance/scripts/create-sco-certification-centers_test.js +++ b/api/tests/acceptance/scripts/create-sco-certification-centers_test.js @@ -1,8 +1,6 @@ -const { expect, knex } = require('../../test-helper'); - -const BookshelfCertificationCenter = require('../../../lib/infrastructure/orm-models/CertificationCenter'); - -const { createScoCertificationCenters } = require('../../../scripts/create-sco-certification-centers'); +import { expect, knex } from '../../test-helper.js'; +import { BookshelfCertificationCenter } from '../../../lib/infrastructure/orm-models/CertificationCenter.js'; +import { createScoCertificationCenters } from '../../../scripts/create-sco-certification-centers.js'; describe('Acceptance | Scripts | create-sco-certification-centers.js', function () { describe('#createScoCertificationCenters', function () { diff --git a/api/tests/acceptance/scripts/create-users-accounts-for-contest_test.js b/api/tests/acceptance/scripts/create-users-accounts-for-contest_test.js index a7b4b11984f..354809bc2aa 100644 --- a/api/tests/acceptance/scripts/create-users-accounts-for-contest_test.js +++ b/api/tests/acceptance/scripts/create-users-accounts-for-contest_test.js @@ -1,6 +1,6 @@ -const { expect, knex } = require('../../test-helper'); -const { createUsers } = require('../../../scripts/create-users-accounts-for-contest'); -const sinon = require('sinon'); +import { expect, knex } from '../../test-helper.js'; +import { createUsers } from '../../../scripts/create-users-accounts-for-contest.js'; +import sinon from 'sinon'; describe('Acceptance | Scripts | create-users-accounts-for-contest', function () { describe('#createUsers', function () { diff --git a/api/tests/acceptance/scripts/target-profile-migrations/convert-badges_test.js b/api/tests/acceptance/scripts/target-profile-migrations/convert-badges_test.js index 19d7a8a1c03..1a599d4ac4d 100644 --- a/api/tests/acceptance/scripts/target-profile-migrations/convert-badges_test.js +++ b/api/tests/acceptance/scripts/target-profile-migrations/convert-badges_test.js @@ -1,9 +1,8 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, sinon, mockLearningContent } = require('../../../test-helper'); -const { knex } = require('../../../../db/knex-database-connection'); -const logger = require('../../../../lib/infrastructure/logger'); - -const { doJob } = require('../../../../scripts/prod/target-profile-migrations/convert-badges'); +import _ from 'lodash'; +import { expect, databaseBuilder, sinon, mockLearningContent } from '../../../test-helper.js'; +import { knex } from '../../../../db/knex-database-connection.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; +import { doJob } from '../../../../scripts/prod/target-profile-migrations/convert-badges.js'; describe('Acceptance | Scripts | convert-badges', function () { it('should execute the script as expected', async function () { diff --git a/api/tests/acceptance/scripts/update-sco-organizations-with-province-code-and-external-id_test.js b/api/tests/acceptance/scripts/update-sco-organizations-with-province-code-and-external-id_test.js index 5f82ce75dcb..79e14e96102 100644 --- a/api/tests/acceptance/scripts/update-sco-organizations-with-province-code-and-external-id_test.js +++ b/api/tests/acceptance/scripts/update-sco-organizations-with-province-code-and-external-id_test.js @@ -1,5 +1,8 @@ -const { expect, sinon, nock } = require('../../test-helper'); -const script = require('../../../scripts/update-sco-organizations-with-province-code-and-external-id'); +import { expect, sinon, nock } from '../../test-helper.js'; +import * as script from '../../../scripts/update-sco-organizations-with-province-code-and-external-id.js'; +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Acceptance | Scripts | update-sco-organizations-with-province-code-and-external-id.js', function () { describe('#assertFileValidity', function () { diff --git a/api/tests/docs/jsonapi-serializer.test.js b/api/tests/docs/jsonapi-serializer.test.js index b41579f8f2b..f3dc4b1aa52 100644 --- a/api/tests/docs/jsonapi-serializer.test.js +++ b/api/tests/docs/jsonapi-serializer.test.js @@ -1,9 +1,8 @@ -// https://jsonapi.org/ -// https://github.com/SeyZ/jsonapi-serializer +import { expect } from '../test-helper.js'; +import jsonapiSerializer from 'jsonapi-serializer'; -const { expect } = require('../test-helper'); +const { Serializer } = jsonapiSerializer; -const Serializer = require('jsonapi-serializer').Serializer; const resourceType = 'users'; describe('Docs | jsonapi-serializer', function () { diff --git a/api/tests/integration/application/.eslintrc.js b/api/tests/integration/application/.eslintrc.cjs similarity index 81% rename from api/tests/integration/application/.eslintrc.js rename to api/tests/integration/application/.eslintrc.cjs index 3086f4d3114..65d1a3802ea 100644 --- a/api/tests/integration/application/.eslintrc.js +++ b/api/tests/integration/application/.eslintrc.cjs @@ -1,3 +1,5 @@ +// eslint-disable-next-line eslint-comments/disable-enable-pair +/* eslint-disable no-undef */ module.exports = { extends: '../../.eslintrc.yaml', rules: { diff --git a/api/tests/integration/application/account-recovery/account-recovery-controller_test.js b/api/tests/integration/application/account-recovery/account-recovery-controller_test.js index df98bdc9322..00df12369cb 100644 --- a/api/tests/integration/application/account-recovery/account-recovery-controller_test.js +++ b/api/tests/integration/application/account-recovery/account-recovery-controller_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); -const { NotFoundError, UserNotFoundError } = require('../../../../lib/domain/errors'); -const usecases = require('../../../../lib/domain/usecases/index.js'); - -const moduleUnderTest = require('../../../../lib/application/account-recovery'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { NotFoundError, UserNotFoundError } from '../../../../lib/domain/errors.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import * as moduleUnderTest from '../../../../lib/application/account-recovery/index.js'; describe('Integration | Application | Account-Recovery | account-recovery-controller', function () { let httpTestServer; diff --git a/api/tests/integration/application/assessments/assessment-controller_test.js b/api/tests/integration/application/assessments/assessment-controller_test.js index 5697c16b235..73b57327b19 100644 --- a/api/tests/integration/application/assessments/assessment-controller_test.js +++ b/api/tests/integration/application/assessments/assessment-controller_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder, HttpTestServer } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const assessmentAuthorization = require('../../../../lib/application/preHandlers/assessment-authorization'); -const moduleUnderTest = require('../../../../lib/application/assessments'); +import { expect, sinon, domainBuilder, HttpTestServer } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { assessmentAuthorization } from '../../../../lib/application/preHandlers/assessment-authorization.js'; +import * as moduleUnderTest from '../../../../lib/application/assessments/index.js'; describe('Integration | Application | Assessments | assessment-controller', function () { let assessment; diff --git a/api/tests/integration/application/authentication/index_test.js b/api/tests/integration/application/authentication/index_test.js index c22c31d2917..c0d0d434abe 100644 --- a/api/tests/integration/application/authentication/index_test.js +++ b/api/tests/integration/application/authentication/index_test.js @@ -1,11 +1,8 @@ -const querystring = require('querystring'); +import querystring from 'querystring'; -const { expect, sinon } = require('../../../test-helper'); - -// eslint-disable-next-line no-restricted-modules -const createServer = require('../../../../server'); - -const authenticationController = require('../../../../lib/application/authentication/authentication-controller'); +import { expect, sinon } from '../../../test-helper.js'; +import { createServer } from '../../../../server.js'; +import { authenticationController } from '../../../../lib/application/authentication/authentication-controller.js'; describe('Integration | Application | Route | AuthenticationRouter', function () { let server; diff --git a/api/tests/integration/application/authentication/oidc/index_test.js b/api/tests/integration/application/authentication/oidc/index_test.js index cb81951ad24..f88fd6daf6a 100644 --- a/api/tests/integration/application/authentication/oidc/index_test.js +++ b/api/tests/integration/application/authentication/oidc/index_test.js @@ -1,11 +1,12 @@ -const { expect, sinon, HttpTestServer, generateValidRequestAuthorizationHeader } = require('../../../../test-helper'); -const oidcController = require('../../../../../lib/application/authentication/oidc/oidc-controller'); -const moduleUnderTest = require('../../../../../lib/application/authentication/oidc'); -const { +import { expect, sinon, HttpTestServer, generateValidRequestAuthorizationHeader } from '../../../../test-helper.js'; +import { oidcController } from '../../../../../lib/application/authentication/oidc/oidc-controller.js'; +import * as moduleUnderTest from '../../../../../lib/application/authentication/oidc/index.js'; + +import { UserNotFoundError, AuthenticationKeyExpired, DifferentExternalIdentifierError, -} = require('../../../../../lib/domain/errors'); +} from '../../../../../lib/domain/errors.js'; describe('Integration | Application | Route | OidcRouter', function () { let server; diff --git a/api/tests/integration/application/campaignParticipations/index_test.js b/api/tests/integration/application/campaignParticipations/index_test.js index 3d8f18e8455..5bcec8845de 100644 --- a/api/tests/integration/application/campaignParticipations/index_test.js +++ b/api/tests/integration/application/campaignParticipations/index_test.js @@ -1,8 +1,6 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/campaign-participations'); - -const campaignParticipationController = require('../../../../lib/application/campaign-participations/campaign-participation-controller'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import * as moduleUnderTest from '../../../../lib/application/campaign-participations/index.js'; +import { campaignParticipationController } from '../../../../lib/application/campaign-participations/campaign-participation-controller.js'; describe('Integration | Application | Route | campaignParticipationRouter', function () { let httpTestServer; diff --git a/api/tests/integration/application/campaigns/index_test.js b/api/tests/integration/application/campaigns/index_test.js index a96c234549e..1a9ddb38621 100644 --- a/api/tests/integration/application/campaigns/index_test.js +++ b/api/tests/integration/application/campaigns/index_test.js @@ -1,8 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/campaigns'); - -const campaignController = require('../../../../lib/application/campaigns/campaign-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { campaignController } from '../../../../lib/application/campaigns/campaign-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/campaigns/index.js'; describe('Integration | Application | Route | campaignRouter', function () { let httpTestServer; diff --git a/api/tests/integration/application/certifications/index_test.js b/api/tests/integration/application/certifications/index_test.js index 463e7c83acb..399f1748ba2 100644 --- a/api/tests/integration/application/certifications/index_test.js +++ b/api/tests/integration/application/certifications/index_test.js @@ -1,10 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); - -const moduleUnderTest = require('../../../../lib/application/certifications'); - -const certificationController = require('../../../../lib/application/certifications/certification-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { certificationController } from '../../../../lib/application/certifications/certification-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/certifications/index.js'; describe('Integration | Application | Route | Certifications', function () { let httpTestServer; diff --git a/api/tests/integration/application/complementary-certification-course-results/complementary-certification-course-results-controller_test.js b/api/tests/integration/application/complementary-certification-course-results/complementary-certification-course-results-controller_test.js index 46c114d40a4..3b63952548f 100644 --- a/api/tests/integration/application/complementary-certification-course-results/complementary-certification-course-results-controller_test.js +++ b/api/tests/integration/application/complementary-certification-course-results/complementary-certification-course-results-controller_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const { InvalidJuryLevelError } = require('../../../../lib/domain/errors'); -const moduleUnderTest = require('../../../../lib/application/complementary-certification-course-results'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { InvalidJuryLevelError } from '../../../../lib/domain/errors.js'; +import * as moduleUnderTest from '../../../../lib/application/complementary-certification-course-results/index.js'; describe('Integration | Application | complementary-certification-course-results | complementary-certification-course-results-controller', function () { let sandbox; diff --git a/api/tests/integration/application/complementary-certification-course-results/index_test.js b/api/tests/integration/application/complementary-certification-course-results/index_test.js index 127d125be5e..da73b10c58f 100644 --- a/api/tests/integration/application/complementary-certification-course-results/index_test.js +++ b/api/tests/integration/application/complementary-certification-course-results/index_test.js @@ -1,7 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/complementary-certification-course-results'); -const complementaryCertificationCourseResultsController = require('../../../../lib/application/complementary-certification-course-results/complementary-certification-course-results-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/complementary-certification-course-results/index.js'; +import { complementaryCertificationCourseResultsController } from '../../../../lib/application/complementary-certification-course-results/complementary-certification-course-results-controller.js'; describe('Integration | Application | Route | Certifications', function () { let httpTestServer; diff --git a/api/tests/integration/application/error-manager_test.js b/api/tests/integration/application/error-manager_test.js index 45ae5ee0365..84277e79c29 100644 --- a/api/tests/integration/application/error-manager_test.js +++ b/api/tests/integration/application/error-manager_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, HttpTestServer } = require('../../test-helper'); -const DomainErrors = require('../../../lib/domain/errors'); +import { expect, sinon, HttpTestServer } from '../../test-helper.js'; +import * as DomainErrors from '../../../lib/domain/errors.js'; describe('Integration | API | Controller Error', function () { let server; diff --git a/api/tests/integration/application/healthcheck/index_test.js b/api/tests/integration/application/healthcheck/index_test.js index 221f4ebe220..57faddfed6e 100644 --- a/api/tests/integration/application/healthcheck/index_test.js +++ b/api/tests/integration/application/healthcheck/index_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); -const moduleUnderTest = require('../../../../lib/application/healthcheck'); -const healthCheckController = require('../../../../lib/application/healthcheck/healthcheck-controller'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { healthcheckController as healthCheckController } from '../../../../lib/application/healthcheck/healthcheck-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/healthcheck/index.js'; describe('Integration | Application | Route | healthcheckRouter', function () { let httpTestServer; diff --git a/api/tests/integration/application/memberships/membership-controller_test.js b/api/tests/integration/application/memberships/membership-controller_test.js index 09c81fd9912..1b754ae7288 100644 --- a/api/tests/integration/application/memberships/membership-controller_test.js +++ b/api/tests/integration/application/memberships/membership-controller_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, domainBuilder, HttpTestServer } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const Membership = require('../../../../lib/domain/models/Membership'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/memberships'); -const { InvalidMembershipOrganizationRoleError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, HttpTestServer } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/memberships/index.js'; +import { InvalidMembershipOrganizationRoleError } from '../../../../lib/domain/errors.js'; describe('Integration | Application | Memberships | membership-controller', function () { let httpTestServer; diff --git a/api/tests/integration/application/organization-invitations/index_test.js b/api/tests/integration/application/organization-invitations/index_test.js index 3ef6ecdab62..7b2366c67a7 100644 --- a/api/tests/integration/application/organization-invitations/index_test.js +++ b/api/tests/integration/application/organization-invitations/index_test.js @@ -1,19 +1,17 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/organization-invitations/index'); - -const organisationInvitationController = require('../../../../lib/application/organization-invitations/organization-invitation-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { organizationInvitationController } from '../../../../lib/application/organization-invitations/organization-invitation-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/organization-invitations/index.js'; describe('Integration | Application | Organization-invitations | Routes', function () { let httpTestServer; beforeEach(async function () { sinon - .stub(organisationInvitationController, 'acceptOrganizationInvitation') + .stub(organizationInvitationController, 'acceptOrganizationInvitation') .callsFake((request, h) => h.response().code(204)); - sinon.stub(organisationInvitationController, 'sendScoInvitation').callsFake((request, h) => h.response().code(201)); + sinon.stub(organizationInvitationController, 'sendScoInvitation').callsFake((request, h) => h.response().code(201)); sinon - .stub(organisationInvitationController, 'getOrganizationInvitation') + .stub(organizationInvitationController, 'getOrganizationInvitation') .callsFake((request, h) => h.response().code(200)); httpTestServer = new HttpTestServer(); diff --git a/api/tests/integration/application/organization-invitations/organization-invitation-controller_test.js b/api/tests/integration/application/organization-invitations/organization-invitation-controller_test.js index 70733f7cbb3..2534a9a199b 100644 --- a/api/tests/integration/application/organization-invitations/organization-invitation-controller_test.js +++ b/api/tests/integration/application/organization-invitations/organization-invitation-controller_test.js @@ -1,10 +1,9 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { serializer as scoOrganizationInvitationSerializer } from '../../../../lib/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer.js'; +import * as moduleUnderTest from '../../../../lib/application/organization-invitations/index.js'; -const usecases = require('../../../../lib/domain/usecases/index.js'); -const scoOrganizationInvitationSerializer = require('../../../../lib/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer'); -const moduleUnderTest = require('../../../../lib/application/organization-invitations'); - -const { +import { AlreadyExistingInvitationError, NotFoundError, UserNotFoundError, @@ -12,7 +11,7 @@ const { OrganizationNotFoundError, ManyOrganizationsFoundError, OrganizationArchivedError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Integration | Application | Organization-invitations | organization-invitation-controller', function () { let sandbox; diff --git a/api/tests/integration/application/organizations-administration/_files/logo-3mb.js b/api/tests/integration/application/organizations-administration/_files/logo-3mb.js index 2163cb1d41a..3dfa492095c 100644 --- a/api/tests/integration/application/organizations-administration/_files/logo-3mb.js +++ b/api/tests/integration/application/organizations-administration/_files/logo-3mb.js @@ -1,4 +1,4 @@ const logo3Mb = ''; -module.exports = { logo3Mb }; +export { logo3Mb }; diff --git a/api/tests/integration/application/organizations-administration/index_test.js b/api/tests/integration/application/organizations-administration/index_test.js index 6452fda0a0b..4ccd95d709e 100644 --- a/api/tests/integration/application/organizations-administration/index_test.js +++ b/api/tests/integration/application/organizations-administration/index_test.js @@ -1,13 +1,14 @@ -const { +import { expect, sinon, HttpTestServer, databaseBuilder, generateValidRequestAuthorizationHeader, -} = require('../../../test-helper'); -const organizationAdministrationController = require('../../../../lib/application/organizations-administration/organization-administration-controller'); -const moduleUnderTest = require('../../../../lib/application/organizations-administration'); -const { logo3Mb } = require('./_files/logo-3mb'); +} from '../../../test-helper.js'; + +import { organizationAdministrationController } from '../../../../lib/application/organizations-administration/organization-administration-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/organizations-administration/index.js'; +import { logo3Mb } from './_files/logo-3mb.js'; describe('Integration | Application | Organization Administration | Routes', function () { describe('PATCH /api/admin/organizations/{:id}', function () { diff --git a/api/tests/integration/application/organizations-administration/organization-administration-controller_test.js b/api/tests/integration/application/organizations-administration/organization-administration-controller_test.js index a500fa02ed5..86e064426fa 100644 --- a/api/tests/integration/application/organizations-administration/organization-administration-controller_test.js +++ b/api/tests/integration/application/organizations-administration/organization-administration-controller_test.js @@ -1,7 +1,7 @@ -const { expect, hFake, databaseBuilder, knex } = require('../../../test-helper'); -const organizationAdministrationController = require('../../../../lib/application/organizations-administration/organization-administration-controller.js'); -const dragonLogo = require('../../../../db/seeds/src/dragonAndCoBase64'); -const apps = require('../../../../lib/domain/constants.js'); +import { expect, hFake, databaseBuilder, knex } from '../../../test-helper.js'; +import * as organizationAdministrationController from '../../../../lib/application/organizations-administration/organization-administration-controller.js'; +import * as dragonLogo from '../../../../db/seeds/src/dragonAndCoBase64.js'; +import * as apps from '../../../../lib/domain/constants.js'; describe('Integration | Application | Controller | organization-administration-controller', function () { let organization; let featureId; diff --git a/api/tests/integration/application/organizations/index_test.js b/api/tests/integration/application/organizations/index_test.js index 98cd2b2da18..63ebd5366c1 100644 --- a/api/tests/integration/application/organizations/index_test.js +++ b/api/tests/integration/application/organizations/index_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const organizationController = require('../../../../lib/application/organizations/organization-controller'); -const moduleUnderTest = require('../../../../lib/application/organizations'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { organizationController } from '../../../../lib/application/organizations/organization-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/organizations/index.js'; describe('Integration | Application | Organizations | Routes', function () { describe('POST /api/admin/organizations', function () { diff --git a/api/tests/integration/application/organizations/organization-controller_test.js b/api/tests/integration/application/organizations/organization-controller_test.js index 5d189caa9bf..e588d761f1f 100644 --- a/api/tests/integration/application/organizations/organization-controller_test.js +++ b/api/tests/integration/application/organizations/organization-controller_test.js @@ -1,14 +1,12 @@ -const { expect, sinon, domainBuilder, HttpTestServer } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const ScoOrganizationParticipant = require('../../../../lib/domain/read-models/ScoOrganizationParticipant'); -const SupOrganizationParticipant = require('../../../../lib/domain/read-models/SupOrganizationParticipant'); -const certificationAttestationPdf = require('../../../../lib/infrastructure/utils/pdf/certification-attestation-pdf'); - -const moduleUnderTest = require('../../../../lib/application/organizations'); -const { NoCertificationAttestationForDivisionError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, HttpTestServer } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import { ScoOrganizationParticipant } from '../../../../lib/domain/read-models/ScoOrganizationParticipant.js'; +import { SupOrganizationParticipant } from '../../../../lib/domain/read-models/SupOrganizationParticipant.js'; +import { getCertificationAttestationsPdf as certificationAttestationPdf } from '../../../../lib/infrastructure/utils/pdf/certification-attestation-pdf.js'; +import * as moduleUnderTest from '../../../../lib/application/organizations/index.js'; +import { NoCertificationAttestationForDivisionError } from '../../../../lib/domain/errors.js'; describe('Integration | Application | Organizations | organization-controller', function () { let sandbox; @@ -23,8 +21,8 @@ describe('Integration | Application | Organizations | organization-controller', sandbox.stub(usecases, 'acceptOrganizationInvitation'); sandbox.stub(usecases, 'findPendingOrganizationInvitations'); sandbox.stub(usecases, 'findCertificationAttestationsForDivision'); - sandbox.stub(usecases, 'findGroupsByOrganization'); sandbox.stub(usecases, 'findDivisionsByOrganization'); + sandbox.stub(usecases, 'findGroupsByOrganization'); sandbox.stub(usecases, 'getPaginatedParticipantsForAnOrganization'); sandbox.stub(usecases, 'findOrganizationPlacesLot'); diff --git a/api/tests/integration/application/passwords/index_test.js b/api/tests/integration/application/passwords/index_test.js index 6f7729afb07..968c33cc441 100644 --- a/api/tests/integration/application/passwords/index_test.js +++ b/api/tests/integration/application/passwords/index_test.js @@ -1,8 +1,6 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/passwords'); - -const passwordController = require('../../../../lib/application/passwords/password-controller'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { passwordController } from '../../../../lib/application/passwords/password-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/passwords/index.js'; describe('Integration | Application | Password | Routes', function () { let httpTestServer; diff --git a/api/tests/integration/application/passwords/password-controller_test.js b/api/tests/integration/application/passwords/password-controller_test.js index b42049ab33b..18b3989b18c 100644 --- a/api/tests/integration/application/passwords/password-controller_test.js +++ b/api/tests/integration/application/passwords/password-controller_test.js @@ -1,14 +1,14 @@ -const { domainBuilder, expect, sinon, HttpTestServer } = require('../../../test-helper'); +import { domainBuilder, expect, sinon, HttpTestServer } from '../../../test-helper.js'; -const { +import { ForbiddenAccess, InvalidTemporaryKeyError, PasswordResetDemandNotFoundError, UserNotFoundError, -} = require('../../../../lib/domain/errors'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +} from '../../../../lib/domain/errors.js'; -const moduleUnderTest = require('../../../../lib/application/passwords'); +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import * as moduleUnderTest from '../../../../lib/application/passwords/index.js'; describe('Integration | Application | Passwords | password-controller', function () { let httpTestServer; diff --git a/api/tests/integration/application/pre-response-utils_test.js b/api/tests/integration/application/pre-response-utils_test.js index c5b8d8f2753..5eb3538549f 100644 --- a/api/tests/integration/application/pre-response-utils_test.js +++ b/api/tests/integration/application/pre-response-utils_test.js @@ -1,6 +1,6 @@ -const { expect, hFake } = require('../../test-helper'); +import { expect, hFake } from '../../test-helper.js'; -const { +import { BadRequestError, ConflictError, ForbiddenError, @@ -10,11 +10,10 @@ const { PreconditionFailedError, UnauthorizedError, UnprocessableEntityError, -} = require('../../../lib/application/http-errors'); +} from '../../../lib/application/http-errors.js'; -const { EntityValidationError } = require('../../../lib/domain/errors'); - -const { handleDomainAndHttpErrors } = require('../../../lib/application/pre-response-utils'); +import { EntityValidationError } from '../../../lib/domain/errors.js'; +import { handleDomainAndHttpErrors } from '../../../lib/application/pre-response-utils.js'; describe('Integration | Application | PreResponse-utils', function () { describe('#handleDomainAndHttpErrors', function () { diff --git a/api/tests/integration/application/prescribers/index_test.js b/api/tests/integration/application/prescribers/index_test.js index 156ada148d9..96704074eef 100644 --- a/api/tests/integration/application/prescribers/index_test.js +++ b/api/tests/integration/application/prescribers/index_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const prescriberController = require('../../../../lib/application/prescribers/prescriber-controller'); -const moduleUnderTest = require('../../../../lib/application/prescribers'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { prescriberController } from '../../../../lib/application/prescribers/prescriber-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/prescribers/index.js'; describe('Integration | Application | Prescribers | Routes', function () { let httpTestServer; diff --git a/api/tests/integration/application/prescribers/prescriber-controller_test.js b/api/tests/integration/application/prescribers/prescriber-controller_test.js index f2e71ea43be..6a68ae66452 100644 --- a/api/tests/integration/application/prescribers/prescriber-controller_test.js +++ b/api/tests/integration/application/prescribers/prescriber-controller_test.js @@ -1,9 +1,7 @@ -const { expect, sinon, domainBuilder, HttpTestServer } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const usecases = require('../../../../lib/domain/usecases/index.js'); - -const moduleUnderTest = require('../../../../lib/application/prescribers'); +import { expect, sinon, domainBuilder, HttpTestServer } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import * as moduleUnderTest from '../../../../lib/application/prescribers/index.js'; describe('Integration | Application | Prescribers | prescriber-controller', function () { let sandbox; diff --git a/api/tests/integration/application/sco-organization-learners/index_test.js b/api/tests/integration/application/sco-organization-learners/index_test.js index 3c4bc101328..1a79cc7858e 100644 --- a/api/tests/integration/application/sco-organization-learners/index_test.js +++ b/api/tests/integration/application/sco-organization-learners/index_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); - -const scoOrganizationLearnerController = require('../../../../lib/application/sco-organization-learners/sco-organization-learner-controller'); -const moduleUnderTest = require('../../../../lib/application/sco-organization-learners'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { scoOrganizationLearnerController } from '../../../../lib/application/sco-organization-learners/sco-organization-learner-controller.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/sco-organization-learners/index.js'; describe('Integration | Application | Route | sco-organization-learners', function () { let httpTestServer; diff --git a/api/tests/integration/application/sco-organization-learners/sco-organization-learner-controller_test.js b/api/tests/integration/application/sco-organization-learners/sco-organization-learner-controller_test.js index 4bbdf05ae06..626af687cff 100644 --- a/api/tests/integration/application/sco-organization-learners/sco-organization-learner-controller_test.js +++ b/api/tests/integration/application/sco-organization-learners/sco-organization-learner-controller_test.js @@ -1,14 +1,13 @@ -const { expect, sinon, domainBuilder, HttpTestServer } = require('../../../test-helper'); +import { expect, sinon, domainBuilder, HttpTestServer } from '../../../test-helper.js'; +import * as moduleUnderTest from '../../../../lib/application/sco-organization-learners/index.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; -const moduleUnderTest = require('../../../../lib/application/sco-organization-learners'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const { +import { NotFoundError, UserNotAuthorizedToUpdatePasswordError, UserNotAuthorizedToGenerateUsernamePasswordError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Integration | Application | sco-organization-learners | sco-organization-learner-controller', function () { let sandbox; diff --git a/api/tests/integration/application/scoring-simulator/scoring-simulator-controller_test.js b/api/tests/integration/application/scoring-simulator/scoring-simulator-controller_test.js index 62e2f94d479..e08f5eda928 100644 --- a/api/tests/integration/application/scoring-simulator/scoring-simulator-controller_test.js +++ b/api/tests/integration/application/scoring-simulator/scoring-simulator-controller_test.js @@ -1,11 +1,11 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); -const ScoringSimulationResult = require('../../../../lib/domain/models/ScoringSimulationResult'); -const ScoringSimulation = require('../../../../lib/domain/models/ScoringSimulation'); -const Answer = require('../../../../lib/domain/models/Answer'); -const ScoringSimulationContext = require('../../../../lib/domain/models/ScoringSimulationContext'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const moduleUnderTest = require('../../../../lib/application/scoring-simulator'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { ScoringSimulationResult } from '../../../../lib/domain/models/ScoringSimulationResult.js'; +import { ScoringSimulation } from '../../../../lib/domain/models/ScoringSimulation.js'; +import { Answer } from '../../../../lib/domain/models/Answer.js'; +import { ScoringSimulationContext } from '../../../../lib/domain/models/ScoringSimulationContext.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/scoring-simulator/index.js'; describe('Integration | Application | Scoring-simulator | scoring-simulator-controller', function () { let httpTestServer; diff --git a/api/tests/integration/application/security-pre-handlers_test.js b/api/tests/integration/application/security-pre-handlers_test.js index a454eef2b9d..c127373e870 100644 --- a/api/tests/integration/application/security-pre-handlers_test.js +++ b/api/tests/integration/application/security-pre-handlers_test.js @@ -1,13 +1,16 @@ -const { +import { expect, generateValidRequestAuthorizationHeader, databaseBuilder, HttpTestServer, sinon, -} = require('../../test-helper'); -const securityPreHandlers = require('../../../lib/application/security-pre-handlers'); -const settings = require('../../../lib/config'); -const { ROLES } = require('../../../lib/domain/constants').PIX_ADMIN; +} from '../../test-helper.js'; + +import { securityPreHandlers } from '../../../lib/application/security-pre-handlers.js'; +import { config as settings } from '../../../lib/config.js'; +import { PIX_ADMIN } from '../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; describe('Integration | Application | SecurityPreHandlers', function () { describe('check admin member roles for pix admin routes', function () { diff --git a/api/tests/integration/application/stage-collections/stage-collection-controller_test.js b/api/tests/integration/application/stage-collections/stage-collection-controller_test.js index 91ee3dc2c8c..3ad20627629 100644 --- a/api/tests/integration/application/stage-collections/stage-collection-controller_test.js +++ b/api/tests/integration/application/stage-collections/stage-collection-controller_test.js @@ -1,6 +1,6 @@ -const { expect, knex, databaseBuilder, hFake } = require('../../../test-helper'); -const controller = require('../../../../lib/application/stage-collections/stage-collection-controller'); -const stageCollectionRepository = require('../../../../lib/infrastructure/repositories/target-profile-management/stage-collection-repository'); +import { expect, knex, databaseBuilder, hFake } from '../../../test-helper.js'; +import { stageCollectionController } from '../../../../lib/application/stage-collections/stage-collection-controller.js'; +import * as stageCollectionRepository from '../../../../lib/infrastructure/repositories/target-profile-management/stage-collection-repository.js'; describe('Integration | Application | stage-collection-controller', function () { context('update', function () { @@ -99,60 +99,60 @@ describe('Integration | Application | stage-collection-controller', function () }; // when - await controller.update(request, hFake); + await stageCollectionController.update(request, hFake); // then const currentStageCollection = await stageCollectionRepository.getByTargetProfileId(targetProfileId); + const currentStages = currentStageCollection.toDTO(); const newStageIds = currentStageCollection.stages .map(({ id }) => id) .filter((value) => ![123, 456, 789].includes(value)) .sort(); - expect(currentStageCollection.toDTO()).to.deep.equal({ - id: targetProfileId, - targetProfileId, - stages: [ - { - id: newStageIds[0], - level: 2, - threshold: null, - isFirstSkill: false, - title: 'Palier niveau 2 titre', - message: 'Palier niveau 2 message', - prescriberTitle: 'Palier niveau 2 titre prescripteur', - prescriberDescription: 'Palier niveau 2 description prescripteur', - }, - { - id: newStageIds[1], - level: null, - threshold: null, - isFirstSkill: true, - title: 'Palier premier acquis titre', - message: 'Palier premier acquis message', - prescriberTitle: 'Palier premier acquis titre prescripteur', - prescriberDescription: 'Palier premier acquis description prescripteur', - }, - { - id: 123, - level: 0, - threshold: null, - isFirstSkill: false, - title: 'Palier niveau 0 titre', - message: 'Palier niveau 0 message', - prescriberTitle: 'Palier niveau 0 titre prescripteur', - prescriberDescription: 'Palier niveau 0 description prescripteur', - }, - { - id: 456, - level: 1, - threshold: null, - isFirstSkill: false, - title: 'Palier niveau 1 titre', - message: 'Palier niveau 1 message', - prescriberTitle: 'Palier niveau 1 titre prescripteur', - prescriberDescription: 'Palier niveau 1 description prescripteur', - }, - ], - }); + + expect(currentStages.id).to.equal(targetProfileId); + expect(currentStages.targetProfileId).to.equal(targetProfileId); + expect(currentStages.stages).to.have.deep.members([ + { + id: newStageIds[0], + level: 2, + threshold: null, + isFirstSkill: false, + title: 'Palier niveau 2 titre', + message: 'Palier niveau 2 message', + prescriberTitle: 'Palier niveau 2 titre prescripteur', + prescriberDescription: 'Palier niveau 2 description prescripteur', + }, + { + id: newStageIds[1], + level: null, + threshold: null, + isFirstSkill: true, + title: 'Palier premier acquis titre', + message: 'Palier premier acquis message', + prescriberTitle: 'Palier premier acquis titre prescripteur', + prescriberDescription: 'Palier premier acquis description prescripteur', + }, + { + id: 123, + level: 0, + threshold: null, + isFirstSkill: false, + title: 'Palier niveau 0 titre', + message: 'Palier niveau 0 message', + prescriberTitle: 'Palier niveau 0 titre prescripteur', + prescriberDescription: 'Palier niveau 0 description prescripteur', + }, + { + id: 456, + level: 1, + threshold: null, + isFirstSkill: false, + title: 'Palier niveau 1 titre', + message: 'Palier niveau 1 message', + prescriberTitle: 'Palier niveau 1 titre prescripteur', + prescriberDescription: 'Palier niveau 1 description prescripteur', + }, + ]); }); }); }); diff --git a/api/tests/integration/application/sup-organization-learners/index_test.js b/api/tests/integration/application/sup-organization-learners/index_test.js index a117ec09186..10c8541c4c4 100644 --- a/api/tests/integration/application/sup-organization-learners/index_test.js +++ b/api/tests/integration/application/sup-organization-learners/index_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, HttpTestServer, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); - -const supOrganizationLearnerController = require('../../../../lib/application/sup-organization-learners/sup-organization-learner-controller'); -const moduleUnderTest = require('../../../../lib/application/sup-organization-learners'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); +import { expect, sinon, HttpTestServer, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { supOrganizationLearnerController } from '../../../../lib/application/sup-organization-learners/sup-organization-learner-controller.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/sup-organization-learners/index.js'; describe('Integration | Application | Route | sup-organization-learners', function () { let httpTestServer; diff --git a/api/tests/integration/application/target-profile/presenter/pdf/learning-content-pdf-presenter_test.js b/api/tests/integration/application/target-profile/presenter/pdf/learning-content-pdf-presenter_test.js index 7f37c4b2f03..b5094de9993 100644 --- a/api/tests/integration/application/target-profile/presenter/pdf/learning-content-pdf-presenter_test.js +++ b/api/tests/integration/application/target-profile/presenter/pdf/learning-content-pdf-presenter_test.js @@ -1,7 +1,11 @@ -const { domainBuilder, expect, MockDate } = require('../../../../../test-helper'); -const { isSameBinary } = require('../../../../../tooling/binary-comparator'); -const learningContentPDFPresenter = require('../../../../../../lib/application/target-profiles/presenter/pdf/learning-content-pdf-presenter'); -const { addRandomSuffix } = require('pdf-lib/cjs/utils'); +import { domainBuilder, expect, MockDate, sinon } from '../../../../../test-helper.js'; +import { isSameBinary } from '../../../../../tooling/binary-comparator.js'; +import * as learningContentPDFPresenter from '../../../../../../lib/application/target-profiles/presenter/pdf/learning-content-pdf-presenter.js'; +import { writeFile } from 'fs/promises'; +import * as url from 'url'; +import pdfLibUtils from 'pdf-lib/cjs/utils/index.js'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); const REWRITE_REFERENCE_FILE = false; @@ -14,7 +18,6 @@ describe('Integration | Application | Target-Profiles | Presenter | PDF | Learni }); afterEach(function () { - _restorePdfLib(); MockDate.reset(); }); @@ -64,7 +67,6 @@ describe('Integration | Application | Target-Profiles | Presenter | PDF | Learni async function _writeFile(buffer, outputFilename) { // Note: to update the reference pdf, set REWRITE_REFERENCE_FILE to true. if (REWRITE_REFERENCE_FILE) { - const { writeFile } = require('fs/promises'); await writeFile(`${__dirname}/${outputFilename}`, buffer); } } @@ -83,11 +85,7 @@ function _makePdfLibPredictable() { return prefix + '-' + Math.floor(suffix); } - require('pdf-lib/cjs/utils').addRandomSuffix = autoIncrementSuffixByPrefix; -} - -function _restorePdfLib() { - require('pdf-lib/cjs/utils').addRandomSuffix = addRandomSuffix; + sinon.stub(pdfLibUtils, 'addRandomSuffix').callsFake(autoIncrementSuffixByPrefix); } function _buildRichLearningContent() { diff --git a/api/tests/integration/application/usecases/checkAuthorizationToManageCampaign_test.js b/api/tests/integration/application/usecases/checkAuthorizationToManageCampaign_test.js index 7800bc8f114..5f7b40bda8e 100644 --- a/api/tests/integration/application/usecases/checkAuthorizationToManageCampaign_test.js +++ b/api/tests/integration/application/usecases/checkAuthorizationToManageCampaign_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const checkAuthorizationToManageCampaign = require('../../../../lib/application/usecases/checkAuthorizationToManageCampaign'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as checkAuthorizationToManageCampaign from '../../../../lib/application/usecases/checkAuthorizationToManageCampaign.js'; describe('Integration | API | checkAuthorizationToManageCampaign', function () { describe('when the user is member in organization and owner of the campaign', function () { diff --git a/api/tests/integration/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization_test.js b/api/tests/integration/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization_test.js index 73baaf3e51a..d235c5b4d17 100644 --- a/api/tests/integration/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization_test.js +++ b/api/tests/integration/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const checkUserIsAdminAndManagingStudentsForOrganization = require('../../../../lib/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization'); -const Membership = require('../../../../lib/domain/models/Membership'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as checkUserIsAdminAndManagingStudentsForOrganization from '../../../../lib/application/usecases/checkUserIsAdminAndManagingStudentsForOrganization.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; describe('Integration | API | checkUserIsAdminAndManagingStudentsForOrganization', function () { describe('when the user does not belongs to the organization', function () { diff --git a/api/tests/integration/application/users/index_test.js b/api/tests/integration/application/users/index_test.js index 69f43a69b17..3a7a7563b02 100644 --- a/api/tests/integration/application/users/index_test.js +++ b/api/tests/integration/application/users/index_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, HttpTestServer, knex } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const userController = require('../../../../lib/application/users/user-controller'); -const moduleUnderTest = require('../../../../lib/application/users'); +import { expect, sinon, HttpTestServer, knex } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { userController } from '../../../../lib/application/users/user-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/users/index.js'; describe('Integration | Application | Users | Routes', function () { const methodGET = 'GET'; diff --git a/api/tests/integration/application/users/user-controller_test.js b/api/tests/integration/application/users/user-controller_test.js index f4e9c633366..e2ff51e7933 100644 --- a/api/tests/integration/application/users/user-controller_test.js +++ b/api/tests/integration/application/users/user-controller_test.js @@ -1,10 +1,9 @@ -const { expect, sinon, domainBuilder, HttpTestServer } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const { UserNotAuthorizedToRemoveAuthenticationMethod } = require('../../../../lib/domain/errors'); -const AssessmentResult = require('../../../../lib/domain/read-models/participant-results/AssessmentResult'); -const moduleUnderTest = require('../../../../lib/application/users'); +import { expect, sinon, domainBuilder, HttpTestServer } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToRemoveAuthenticationMethod } from '../../../../lib/domain/errors.js'; +import { AssessmentResult } from '../../../../lib/domain/read-models/participant-results/AssessmentResult.js'; +import * as moduleUnderTest from '../../../../lib/application/users/index.js'; describe('Integration | Application | Users | user-controller', function () { let sandbox; diff --git a/api/tests/integration/domain/event/handle-pole-emploi-participation-finished_test.js b/api/tests/integration/domain/event/handle-pole-emploi-participation-finished_test.js index 5c646826e01..c565b8264b3 100644 --- a/api/tests/integration/domain/event/handle-pole-emploi-participation-finished_test.js +++ b/api/tests/integration/domain/event/handle-pole-emploi-participation-finished_test.js @@ -1,20 +1,21 @@ -const { +import { expect, databaseBuilder, knex, mockLearningContent, learningContentBuilder, sinon, -} = require('../../../test-helper'); -const handlePoleEmploiParticipationFinished = require('../../../../lib/domain/events/handle-pole-emploi-participation-finished'); -const assessmentRepository = require('../../../../lib/infrastructure/repositories/assessment-repository'); -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const campaignParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-repository'); -const organizationRepository = require('../../../../lib/infrastructure/repositories/organization-repository'); -const poleEmploiSendingRepository = require('../../../../lib/infrastructure/repositories/pole-emploi-sending-repository'); -const targetProfileRepository = require('../../../../lib/infrastructure/repositories/target-profile-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); -const AsessmentCompletedEvent = require('../../../../lib/domain/events/AssessmentCompleted'); +} from '../../../test-helper.js'; + +import { handlePoleEmploiParticipationFinished } from '../../../../lib/domain/events/handle-pole-emploi-participation-finished.js'; +import * as assessmentRepository from '../../../../lib/infrastructure/repositories/assessment-repository.js'; +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import * as campaignParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-participation-repository.js'; +import * as organizationRepository from '../../../../lib/infrastructure/repositories/organization-repository.js'; +import * as poleEmploiSendingRepository from '../../../../lib/infrastructure/repositories/pole-emploi-sending-repository.js'; +import * as targetProfileRepository from '../../../../lib/infrastructure/repositories/target-profile-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; +import { AssessmentCompleted as AsessmentCompletedEvent } from '../../../../lib/domain/events/AssessmentCompleted.js'; describe('Integration | Event | Handle Pole emploi participation finished', function () { let campaignParticipationId, userId, event, poleEmploiNotifier, responseCode; @@ -37,7 +38,7 @@ describe('Integration | Event | Handle Pole emploi participation finished', func event = new AsessmentCompletedEvent(); event.campaignParticipationId = campaignParticipationId; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([]); + const learningContentObjects = learningContentBuilder.fromAreas([]); mockLearningContent(learningContentObjects); return databaseBuilder.commit(); diff --git a/api/tests/integration/domain/event/handle-pole-emploi-participation-started_test.js b/api/tests/integration/domain/event/handle-pole-emploi-participation-started_test.js index e3d4815fea7..43e64f4240e 100644 --- a/api/tests/integration/domain/event/handle-pole-emploi-participation-started_test.js +++ b/api/tests/integration/domain/event/handle-pole-emploi-participation-started_test.js @@ -1,20 +1,21 @@ -const { +import { expect, databaseBuilder, knex, mockLearningContent, learningContentBuilder, sinon, -} = require('../../../test-helper'); -const handlePoleEmploiParticipationStarted = require('../../../../lib/domain/events/handle-pole-emploi-participation-started'); -const assessmentRepository = require('../../../../lib/infrastructure/repositories/assessment-repository'); -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const campaignParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-repository'); -const organizationRepository = require('../../../../lib/infrastructure/repositories/organization-repository'); -const poleEmploiSendingRepository = require('../../../../lib/infrastructure/repositories/pole-emploi-sending-repository'); -const targetProfileRepository = require('../../../../lib/infrastructure/repositories/target-profile-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); -const CampaignParticipationStartedEvent = require('../../../../lib/domain/events/CampaignParticipationStarted'); +} from '../../../test-helper.js'; + +import { handlePoleEmploiParticipationStarted } from '../../../../lib/domain/events/handle-pole-emploi-participation-started.js'; +import * as assessmentRepository from '../../../../lib/infrastructure/repositories/assessment-repository.js'; +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import * as campaignParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-participation-repository.js'; +import * as organizationRepository from '../../../../lib/infrastructure/repositories/organization-repository.js'; +import * as poleEmploiSendingRepository from '../../../../lib/infrastructure/repositories/pole-emploi-sending-repository.js'; +import * as targetProfileRepository from '../../../../lib/infrastructure/repositories/target-profile-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; +import { CampaignParticipationStarted as CampaignParticipationStartedEvent } from '../../../../lib/domain/events/CampaignParticipationStarted.js'; describe('Integration | Event | Handle Pole emploi participation started', function () { let campaignParticipationId, userId, event, poleEmploiNotifier, responseCode; @@ -37,7 +38,7 @@ describe('Integration | Event | Handle Pole emploi participation started', funct event = new CampaignParticipationStartedEvent(); event.campaignParticipationId = campaignParticipationId; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([]); + const learningContentObjects = learningContentBuilder.fromAreas([]); mockLearningContent(learningContentObjects); return databaseBuilder.commit(); diff --git a/api/tests/integration/domain/services/algorithm-methods/flash_test.js b/api/tests/integration/domain/services/algorithm-methods/flash_test.js index 0a5e48ba226..d5b9f212158 100644 --- a/api/tests/integration/domain/services/algorithm-methods/flash_test.js +++ b/api/tests/integration/domain/services/algorithm-methods/flash_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const flash = require('../../../../../lib/domain/services/algorithm-methods/flash'); -const AnswerStatus = require('../../../../../lib/domain/models/AnswerStatus'); -const config = require('../../../../../lib/config'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as flash from '../../../../../lib/domain/services/algorithm-methods/flash.js'; +import { AnswerStatus } from '../../../../../lib/domain/models/AnswerStatus.js'; +import { config } from '../../../../../lib/config.js'; describe('Integration | Domain | Algorithm-methods | Flash', function () { describe('#getPossibleNextChallenge', function () { diff --git a/api/tests/integration/domain/services/algorithm-methods/smart-random_test.js b/api/tests/integration/domain/services/algorithm-methods/smart-random_test.js index 3b3b6cf7cec..569ce711160 100644 --- a/api/tests/integration/domain/services/algorithm-methods/smart-random_test.js +++ b/api/tests/integration/domain/services/algorithm-methods/smart-random_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const AnswerStatus = require('../../../../../lib/domain/models/AnswerStatus'); -const SmartRandom = require('../../../../../lib/domain/services/algorithm-methods/smart-random'); -const _ = require('lodash'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import { AnswerStatus } from '../../../../../lib/domain/models/AnswerStatus.js'; +import * as SmartRandom from '../../../../../lib/domain/services/algorithm-methods/smart-random.js'; +import _ from 'lodash'; const KNOWLEDGE_ELEMENT_STATUS = { VALIDATED: 'validated', diff --git a/api/tests/integration/domain/services/authentication/fwb-oidc-authentication-service_test.js b/api/tests/integration/domain/services/authentication/fwb-oidc-authentication-service_test.js index a31450fcb43..8a6989131e3 100644 --- a/api/tests/integration/domain/services/authentication/fwb-oidc-authentication-service_test.js +++ b/api/tests/integration/domain/services/authentication/fwb-oidc-authentication-service_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const { temporaryStorage } = require('../../../../../lib/infrastructure/temporary-storage'); -const FwbOidcAuthenticationService = require('../../../../../lib/domain/services/authentication/fwb-oidc-authentication-service'); +import { expect } from '../../../../test-helper.js'; +import { temporaryStorage } from '../../../../../lib/infrastructure/temporary-storage/index.js'; +import { FwbOidcAuthenticationService } from '../../../../../lib/domain/services/authentication/fwb-oidc-authentication-service.js'; const logoutUrlTemporaryStorage = temporaryStorage.withPrefix('logout-url:'); diff --git a/api/tests/integration/domain/services/authentication/pole-emploi-oidc-authentication-service_test.js b/api/tests/integration/domain/services/authentication/pole-emploi-oidc-authentication-service_test.js index ecb4b909513..b2cb4693995 100644 --- a/api/tests/integration/domain/services/authentication/pole-emploi-oidc-authentication-service_test.js +++ b/api/tests/integration/domain/services/authentication/pole-emploi-oidc-authentication-service_test.js @@ -1,10 +1,10 @@ -const { expect, knex } = require('../../../../test-helper'); -const { temporaryStorage } = require('../../../../../lib/infrastructure/temporary-storage'); -const authenticationMethodRepository = require('../../../../../lib/infrastructure/repositories/authentication-method-repository'); -const userToCreateRepository = require('../../../../../lib/infrastructure/repositories/user-to-create-repository'); -const PoleEmploiOidcAuthenticationService = require('../../../../../lib/domain/services/authentication/pole-emploi-oidc-authentication-service'); -const UserToCreate = require('../../../../../lib/domain/models/UserToCreate'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); +import { expect, knex } from '../../../../test-helper.js'; +import { temporaryStorage } from '../../../../../lib/infrastructure/temporary-storage/index.js'; +import * as authenticationMethodRepository from '../../../../../lib/infrastructure/repositories/authentication-method-repository.js'; +import * as userToCreateRepository from '../../../../../lib/infrastructure/repositories/user-to-create-repository.js'; +import { PoleEmploiOidcAuthenticationService } from '../../../../../lib/domain/services/authentication/pole-emploi-oidc-authentication-service.js'; +import { UserToCreate } from '../../../../../lib/domain/models/UserToCreate.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; const logoutUrlTemporaryStorage = temporaryStorage.withPrefix('logout-url:'); diff --git a/api/tests/integration/domain/services/certification-badges-service_test.js b/api/tests/integration/domain/services/certification-badges-service_test.js index 25c05dd268a..3c2a03244d3 100644 --- a/api/tests/integration/domain/services/certification-badges-service_test.js +++ b/api/tests/integration/domain/services/certification-badges-service_test.js @@ -1,13 +1,14 @@ -const { +import { expect, databaseBuilder, mockLearningContent, learningContentBuilder, domainBuilder, -} = require('../../../test-helper'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +} from '../../../test-helper.js'; -const certificationBadgesService = require('../../../../lib/domain/services/certification-badges-service'); +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; + +import * as certificationBadgesService from '../../../../lib/domain/services/certification-badges-service.js'; const listSkill = ['web1', 'web2', 'web3', 'web4']; const learningContent = [ @@ -93,7 +94,7 @@ describe('Integration | Service | Certification-Badges Service', function () { threshold: 40, }); await databaseBuilder.commit(); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); // when diff --git a/api/tests/integration/domain/services/certification-candidates-ods-service/certification-candidates-ods-service_test.js b/api/tests/integration/domain/services/certification-candidates-ods-service/certification-candidates-ods-service_test.js index daf978e1b2f..b76e9fac84a 100644 --- a/api/tests/integration/domain/services/certification-candidates-ods-service/certification-candidates-ods-service_test.js +++ b/api/tests/integration/domain/services/certification-candidates-ods-service/certification-candidates-ods-service_test.js @@ -1,23 +1,31 @@ -const { expect, databaseBuilder, catchErr, domainBuilder } = require('../../../../test-helper'); -const { +import { expect, databaseBuilder, catchErr, domainBuilder } from '../../../../test-helper.js'; +import { CLEA, PIX_PLUS_DROIT, PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE, -} = require('../../../../../lib/domain/models/ComplementaryCertification'); -const certificationCandidatesOdsService = require('../../../../../lib/domain/services/certification-candidates-ods-service'); -const certificationCpfService = require('../../../../../lib/domain/services/certification-cpf-service'); -const certificationCpfCountryRepository = require('../../../../../lib/infrastructure/repositories/certification-cpf-country-repository'); -const certificationCpfCityRepository = require('../../../../../lib/infrastructure/repositories/certification-cpf-city-repository'); -const certificationCenterRepository = require('../../../../../lib/infrastructure/repositories/certification-center-repository'); -const complementaryCertificationRepository = require('../../../../../lib/infrastructure/repositories/complementary-certification-repository'); -const CertificationCandidate = require('../../../../../lib/domain/models/CertificationCandidate'); -const { CertificationCandidatesImportError } = require('../../../../../lib/domain/errors'); -const { readFile } = require('fs').promises; -const _ = require('lodash'); -const { getI18n } = require('../../../../tooling/i18n/i18n'); +} from '../../../../../lib/domain/models/ComplementaryCertification.js'; +import * as certificationCandidatesOdsService from '../../../../../lib/domain/services/certification-candidates-ods-service.js'; +import * as certificationCpfService from '../../../../../lib/domain/services/certification-cpf-service.js'; +import * as certificationCpfCountryRepository from '../../../../../lib/infrastructure/repositories/certification-cpf-country-repository.js'; +import * as certificationCpfCityRepository from '../../../../../lib/infrastructure/repositories/certification-cpf-city-repository.js'; +import * as certificationCenterRepository from '../../../../../lib/infrastructure/repositories/certification-center-repository.js'; +import * as complementaryCertificationRepository from '../../../../../lib/infrastructure/repositories/complementary-certification-repository.js'; +import { CertificationCandidate } from '../../../../../lib/domain/models/CertificationCandidate.js'; +import { CertificationCandidatesImportError } from '../../../../../lib/domain/errors.js'; +import fs from 'fs'; + +const { promises } = fs; + +const { readFile } = promises; + +import _ from 'lodash'; +import { getI18n } from '../../../../tooling/i18n/i18n.js'; const i18n = getI18n(); +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); + describe('Integration | Services | extractCertificationCandidatesFromCandidatesImportSheet', function () { let userId; let sessionId; diff --git a/api/tests/integration/domain/services/organization-invitation-service_test.js b/api/tests/integration/domain/services/organization-invitation-service_test.js index 3e86fa88a89..316e209821b 100644 --- a/api/tests/integration/domain/services/organization-invitation-service_test.js +++ b/api/tests/integration/domain/services/organization-invitation-service_test.js @@ -1,18 +1,15 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, knex, sinon, catchErr } = require('../../../test-helper'); +import _ from 'lodash'; +import { expect, databaseBuilder, knex, sinon, catchErr } from '../../../test-helper.js'; -const organizationInvitationRepository = require('../../../../lib/infrastructure/repositories/organization-invitation-repository'); -const organizationRepository = require('../../../../lib/infrastructure/repositories/organization-repository'); -const mailService = require('../../../../lib/domain/services/mail-service'); +import * as organizationInvitationRepository from '../../../../lib/infrastructure/repositories/organization-invitation-repository.js'; +import * as organizationRepository from '../../../../lib/infrastructure/repositories/organization-repository.js'; +import { mailService } from '../../../../lib/domain/services/mail-service.js'; -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const Membership = require('../../../../lib/domain/models/Membership'); - -const { - createOrUpdateOrganizationInvitation, -} = require('../../../../lib/domain/services/organization-invitation-service'); -const EmailingAttempt = require('../../../../lib/domain/models/EmailingAttempt'); -const { SendingEmailError } = require('../../../../lib/domain/errors'); +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { createOrUpdateOrganizationInvitation } from '../../../../lib/domain/services/organization-invitation-service.js'; +import { EmailingAttempt } from '../../../../lib/domain/models/EmailingAttempt.js'; +import { SendingEmailError } from '../../../../lib/domain/errors.js'; describe('Integration | Service | Organization-Invitation Service', function () { describe('#createOrUpdateOrganizationInvitation', function () { @@ -100,6 +97,9 @@ describe('Integration | Service | Organization-Invitation Service', function () email, organizationRepository, organizationInvitationRepository, + dependencies: { + mailService, + }, }); // then diff --git a/api/tests/integration/domain/services/organization-learners-csv-service_test.js b/api/tests/integration/domain/services/organization-learners-csv-service_test.js index 4089aa67d2b..1141737c3d8 100644 --- a/api/tests/integration/domain/services/organization-learners-csv-service_test.js +++ b/api/tests/integration/domain/services/organization-learners-csv-service_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, catchErr } = require('../../../test-helper'); -const { CsvImportError } = require('../../../../lib/domain/errors'); -const organizationLearnersCsvService = require('../../../../lib/domain/services/organization-learners-csv-service'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import _ from 'lodash'; +import { expect, catchErr } from '../../../test-helper.js'; +import { CsvImportError } from '../../../../lib/domain/errors.js'; +import { extractOrganizationLearnersInformation } from '../../../../lib/domain/services/organization-learners-csv-service.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; const i18n = getI18n(); describe('Integration | Services | organization-learners-csv-service', function () { @@ -49,11 +49,7 @@ describe('Integration | Services | organization-learners-csv-service', function ]; // when - const results = await organizationLearnersCsvService.extractOrganizationLearnersInformation( - path, - organization, - i18n - ); + const results = await extractOrganizationLearnersInformation(path, organization, i18n); //then const actualResult = _.map(results, (result) => @@ -67,11 +63,7 @@ describe('Integration | Services | organization-learners-csv-service', function const organization = { id: 123, isAgriculture: true }; const path = `${process.cwd()}/tests/tooling/fixtures/siecle-file/siecle-csv-with-unknown-encoding.csv`; // when - const error = await catchErr(organizationLearnersCsvService.extractOrganizationLearnersInformation)( - path, - organization, - i18n - ); + const error = await catchErr(extractOrganizationLearnersInformation)(path, organization, i18n); //then expect(error).to.be.instanceof(CsvImportError); @@ -83,11 +75,7 @@ describe('Integration | Services | organization-learners-csv-service', function const organization = { id: 123, isAgriculture: true }; const path = `${process.cwd()}/tests/tooling/fixtures/siecle-file/siecle-csv-with-duplicate-national-student-id.csv`; // when - const error = await catchErr(organizationLearnersCsvService.extractOrganizationLearnersInformation)( - path, - organization, - i18n - ); + const error = await catchErr(extractOrganizationLearnersInformation)(path, organization, i18n); //then expect(error).to.be.instanceof(CsvImportError); @@ -100,11 +88,7 @@ describe('Integration | Services | organization-learners-csv-service', function const organization = { id: 123, isAgriculture: true }; const path = `${process.cwd()}/tests/tooling/fixtures/siecle-file/siecle-csv-with-no-national-student-id.csv`; // when - const error = await catchErr(organizationLearnersCsvService.extractOrganizationLearnersInformation)( - path, - organization, - i18n - ); + const error = await catchErr(extractOrganizationLearnersInformation)(path, organization, i18n); //then expect(error).to.be.instanceof(CsvImportError); diff --git a/api/tests/integration/domain/services/organization-learners-xml-service_test.js b/api/tests/integration/domain/services/organization-learners-xml-service_test.js index 0652192706e..4fde2549bb0 100644 --- a/api/tests/integration/domain/services/organization-learners-xml-service_test.js +++ b/api/tests/integration/domain/services/organization-learners-xml-service_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr } = require('../../../test-helper'); -const { SiecleXmlImportError } = require('../../../../lib/domain/errors'); -const organizationLearnersXmlService = require('../../../../lib/domain/services/organization-learners-xml-service'); +import { expect, catchErr } from '../../../test-helper.js'; +import { SiecleXmlImportError } from '../../../../lib/domain/errors.js'; +import * as organizationLearnersXmlService from '../../../../lib/domain/services/organization-learners-xml-service.js'; describe('Integration | Services | organization-learnerz-xml-service', function () { describe('extractOrganizationLearnersInformationFromSIECLE', function () { diff --git a/api/tests/integration/domain/services/pick-certification-challenge_test.js b/api/tests/integration/domain/services/pick-certification-challenge_test.js index 1c10fb59566..a15315bb1eb 100644 --- a/api/tests/integration/domain/services/pick-certification-challenge_test.js +++ b/api/tests/integration/domain/services/pick-certification-challenge_test.js @@ -1,10 +1,10 @@ -const { expect, databaseBuilder, mockLearningContent } = require('../../../test-helper'); -const placementProfileService = require('../../../../lib/domain/services/placement-profile-service'); -const certificationChallengesService = require('../../../../lib/domain/services/certification-challenges-service'); -const knowledgeElementRepository = require('../../../../lib/infrastructure/repositories/knowledge-element-repository'); -const answerRepository = require('../../../../lib/infrastructure/repositories/answer-repository'); -const challengeRepository = require('../../../../lib/infrastructure/repositories/challenge-repository'); -const { PIX_COUNT_BY_LEVEL } = require('../../../../lib/domain/constants'); +import { expect, databaseBuilder, mockLearningContent } from '../../../test-helper.js'; +import * as placementProfileService from '../../../../lib/domain/services/placement-profile-service.js'; +import * as certificationChallengesService from '../../../../lib/domain/services/certification-challenges-service.js'; +import * as knowledgeElementRepository from '../../../../lib/infrastructure/repositories/knowledge-element-repository.js'; +import * as answerRepository from '../../../../lib/infrastructure/repositories/answer-repository.js'; +import * as challengeRepository from '../../../../lib/infrastructure/repositories/challenge-repository.js'; +import { PIX_COUNT_BY_LEVEL } from '../../../../lib/domain/constants.js'; describe('Integration | CertificationChallengeService | pickCertificationChallenge', function () { const placementDate = new Date('2020-01-01'); diff --git a/api/tests/integration/domain/services/placement-profile-service_test.js b/api/tests/integration/domain/services/placement-profile-service_test.js index 2793328f99f..29d9a512bdb 100644 --- a/api/tests/integration/domain/services/placement-profile-service_test.js +++ b/api/tests/integration/domain/services/placement-profile-service_test.js @@ -1,7 +1,9 @@ -const { expect, databaseBuilder, mockLearningContent, learningContentBuilder } = require('../../../test-helper'); -const placementProfileService = require('../../../../lib/domain/services/placement-profile-service'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const { ENGLISH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { expect, databaseBuilder, mockLearningContent, learningContentBuilder } from '../../../test-helper.js'; +import * as placementProfileService from '../../../../lib/domain/services/placement-profile-service.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { ENGLISH_SPOKEN } = LOCALE; describe('Integration | Service | Placement Profile Service', function () { let userId, assessmentId; @@ -86,7 +88,7 @@ describe('Integration | Service | Placement Profile Service', function () { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); userId = databaseBuilder.factory.buildUser().id; diff --git a/api/tests/integration/domain/services/reset-password-service_test.js b/api/tests/integration/domain/services/reset-password-service_test.js index 12160c0f078..e38b5352c2d 100644 --- a/api/tests/integration/domain/services/reset-password-service_test.js +++ b/api/tests/integration/domain/services/reset-password-service_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const resetPasswordService = require('../../../../lib/domain/services/reset-password-service'); +import { expect } from '../../../test-helper.js'; +import * as resetPasswordService from '../../../../lib/domain/services/reset-password-service.js'; describe('Integration | Service | Password Service', function () { describe('#generateTemporaryKey', function () { diff --git a/api/tests/integration/domain/services/token-service_test.js b/api/tests/integration/domain/services/token-service_test.js index 274be527814..30a76af7905 100644 --- a/api/tests/integration/domain/services/token-service_test.js +++ b/api/tests/integration/domain/services/token-service_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const tokenService = require('../../../../lib/domain/services/token-service'); -const settings = require('../../../../lib/config'); +import { expect } from '../../../test-helper.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import { config as settings } from '../../../../lib/config.js'; describe('Integration | Domain | Services | TokenService', function () { describe('#createAccessTokenForSaml', function () { diff --git a/api/tests/integration/domain/services/tube-service_test.js b/api/tests/integration/domain/services/tube-service_test.js index 039b487f428..897bfc78ea4 100644 --- a/api/tests/integration/domain/services/tube-service_test.js +++ b/api/tests/integration/domain/services/tube-service_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../test-helper'); -const Skill = require('../../../../lib/domain/models/Skill'); -const Tube = require('../../../../lib/domain/models/Tube'); -const { computeTubesFromSkills } = require('../../../../lib/domain/services/tube-service'); +import { expect } from '../../../test-helper.js'; +import { Skill } from '../../../../lib/domain/models/Skill.js'; +import { Tube } from '../../../../lib/domain/models/Tube.js'; +import { computeTubesFromSkills } from '../../../../lib/domain/services/tube-service.js'; describe('Integration | Domain | Services | TubeService', function () { describe('#computeTubesFromSkills', function () { diff --git a/api/tests/integration/domain/services/user-service_test.js b/api/tests/integration/domain/services/user-service_test.js index 1ed6b1e69f4..1dc74caca88 100644 --- a/api/tests/integration/domain/services/user-service_test.js +++ b/api/tests/integration/domain/services/user-service_test.js @@ -1,16 +1,17 @@ -const pick = require('lodash/pick'); +import lodash from 'lodash'; +const { pick } = lodash; -const { catchErr, domainBuilder, databaseBuilder, expect, knex } = require('../../../test-helper'); +import { catchErr, domainBuilder, databaseBuilder, expect, knex } from '../../../test-helper.js'; -const authenticationMethodRepository = require('../../../../lib/infrastructure/repositories/authentication-method-repository'); -const organizationLearnerRepository = require('../../../../lib/infrastructure/repositories/organization-learner-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); -const userToCreateRepository = require('../../../../lib/infrastructure/repositories/user-to-create-repository'); +import * as authenticationMethodRepository from '../../../../lib/infrastructure/repositories/authentication-method-repository.js'; +import * as organizationLearnerRepository from '../../../../lib/infrastructure/repositories/organization-learner-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; +import * as userToCreateRepository from '../../../../lib/infrastructure/repositories/user-to-create-repository.js'; -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const { OrganizationLearnerNotFound } = require('../../../../lib/domain/errors'); +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import { OrganizationLearnerNotFound } from '../../../../lib/domain/errors.js'; -const userService = require('../../../../lib/domain/services/user-service'); +import * as userService from '../../../../lib/domain/services/user-service.js'; describe('Integration | Domain | Services | user-service', function () { const hashedPassword = 'Abcdef1234'; diff --git a/api/tests/integration/domain/usecases/abort-certification-course_test.js b/api/tests/integration/domain/usecases/abort-certification-course_test.js index 4d0ca5bb6dc..d6b402127a3 100644 --- a/api/tests/integration/domain/usecases/abort-certification-course_test.js +++ b/api/tests/integration/domain/usecases/abort-certification-course_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const abortCertificationCourse = require('../../../../lib/domain/usecases/abort-certification-course'); -const certificationCourseRepository = require('../../../../lib/infrastructure/repositories/certification-course-repository'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { abortCertificationCourse } from '../../../../lib/domain/usecases/abort-certification-course.js'; +import * as certificationCourseRepository from '../../../../lib/infrastructure/repositories/certification-course-repository.js'; describe('Integration | UseCase | abort-certification-course', function () { context('when abort reason is valid', function () { diff --git a/api/tests/integration/domain/usecases/account-recovery/update-user-for-account-recovery_test.js b/api/tests/integration/domain/usecases/account-recovery/update-user-for-account-recovery_test.js index db0f9c9fb6c..5e7c4ba5252 100644 --- a/api/tests/integration/domain/usecases/account-recovery/update-user-for-account-recovery_test.js +++ b/api/tests/integration/domain/usecases/account-recovery/update-user-for-account-recovery_test.js @@ -1,12 +1,12 @@ -const { catchErr, databaseBuilder, expect, knex } = require('../../../../test-helper'); -const DomainTransaction = require('../../../../../lib/infrastructure/DomainTransaction'); +import { catchErr, databaseBuilder, expect, knex } from '../../../../test-helper.js'; +import { DomainTransaction } from '../../../../../lib/infrastructure/DomainTransaction.js'; -const authenticationMethodRepository = require('../../../../../lib/infrastructure/repositories/authentication-method-repository'); -const accountRecoveryDemandRepository = require('../../../../../lib/infrastructure/repositories/account-recovery-demand-repository'); -const userRepository = require('../../../../../lib/infrastructure/repositories/user-repository'); -const encryptionService = require('../../../../../lib/domain/services/encryption-service'); +import * as authenticationMethodRepository from '../../../../../lib/infrastructure/repositories/authentication-method-repository.js'; +import * as accountRecoveryDemandRepository from '../../../../../lib/infrastructure/repositories/account-recovery-demand-repository.js'; +import * as userRepository from '../../../../../lib/infrastructure/repositories/user-repository.js'; +import * as encryptionService from '../../../../../lib/domain/services/encryption-service.js'; -const updateUserForAccountRecovery = require('../../../../../lib/domain/usecases/account-recovery/update-user-for-account-recovery'); +import { updateUserForAccountRecovery } from '../../../../../lib/domain/usecases/account-recovery/update-user-for-account-recovery.js'; describe('Integration | UseCases | Account-recovery | updateUserForAccountRecovery', function () { it('should rollback update user account when domain transaction throw an error', async function () { diff --git a/api/tests/integration/domain/usecases/add-pix-authentication-method-by-email_test.js b/api/tests/integration/domain/usecases/add-pix-authentication-method-by-email_test.js index 17c50485551..bcf829c7523 100644 --- a/api/tests/integration/domain/usecases/add-pix-authentication-method-by-email_test.js +++ b/api/tests/integration/domain/usecases/add-pix-authentication-method-by-email_test.js @@ -1,8 +1,8 @@ -const { databaseBuilder, expect, catchErr } = require('../../../test-helper'); -const addPixAuthenticationMethodByEmail = require('../../../../lib/domain/usecases/add-pix-authentication-method-by-email'); -const { AuthenticationMethodAlreadyExistsError } = require('../../../../lib/domain/errors'); -const authenticationMethodRepository = require('../../../../lib/infrastructure/repositories/authentication-method-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); +import { databaseBuilder, expect, catchErr } from '../../../test-helper.js'; +import { addPixAuthenticationMethodByEmail } from '../../../../lib/domain/usecases/add-pix-authentication-method-by-email.js'; +import { AuthenticationMethodAlreadyExistsError } from '../../../../lib/domain/errors.js'; +import * as authenticationMethodRepository from '../../../../lib/infrastructure/repositories/authentication-method-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; describe('Integration | UseCase | add-pix-authentication-method-by-email', function () { context('when user have already Pix authentication method', function () { diff --git a/api/tests/integration/domain/usecases/attach-organizations-from-existing-target-profile_test.js b/api/tests/integration/domain/usecases/attach-organizations-from-existing-target-profile_test.js index b9c706bec96..ff5a5ab3881 100644 --- a/api/tests/integration/domain/usecases/attach-organizations-from-existing-target-profile_test.js +++ b/api/tests/integration/domain/usecases/attach-organizations-from-existing-target-profile_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, databaseBuilder, knex, catchErr } = require('../../../test-helper'); -const { NoOrganizationToAttach, NotFoundError } = require('../../../../lib/domain/errors'); -const attachOrganizationsFromExistingTargetProfile = require('../../../../lib/domain/usecases/attach-organizations-from-existing-target-profile'); -const organizationsToAttachToTargetProfileRepository = require('../../../../lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository'); -const targetProfileRepository = require('../../../../lib/infrastructure/repositories/target-profile-repository'); -const { skillDatasource } = require('../../../../lib/infrastructure/datasources/learning-content/skill-datasource'); +import { expect, sinon, databaseBuilder, knex, catchErr } from '../../../test-helper.js'; +import { NoOrganizationToAttach, NotFoundError } from '../../../../lib/domain/errors.js'; +import { attachOrganizationsFromExistingTargetProfile } from '../../../../lib/domain/usecases/attach-organizations-from-existing-target-profile.js'; +import * as organizationsToAttachToTargetProfileRepository from '../../../../lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js'; +import * as targetProfileRepository from '../../../../lib/infrastructure/repositories/target-profile-repository.js'; +import { skillDatasource } from '../../../../lib/infrastructure/datasources/learning-content/skill-datasource.js'; describe('Integration | UseCase | attach-organizations-from-existing-target-profile', function () { beforeEach(function () { diff --git a/api/tests/integration/domain/usecases/attach-organizations-to-target-profile_test.js b/api/tests/integration/domain/usecases/attach-organizations-to-target-profile_test.js index 803698b2c7a..7d9dda66947 100644 --- a/api/tests/integration/domain/usecases/attach-organizations-to-target-profile_test.js +++ b/api/tests/integration/domain/usecases/attach-organizations-to-target-profile_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, databaseBuilder, knex } = require('../../../test-helper'); -const attachOrganizationsToTargetProfile = require('../../../../lib/domain/usecases/attach-organizations-to-target-profile'); -const organizationsToAttachToTargetProfileRepository = require('../../../../lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository'); -const { skillDatasource } = require('../../../../lib/infrastructure/datasources/learning-content/skill-datasource'); +import { expect, sinon, databaseBuilder, knex } from '../../../test-helper.js'; +import { attachOrganizationsToTargetProfile } from '../../../../lib/domain/usecases/attach-organizations-to-target-profile.js'; +import * as organizationsToAttachToTargetProfileRepository from '../../../../lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js'; +import { skillDatasource } from '../../../../lib/infrastructure/datasources/learning-content/skill-datasource.js'; describe('Integration | UseCase | attach-organizations-to-target-profile', function () { beforeEach(function () { diff --git a/api/tests/integration/domain/usecases/begin-campaign-participation-improvement_test.js b/api/tests/integration/domain/usecases/begin-campaign-participation-improvement_test.js index 6f02efb7f07..8093b594847 100644 --- a/api/tests/integration/domain/usecases/begin-campaign-participation-improvement_test.js +++ b/api/tests/integration/domain/usecases/begin-campaign-participation-improvement_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const beginCampaignParticipationImprovement = require('../../../../lib/domain/usecases/begin-campaign-participation-improvement'); -const assessmentRepository = require('../../../../lib/infrastructure/repositories/assessment-repository'); -const campaignParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-repository'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { beginCampaignParticipationImprovement } from '../../../../lib/domain/usecases/begin-campaign-participation-improvement.js'; +import * as assessmentRepository from '../../../../lib/infrastructure/repositories/assessment-repository.js'; +import * as campaignParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-participation-repository.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED, TO_SHARE } = CampaignParticipationStatuses; diff --git a/api/tests/integration/domain/usecases/cancel-certification-center-invitation_test.js b/api/tests/integration/domain/usecases/cancel-certification-center-invitation_test.js index 3baa2c78f50..2a006b69e6d 100644 --- a/api/tests/integration/domain/usecases/cancel-certification-center-invitation_test.js +++ b/api/tests/integration/domain/usecases/cancel-certification-center-invitation_test.js @@ -1,11 +1,9 @@ -const { catchErr, databaseBuilder, expect } = require('../../../test-helper'); -const sinon = require('sinon'); +import { catchErr, databaseBuilder, expect } from '../../../test-helper.js'; +import sinon from 'sinon'; -const useCases = require('../../../../lib/domain/usecases/index.js'); - -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); - -const { NotFoundError, UncancellableCertificationCenterInvitationError } = require('../../../../lib/domain/errors'); +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; +import { NotFoundError, UncancellableCertificationCenterInvitationError } from '../../../../lib/domain/errors.js'; describe('Integration | UseCases | cancel-certification-center-invitation', function () { describe('when the invitation exists', function () { @@ -42,7 +40,7 @@ describe('Integration | UseCases | cancel-certification-center-invitation', func await databaseBuilder.commit(); // when - const result = await useCases.cancelCertificationCenterInvitation({ + const result = await usecases.cancelCertificationCenterInvitation({ certificationCenterInvitationId: certificationCenterInvitation.id, }); @@ -73,7 +71,7 @@ describe('Integration | UseCases | cancel-certification-center-invitation', func await databaseBuilder.commit(); // when - const error = await catchErr(useCases.cancelCertificationCenterInvitation)({ + const error = await catchErr(usecases.cancelCertificationCenterInvitation)({ certificationCenterInvitationId: acceptedInvitation.id, }); @@ -90,7 +88,7 @@ describe('Integration | UseCases | cancel-certification-center-invitation', func const certificationCenterInvitationId = 123; // when - const error = await catchErr(useCases.cancelCertificationCenterInvitation)({ + const error = await catchErr(usecases.cancelCertificationCenterInvitation)({ certificationCenterInvitationId, }); diff --git a/api/tests/integration/domain/usecases/complete-assessment_test.js b/api/tests/integration/domain/usecases/complete-assessment_test.js index 23431bd27c9..0eec0592619 100644 --- a/api/tests/integration/domain/usecases/complete-assessment_test.js +++ b/api/tests/integration/domain/usecases/complete-assessment_test.js @@ -1,10 +1,12 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const completeAssessment = require('../../../../lib/domain/usecases/complete-assessment'); -const assessmentRepository = require('../../../../lib/infrastructure/repositories/assessment-repository'); -const campaignParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-repository'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const { TO_SHARE, STARTED } = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { completeAssessment } from '../../../../lib/domain/usecases/complete-assessment.js'; +import * as assessmentRepository from '../../../../lib/infrastructure/repositories/assessment-repository.js'; +import * as campaignParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-participation-repository.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; + +const { TO_SHARE, STARTED } = CampaignParticipationStatuses; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Integration | Usecase | Complete Assessment', function () { let userId, assessmentId, campaignParticipationId; diff --git a/api/tests/integration/domain/usecases/create-and-reconcile-user-to-organization-learner_test.js b/api/tests/integration/domain/usecases/create-and-reconcile-user-to-organization-learner_test.js index ef3c07ed69b..ebc71164ae6 100644 --- a/api/tests/integration/domain/usecases/create-and-reconcile-user-to-organization-learner_test.js +++ b/api/tests/integration/domain/usecases/create-and-reconcile-user-to-organization-learner_test.js @@ -1,29 +1,28 @@ -const pick = require('lodash/pick'); - -const { catchErr, databaseBuilder, expect, knex } = require('../../../test-helper'); - -const authenticationMethodRepository = require('../../../../lib/infrastructure/repositories/authentication-method-repository'); -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const organizationLearnerRepository = require('../../../../lib/infrastructure/repositories/organization-learner-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); -const userToCreateRepository = require('../../../../lib/infrastructure/repositories/user-to-create-repository'); - -const encryptionService = require('../../../../lib/domain/services/encryption-service'); -const mailService = require('../../../../lib/domain/services/mail-service'); -const obfuscationService = require('../../../../lib/domain/services/obfuscation-service'); -const userReconciliationService = require('../../../../lib/domain/services/user-reconciliation-service'); -const userService = require('../../../../lib/domain/services/user-service'); -const createAndReconcileUserToOrganizationLearner = require('../../../../lib/domain/usecases/create-and-reconcile-user-to-organization-learner'); - -const passwordValidator = require('../../../../lib/domain/validators/password-validator'); -const userValidator = require('../../../../lib/domain/validators/user-validator'); - -const { +import lodash from 'lodash'; +const { pick } = lodash; + +import { catchErr, databaseBuilder, expect, knex } from '../../../test-helper.js'; + +import * as authenticationMethodRepository from '../../../../lib/infrastructure/repositories/authentication-method-repository.js'; +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import * as organizationLearnerRepository from '../../../../lib/infrastructure/repositories/organization-learner-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; +import * as userToCreateRepository from '../../../../lib/infrastructure/repositories/user-to-create-repository.js'; +import * as encryptionService from '../../../../lib/domain/services/encryption-service.js'; +import * as mailService from '../../../../lib/domain/services/mail-service.js'; +import * as obfuscationService from '../../../../lib/domain/services/obfuscation-service.js'; +import * as userReconciliationService from '../../../../lib/domain/services/user-reconciliation-service.js'; +import * as userService from '../../../../lib/domain/services/user-service.js'; +import { createAndReconcileUserToOrganizationLearner } from '../../../../lib/domain/usecases/create-and-reconcile-user-to-organization-learner.js'; +import * as passwordValidator from '../../../../lib/domain/validators/password-validator.js'; +import * as userValidator from '../../../../lib/domain/validators/user-validator.js'; + +import { CampaignCodeError, EntityValidationError, NotFoundError, OrganizationLearnerAlreadyLinkedToUserError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Integration | UseCases | create-and-reconcile-user-to-organization-learner', function () { const pickUserAttributes = ['firstName', 'lastName', 'email', 'username', 'cgu']; diff --git a/api/tests/integration/domain/usecases/create-badge_test.js b/api/tests/integration/domain/usecases/create-badge_test.js index f36cf5021d0..e64e8e727bf 100644 --- a/api/tests/integration/domain/usecases/create-badge_test.js +++ b/api/tests/integration/domain/usecases/create-badge_test.js @@ -1,19 +1,20 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { expect, databaseBuilder, mockLearningContent, knex, catchErr, sinon } = require('../../../test-helper'); +import { expect, databaseBuilder, mockLearningContent, knex, catchErr, sinon } from '../../../test-helper.js'; -const badgeRepository = require('../../../../lib/infrastructure/repositories/badge-repository'); -const badgeCriteriaRepository = require('../../../../lib/infrastructure/repositories/badge-criteria-repository'); -const skillSetRepository = require('../../../../lib/infrastructure/repositories/skill-set-repository'); -const targetProfileRepository = require('../../../../lib/infrastructure/repositories/target-profile-repository'); -const createBadge = require('../../../../lib/domain/usecases/create-badge'); -const Badge = require('../../../../lib/domain/models/Badge'); -const { +import * as badgeRepository from '../../../../lib/infrastructure/repositories/badge-repository.js'; +import * as badgeCriteriaRepository from '../../../../lib/infrastructure/repositories/badge-criteria-repository.js'; +import * as skillSetRepository from '../../../../lib/infrastructure/repositories/skill-set-repository.js'; +import * as targetProfileRepository from '../../../../lib/infrastructure/repositories/target-profile-repository.js'; +import { createBadge } from '../../../../lib/domain/usecases/create-badge.js'; +import { Badge } from '../../../../lib/domain/models/Badge.js'; + +import { AlreadyExistingEntityError, NotFoundError, InvalidSkillSetError, MissingBadgeCriterionError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Integration | UseCases | create-badge', function () { let targetProfileId; diff --git a/api/tests/integration/domain/usecases/create-campaign_test.js b/api/tests/integration/domain/usecases/create-campaign_test.js index 122f1fbb8ac..bd2846138d1 100644 --- a/api/tests/integration/domain/usecases/create-campaign_test.js +++ b/api/tests/integration/domain/usecases/create-campaign_test.js @@ -1,15 +1,13 @@ -const { expect, databaseBuilder, mockLearningContent, knex } = require('../../../test-helper'); -const _ = require('lodash'); +import { expect, databaseBuilder, mockLearningContent, knex } from '../../../test-helper.js'; +import _ from 'lodash'; -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const campaignCreatorRepository = require('../../../../lib/infrastructure/repositories/campaign-creator-repository'); +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import * as campaignCreatorRepository from '../../../../lib/infrastructure/repositories/campaign-creator-repository.js'; -const createCampaign = require('../../../../lib/domain/usecases/create-campaign'); - -const Campaign = require('../../../../lib/domain/models/Campaign'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); - -const campaignCodeGenerator = require('../../../../lib/domain/services/campaigns/campaign-code-generator'); +import { createCampaign } from '../../../../lib/domain/usecases/create-campaign.js'; +import { Campaign } from '../../../../lib/domain/models/Campaign.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import * as campaignCodeGenerator from '../../../../lib/domain/services/campaigns/campaign-code-generator.js'; describe('Integration | UseCases | create-campaign', function () { let userId; diff --git a/api/tests/integration/domain/usecases/create-certification-center-membership-by-email_test.js b/api/tests/integration/domain/usecases/create-certification-center-membership-by-email_test.js index 8fc597ee43c..fd33857ecbe 100644 --- a/api/tests/integration/domain/usecases/create-certification-center-membership-by-email_test.js +++ b/api/tests/integration/domain/usecases/create-certification-center-membership-by-email_test.js @@ -1,13 +1,11 @@ -const { catchErr, databaseBuilder, expect, knex } = require('../../../test-helper'); +import { catchErr, databaseBuilder, expect, knex } from '../../../test-helper.js'; +import { UserNotFoundError, AlreadyExistingEntityError } from '../../../../lib/domain/errors.js'; +import { CertificationCenterMembership } from '../../../../lib/domain/models/CertificationCenterMembership.js'; -const { UserNotFoundError, AlreadyExistingEntityError } = require('../../../../lib/domain/errors'); +import * as certificationCenterMembershipRepository from '../../../../lib/infrastructure/repositories/certification-center-membership-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; -const CertificationCenterMembership = require('../../../../lib/domain/models/CertificationCenterMembership'); - -const certificationCenterMembershipRepository = require('../../../../lib/infrastructure/repositories/certification-center-membership-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); - -const createCertificationCenterMembershipByEmail = require('../../../../lib/domain/usecases/create-certification-center-membership-by-email'); +import { createCertificationCenterMembershipByEmail } from '../../../../lib/domain/usecases/create-certification-center-membership-by-email.js'; describe('Integration | UseCases | create-certification-center-membership-by-email', function () { let certificationCenterId; diff --git a/api/tests/integration/domain/usecases/create-certification-center-membership-for-sco-organization-member_test.js b/api/tests/integration/domain/usecases/create-certification-center-membership-for-sco-organization-member_test.js index 3bca1d42d01..8c008e030b5 100644 --- a/api/tests/integration/domain/usecases/create-certification-center-membership-for-sco-organization-member_test.js +++ b/api/tests/integration/domain/usecases/create-certification-center-membership-for-sco-organization-member_test.js @@ -1,12 +1,11 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; -const membershipRepository = require('../../../../lib/infrastructure/repositories/membership-repository'); -const certificationCenterRepository = require('../../../../lib/infrastructure/repositories/certification-center-repository'); -const certificationCenterMembershipRepository = require('../../../../lib/infrastructure/repositories/certification-center-membership-repository'); +import * as membershipRepository from '../../../../lib/infrastructure/repositories/membership-repository.js'; +import * as certificationCenterRepository from '../../../../lib/infrastructure/repositories/certification-center-repository.js'; +import * as certificationCenterMembershipRepository from '../../../../lib/infrastructure/repositories/certification-center-membership-repository.js'; -const Membership = require('../../../../lib/domain/models/Membership'); - -const createCertificationCenterMembershipForScoOrganizationMember = require('../../../../lib/domain/usecases/create-certification-center-membership-for-sco-organization-member'); +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { createCertificationCenterMembershipForScoOrganizationMember } from '../../../../lib/domain/usecases/create-certification-center-membership-for-sco-organization-member.js'; describe('Integration | UseCases | create-certification-center-membership-for-sco-organization-member', function () { afterEach(function () { diff --git a/api/tests/integration/domain/usecases/create-or-update-certification-center-invitation-for-admin_test.js b/api/tests/integration/domain/usecases/create-or-update-certification-center-invitation-for-admin_test.js index 117f235900a..5ecdd2e9f0a 100644 --- a/api/tests/integration/domain/usecases/create-or-update-certification-center-invitation-for-admin_test.js +++ b/api/tests/integration/domain/usecases/create-or-update-certification-center-invitation-for-admin_test.js @@ -1,9 +1,9 @@ -const { expect, databaseBuilder, knex, sinon, catchErr } = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); -const mailService = require('../../../../lib/domain/services/mail-service'); -const { SendingEmailError, SendingEmailToInvalidDomainError } = require('../../../../lib/domain/errors'); -const EmailingAttempt = require('../../../../lib/domain/models/EmailingAttempt'); +import { expect, databaseBuilder, knex, sinon, catchErr } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; +import { mailService } from '../../../../lib/domain/services/mail-service.js'; +import { SendingEmailError, SendingEmailToInvalidDomainError } from '../../../../lib/domain/errors.js'; +import { EmailingAttempt } from '../../../../lib/domain/models/EmailingAttempt.js'; describe('Integration | UseCase | create-or-update-certification-center-invitation-for-admin', function () { let clock; @@ -39,7 +39,7 @@ describe('Integration | UseCase | create-or-update-certification-center-invitati await databaseBuilder.commit(); // when - const result = await useCases.createOrUpdateCertificationCenterInvitationForAdmin({ + const result = await usecases.createOrUpdateCertificationCenterInvitationForAdmin({ email, certificationCenterId, mailService, @@ -81,7 +81,7 @@ describe('Integration | UseCase | create-or-update-certification-center-invitati await databaseBuilder.commit(); // when - const result = await useCases.createOrUpdateCertificationCenterInvitationForAdmin({ + const result = await usecases.createOrUpdateCertificationCenterInvitationForAdmin({ email, certificationCenterId, mailService, @@ -116,7 +116,7 @@ describe('Integration | UseCase | create-or-update-certification-center-invitati await databaseBuilder.commit(); // when - await useCases.createOrUpdateCertificationCenterInvitationForAdmin({ + await usecases.createOrUpdateCertificationCenterInvitationForAdmin({ email, locale: 'en', certificationCenterId, @@ -150,7 +150,7 @@ describe('Integration | UseCase | create-or-update-certification-center-invitati mailService.sendCertificationCenterInvitationEmail.resolves(mailerResponse); // when - const result = await catchErr(useCases.createOrUpdateCertificationCenterInvitationForAdmin)({ + const result = await catchErr(usecases.createOrUpdateCertificationCenterInvitationForAdmin)({ email, locale: 'fr', certificationCenterId, @@ -177,7 +177,7 @@ describe('Integration | UseCase | create-or-update-certification-center-invitati mailService.sendCertificationCenterInvitationEmail.resolves(emailAttemptFailure); // when - const error = await catchErr(useCases.createOrUpdateCertificationCenterInvitationForAdmin)({ + const error = await catchErr(usecases.createOrUpdateCertificationCenterInvitationForAdmin)({ email, locale: 'fr', certificationCenterId, diff --git a/api/tests/integration/domain/usecases/create-organization_test.js b/api/tests/integration/domain/usecases/create-organization_test.js index 870a7be4919..6beab0e51fe 100644 --- a/api/tests/integration/domain/usecases/create-organization_test.js +++ b/api/tests/integration/domain/usecases/create-organization_test.js @@ -1,11 +1,10 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; -const organizationForAdminRepository = require('../../../../lib/infrastructure/repositories/organization-for-admin-repository'); -const dataProtectionOfficerRepository = require('../../../../lib/infrastructure/repositories/data-protection-officer-repository'); -const organizationCreationValidator = require('../../../../lib/domain/validators/organization-creation-validator.js'); -const OrganizationForAdmin = require('../../../../lib/domain/models/organizations-administration/Organization'); - -const createOrganization = require('../../../../lib/domain/usecases/create-organization'); +import * as organizationForAdminRepository from '../../../../lib/infrastructure/repositories/organization-for-admin-repository.js'; +import * as dataProtectionOfficerRepository from '../../../../lib/infrastructure/repositories/data-protection-officer-repository.js'; +import { OrganizationForAdmin } from '../../../../lib/domain/models/organizations-administration/Organization.js'; +import * as organizationCreationValidator from '../../../../lib/domain/validators/organization-creation-validator.js'; +import { createOrganization } from '../../../../lib/domain/usecases/create-organization.js'; describe('Integration | UseCases | create-organization', function () { afterEach(async function () { diff --git a/api/tests/integration/domain/usecases/create-organizations-with-tags-and-target-profiles_test.js b/api/tests/integration/domain/usecases/create-organizations-with-tags-and-target-profiles_test.js index 6d5afdc36c9..6d2d62c9f85 100644 --- a/api/tests/integration/domain/usecases/create-organizations-with-tags-and-target-profiles_test.js +++ b/api/tests/integration/domain/usecases/create-organizations-with-tags-and-target-profiles_test.js @@ -1,25 +1,29 @@ -const { catchErr, expect, databaseBuilder, knex } = require('../../../test-helper'); -const { omit } = require('lodash'); - -const domainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const organizationInvitationRepository = require('../../../../lib/infrastructure/repositories/organization-invitation-repository'); -const organizationRepository = require('../../../../lib/infrastructure/repositories/organization-repository'); -const organizationTagRepository = require('../../../../lib/infrastructure/repositories/organization-tag-repository'); -const targetProfileShareRepository = require('../../../../lib/infrastructure/repositories/target-profile-share-repository'); -const dataProtectionOfficerRepository = require('../../../../lib/infrastructure/repositories/data-protection-officer-repository'); -const tagRepository = require('../../../../lib/infrastructure/repositories/tag-repository'); -const organizationValidator = require('../../../../lib/domain/validators/organization-with-tags-and-target-profiles-script.js'); -const organizationInvitationService = require('../../../../lib/domain/services/organization-invitation-service.js'); -const { +import { catchErr, expect, databaseBuilder, knex } from '../../../test-helper.js'; +import lodash from 'lodash'; + +const { omit } = lodash; + +import { DomainTransaction as domainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import * as organizationInvitationRepository from '../../../../lib/infrastructure/repositories/organization-invitation-repository.js'; +import * as organizationRepository from '../../../../lib/infrastructure/repositories/organization-repository.js'; +import * as organizationTagRepository from '../../../../lib/infrastructure/repositories/organization-tag-repository.js'; +import * as targetProfileShareRepository from '../../../../lib/infrastructure/repositories/target-profile-share-repository.js'; +import * as dataProtectionOfficerRepository from '../../../../lib/infrastructure/repositories/data-protection-officer-repository.js'; +import * as tagRepository from '../../../../lib/infrastructure/repositories/tag-repository.js'; +import * as organizationValidator from '../../../../lib/domain/validators/organization-with-tags-and-target-profiles-script.js'; +import * as organizationInvitationService from '../../../../lib/domain/services/organization-invitation-service.js'; + +import { OrganizationTagNotFound, ManyOrganizationsFoundError, OrganizationAlreadyExistError, EntityValidationError, ObjectValidationError, TargetProfileInvalidError, -} = require('../../../../lib/domain/errors'); -const createOrganizationsWithTagsAndTargetProfiles = require('../../../../lib/domain/usecases/create-organizations-with-tags-and-target-profiles'); -const Membership = require('../../../../lib/domain/models/Membership'); +} from '../../../../lib/domain/errors.js'; + +import { createOrganizationsWithTagsAndTargetProfiles } from '../../../../lib/domain/usecases/create-organizations-with-tags-and-target-profiles.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; describe('Integration | UseCases | create-organizations-with-tags-and-target-profiles', function () { let userId; diff --git a/api/tests/integration/domain/usecases/create-password-reset-demand_test.js b/api/tests/integration/domain/usecases/create-password-reset-demand_test.js index 9fd47281cf8..c6bf2946bac 100644 --- a/api/tests/integration/domain/usecases/create-password-reset-demand_test.js +++ b/api/tests/integration/domain/usecases/create-password-reset-demand_test.js @@ -1,13 +1,12 @@ -const { catchErr, databaseBuilder, expect, knex } = require('../../../test-helper'); +import { catchErr, databaseBuilder, expect, knex } from '../../../test-helper.js'; -const mailService = require('../../../../lib/domain/services/mail-service'); -const resetPasswordService = require('../../../../lib/domain/services/reset-password-service'); -const resetPasswordDemandRepository = require('../../../../lib/infrastructure/repositories/reset-password-demands-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); +import * as mailService from '../../../../lib/domain/services/mail-service.js'; +import * as resetPasswordService from '../../../../lib/domain/services/reset-password-service.js'; +import * as resetPasswordDemandRepository from '../../../../lib/infrastructure/repositories/reset-password-demands-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; -const { UserNotFoundError } = require('../../../../lib/domain/errors'); - -const createPasswordResetDemand = require('../../../../lib/domain/usecases/create-password-reset-demand'); +import { UserNotFoundError } from '../../../../lib/domain/errors.js'; +import { createPasswordResetDemand } from '../../../../lib/domain/usecases/create-password-reset-demand.js'; describe('Integration | UseCases | create-password-reset-demand', function () { const email = 'user@example.net'; diff --git a/api/tests/integration/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user_test.js b/api/tests/integration/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user_test.js index 0d3a2ef4130..5f078f4469a 100644 --- a/api/tests/integration/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user_test.js +++ b/api/tests/integration/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user_test.js @@ -1,27 +1,26 @@ -const { catchErr, databaseBuilder, expect, knex } = require('../../../test-helper'); - -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const organizationLearnerRepository = require('../../../../lib/infrastructure/repositories/organization-learner-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); -const userToCreateRepository = require('../../../../lib/infrastructure/repositories/user-to-create-repository'); -const studentRepository = require('../../../../lib/infrastructure/repositories/student-repository'); -const authenticationMethodRepository = require('../../../../lib/infrastructure/repositories/authentication-method-repository'); - -const obfuscationService = require('../../../../lib/domain/services/obfuscation-service'); -const tokenService = require('../../../../lib/domain/services/token-service'); -const userReconciliationService = require('../../../../lib/domain/services/user-reconciliation-service'); -const userService = require('../../../../lib/domain/services/user-service'); - -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); - -const { +import { catchErr, databaseBuilder, expect, knex } from '../../../test-helper.js'; + +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import * as organizationLearnerRepository from '../../../../lib/infrastructure/repositories/organization-learner-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; +import * as userToCreateRepository from '../../../../lib/infrastructure/repositories/user-to-create-repository.js'; +import * as studentRepository from '../../../../lib/infrastructure/repositories/student-repository.js'; +import * as authenticationMethodRepository from '../../../../lib/infrastructure/repositories/authentication-method-repository.js'; +import * as obfuscationService from '../../../../lib/domain/services/obfuscation-service.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import * as userReconciliationService from '../../../../lib/domain/services/user-reconciliation-service.js'; +import * as userService from '../../../../lib/domain/services/user-service.js'; + +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; + +import { CampaignCodeError, NotFoundError, ObjectValidationError, OrganizationLearnerAlreadyLinkedToUserError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; -const createUserAndReconcileToOrganizationLearnerByExternalUser = require('../../../../lib/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user'); +import { createUserAndReconcileToOrganizationLearnerFromExternalUser as createUserAndReconcileToOrganizationLearnerByExternalUser } from '../../../../lib/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user.js'; describe('Integration | UseCases | create-user-and-reconcile-to-organization-learner-from-external-user', function () { context('When there is no campaign with the given code', function () { diff --git a/api/tests/integration/domain/usecases/delete-campaign-participation-for-admin_test.js b/api/tests/integration/domain/usecases/delete-campaign-participation-for-admin_test.js index 75be05e0d54..7c87a295852 100644 --- a/api/tests/integration/domain/usecases/delete-campaign-participation-for-admin_test.js +++ b/api/tests/integration/domain/usecases/delete-campaign-participation-for-admin_test.js @@ -1,9 +1,9 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const campaignParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-repository'); -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import * as campaignParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-participation-repository.js'; +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; -const deleteCampaignParticipationForAdmin = require('../../../../lib/domain/usecases/delete-campaign-participation-for-admin'); +import { deleteCampaignParticipationForAdmin } from '../../../../lib/domain/usecases/delete-campaign-participation-for-admin.js'; describe('Integration | UseCases | delete-campaign-participation-for-admin', function () { it('should delete all campaignParticipations', async function () { diff --git a/api/tests/integration/domain/usecases/delete-campaign-participation_test.js b/api/tests/integration/domain/usecases/delete-campaign-participation_test.js index 6efbacf0b44..ce2e2990cb1 100644 --- a/api/tests/integration/domain/usecases/delete-campaign-participation_test.js +++ b/api/tests/integration/domain/usecases/delete-campaign-participation_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const campaignParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-repository'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import * as campaignParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-participation-repository.js'; -const deleteCampaignParticipation = require('../../../../lib/domain/usecases/delete-campaign-participation'); +import { deleteCampaignParticipation } from '../../../../lib/domain/usecases/delete-campaign-participation.js'; describe('Integration | UseCases | delete-campaign-participation', function () { it('should delete all campaignParticipations', async function () { diff --git a/api/tests/integration/domain/usecases/find-assessment-participation-result-list_test.js b/api/tests/integration/domain/usecases/find-assessment-participation-result-list_test.js index 3dbf62c27a7..5255088316c 100644 --- a/api/tests/integration/domain/usecases/find-assessment-participation-result-list_test.js +++ b/api/tests/integration/domain/usecases/find-assessment-participation-result-list_test.js @@ -1,5 +1,5 @@ -const { expect, mockLearningContent, databaseBuilder } = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); +import { expect, mockLearningContent, databaseBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Integration | UseCase | find-assessment-participation-result-list', function () { let organizationId; @@ -28,7 +28,7 @@ describe('Integration | UseCase | find-assessment-participation-result-list', fu context('when there are filters', function () { it('returns the assessmentParticipationResultMinimal list filtered by the search', async function () { - const { participations } = await useCases.findAssessmentParticipationResultList({ + const { participations } = await usecases.findAssessmentParticipationResultList({ campaignId, filters: { search: 'Tonari N' }, page, diff --git a/api/tests/integration/domain/usecases/find-campaign-profiles-collection-participation-summaries_test.js b/api/tests/integration/domain/usecases/find-campaign-profiles-collection-participation-summaries_test.js index 987128902c8..e29a8b0126d 100644 --- a/api/tests/integration/domain/usecases/find-campaign-profiles-collection-participation-summaries_test.js +++ b/api/tests/integration/domain/usecases/find-campaign-profiles-collection-participation-summaries_test.js @@ -1,5 +1,5 @@ -const { expect, mockLearningContent, databaseBuilder } = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); +import { expect, mockLearningContent, databaseBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Integration | UseCase | find-campaign-profiles-collection-participation-summaries', function () { let organizationId; @@ -33,7 +33,7 @@ describe('Integration | UseCase | find-campaign-profiles-collection-participatio await databaseBuilder.commit(); }); it('returns the list filtered by the search', async function () { - const { data } = await useCases.findCampaignProfilesCollectionParticipationSummaries({ + const { data } = await usecases.findCampaignProfilesCollectionParticipationSummaries({ userId, campaignId, filters: { search: 'Tonari N' }, diff --git a/api/tests/integration/domain/usecases/find-certification-center-memberships-by-certification-center_test.js b/api/tests/integration/domain/usecases/find-certification-center-memberships-by-certification-center_test.js index 04032fdf4b7..50bc6993f38 100644 --- a/api/tests/integration/domain/usecases/find-certification-center-memberships-by-certification-center_test.js +++ b/api/tests/integration/domain/usecases/find-certification-center-memberships-by-certification-center_test.js @@ -1,9 +1,10 @@ -const { databaseBuilder, expect } = require('../../../test-helper'); +import { databaseBuilder, expect } from '../../../test-helper.js'; -const certificationCenterMembershipRepository = require('../../../../lib/infrastructure/repositories/certification-center-membership-repository'); -const CertificationCenterMembership = require('../../../../lib/domain/models/CertificationCenterMembership'); +import * as certificationCenterMembershipRepository from '../../../../lib/infrastructure/repositories/certification-center-membership-repository.js'; +import { CertificationCenterMembership } from '../../../../lib/domain/models/CertificationCenterMembership.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; -const { findCertificationCenterMembershipsByCertificationCenter } = require('../../../../lib/domain/usecases/index'); +const { findCertificationCenterMembershipsByCertificationCenter } = usecases; describe('Integration | UseCase | find-certification-center-memberships-by-certification-center', function () { it('should return certification center memberships', async function () { diff --git a/api/tests/integration/domain/usecases/find-paginated-campaign-participant-activities_test.js b/api/tests/integration/domain/usecases/find-paginated-campaign-participant-activities_test.js index 9bbb64849c7..27ed9a765d6 100644 --- a/api/tests/integration/domain/usecases/find-paginated-campaign-participant-activities_test.js +++ b/api/tests/integration/domain/usecases/find-paginated-campaign-participant-activities_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr, databaseBuilder } = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); +import { expect, catchErr, databaseBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; describe('Integration | UseCase | find-paginated-campaign-participants-activities', function () { let organizationId; @@ -17,7 +17,7 @@ describe('Integration | UseCase | find-paginated-campaign-participants-activitie context('when requesting user is not allowed to access campaign informations', function () { it('should throw a UserNotAuthorizedToAccessEntityError error', async function () { // when - const error = await catchErr(useCases.findPaginatedCampaignParticipantsActivities)({ + const error = await catchErr(usecases.findPaginatedCampaignParticipantsActivities)({ userId, campaignId, }); @@ -39,7 +39,7 @@ describe('Integration | UseCase | find-paginated-campaign-participants-activitie }); it('returns the campaignParticipantsActivites of the participants of the campaign', async function () { - const { campaignParticipantsActivities } = await useCases.findPaginatedCampaignParticipantsActivities({ + const { campaignParticipantsActivities } = await usecases.findPaginatedCampaignParticipantsActivities({ userId, campaignId, page, @@ -65,7 +65,7 @@ describe('Integration | UseCase | find-paginated-campaign-participants-activitie }); it('returns the campaignParticipantsActivities for the participants for the division', async function () { - const { campaignParticipantsActivities } = await useCases.findPaginatedCampaignParticipantsActivities({ + const { campaignParticipantsActivities } = await usecases.findPaginatedCampaignParticipantsActivities({ userId, campaignId, filters: { divisions: ['6eme'] }, @@ -75,7 +75,7 @@ describe('Integration | UseCase | find-paginated-campaign-participants-activitie }); it('returns the campaignParticipantsActivities filtered by the search', async function () { - const { campaignParticipantsActivities } = await useCases.findPaginatedCampaignParticipantsActivities({ + const { campaignParticipantsActivities } = await usecases.findPaginatedCampaignParticipantsActivities({ userId, campaignId, filters: { search: 'Tonari N' }, diff --git a/api/tests/integration/domain/usecases/find-pending-certification-center-invitations_test.js b/api/tests/integration/domain/usecases/find-pending-certification-center-invitations_test.js index ac3d0870b86..d1309984cd5 100644 --- a/api/tests/integration/domain/usecases/find-pending-certification-center-invitations_test.js +++ b/api/tests/integration/domain/usecases/find-pending-certification-center-invitations_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; describe('Integration | UseCase | find-pending-certification-center-invitations', function () { it('should find only pending certification center invitations for a given certification center', async function () { @@ -33,7 +33,7 @@ describe('Integration | UseCase | find-pending-certification-center-invitations' await databaseBuilder.commit(); // when - const certificationCenterInvitations = await useCases.findPendingCertificationCenterInvitations({ + const certificationCenterInvitations = await usecases.findPendingCertificationCenterInvitations({ certificationCenterId, }); @@ -88,7 +88,7 @@ describe('Integration | UseCase | find-pending-certification-center-invitations' await databaseBuilder.commit(); // when - const certificationCenterInvitations = await useCases.findPendingCertificationCenterInvitations({ + const certificationCenterInvitations = await usecases.findPendingCertificationCenterInvitations({ certificationCenterId, }); @@ -107,7 +107,7 @@ describe('Integration | UseCase | find-pending-certification-center-invitations' await databaseBuilder.commit(); // when - const certificationCenterInvitations = await useCases.findPendingCertificationCenterInvitations({ + const certificationCenterInvitations = await usecases.findPendingCertificationCenterInvitations({ certificationCenterId, }); diff --git a/api/tests/integration/domain/usecases/get-attendance-sheet/get-attendance-sheet_test.js b/api/tests/integration/domain/usecases/get-attendance-sheet/get-attendance-sheet_test.js index 5486b46cfcc..ae8c29b7769 100644 --- a/api/tests/integration/domain/usecases/get-attendance-sheet/get-attendance-sheet_test.js +++ b/api/tests/integration/domain/usecases/get-attendance-sheet/get-attendance-sheet_test.js @@ -1,12 +1,19 @@ -const { unlink, writeFile } = require('fs').promises; -const _ = require('lodash'); -const { expect, databaseBuilder } = require('../../../../test-helper'); -const readOdsUtils = require('../../../../../lib/infrastructure/utils/ods/read-ods-utils'); -const writeOdsUtils = require('../../../../../lib/infrastructure/utils/ods/write-ods-utils'); -const sessionXmlService = require('../../../../../lib/domain/services/session-xml-service'); -const sessionRepository = require('../../../../../lib/infrastructure/repositories/sessions/session-repository'); -const sessionForAttendanceSheetRepository = require('../../../../../lib/infrastructure/repositories/sessions/session-for-attendance-sheet-repository'); -const getAttendanceSheet = require('../../../../../lib/domain/usecases/get-attendance-sheet'); +import fs from 'fs'; + +const { promises } = fs; + +const { unlink, writeFile } = promises; + +import _ from 'lodash'; +import { expect, databaseBuilder } from '../../../../test-helper.js'; +import * as writeOdsUtils from '../../../../../lib/infrastructure/utils/ods/write-ods-utils.js'; +import * as sessionXmlService from '../../../../../lib/domain/services/session-xml-service.js'; +import * as readOdsUtils from '../../../../../lib/infrastructure/utils/ods/read-ods-utils.js'; +import * as sessionRepository from '../../../../../lib/infrastructure/repositories/sessions/session-repository.js'; +import * as sessionForAttendanceSheetRepository from '../../../../../lib/infrastructure/repositories/sessions/session-for-attendance-sheet-repository.js'; +import { getAttendanceSheet } from '../../../../../lib/domain/usecases/get-attendance-sheet.js'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | UseCases | getAttendanceSheet', function () { describe('when certification center is not sco', function () { diff --git a/api/tests/integration/domain/usecases/get-campaign-participations-activity-by-day_test.js b/api/tests/integration/domain/usecases/get-campaign-participations-activity-by-day_test.js index 08b6193ab60..f56631bbaf5 100644 --- a/api/tests/integration/domain/usecases/get-campaign-participations-activity-by-day_test.js +++ b/api/tests/integration/domain/usecases/get-campaign-participations-activity-by-day_test.js @@ -1,7 +1,7 @@ -const { expect, catchErr, databaseBuilder } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, catchErr, databaseBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/domain/usecases/get-campaign-participations-counts-by-stage_test.js b/api/tests/integration/domain/usecases/get-campaign-participations-counts-by-stage_test.js index f66cd2cf228..656796b4c93 100644 --- a/api/tests/integration/domain/usecases/get-campaign-participations-counts-by-stage_test.js +++ b/api/tests/integration/domain/usecases/get-campaign-participations-counts-by-stage_test.js @@ -1,12 +1,13 @@ -const { +import { expect, catchErr, databaseBuilder, learningContentBuilder, mockLearningContent, -} = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const { UserNotAuthorizedToAccessEntityError, NoStagesForCampaign } = require('../../../../lib/domain/errors'); +} from '../../../test-helper.js'; + +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToAccessEntityError, NoStagesForCampaign } from '../../../../lib/domain/errors.js'; describe('Integration | UseCase | get-campaign-participations-counts-by-stage', function () { let organizationId; @@ -15,7 +16,7 @@ describe('Integration | UseCase | get-campaign-participations-counts-by-stage', let stage1, stage2, stage3; beforeEach(async function () { - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContentObjects = learningContentBuilder.fromAreas([ { id: 'recArea1', title_i18n: { diff --git a/api/tests/integration/domain/usecases/get-campaign-participations-counts-by-status_test.js b/api/tests/integration/domain/usecases/get-campaign-participations-counts-by-status_test.js index 84d46797d08..cfb2c060eb5 100644 --- a/api/tests/integration/domain/usecases/get-campaign-participations-counts-by-status_test.js +++ b/api/tests/integration/domain/usecases/get-campaign-participations-counts-by-status_test.js @@ -1,7 +1,7 @@ -const { expect, catchErr, databaseBuilder } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, catchErr, databaseBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED, TO_SHARE } = CampaignParticipationStatuses; diff --git a/api/tests/integration/domain/usecases/get-campaign-profile_test.js b/api/tests/integration/domain/usecases/get-campaign-profile_test.js index 20e2be94214..ce3a8a5a19d 100644 --- a/api/tests/integration/domain/usecases/get-campaign-profile_test.js +++ b/api/tests/integration/domain/usecases/get-campaign-profile_test.js @@ -1,6 +1,8 @@ -const { expect, databaseBuilder, mockLearningContent } = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { expect, databaseBuilder, mockLearningContent } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_SPOKEN } = LOCALE; describe('Integration | UseCase | get-campaign-profile', function () { const locale = FRENCH_SPOKEN; @@ -21,7 +23,7 @@ describe('Integration | UseCase | get-campaign-profile', function () { await databaseBuilder.commit(); // when - const profile = await useCases.getCampaignProfile({ + const profile = await usecases.getCampaignProfile({ userId, campaignId, campaignParticipationId, diff --git a/api/tests/integration/domain/usecases/get-campaign_test.js b/api/tests/integration/domain/usecases/get-campaign_test.js index 36d2e40c33c..ee4512f596b 100644 --- a/api/tests/integration/domain/usecases/get-campaign_test.js +++ b/api/tests/integration/domain/usecases/get-campaign_test.js @@ -1,10 +1,9 @@ -const { expect, databaseBuilder, catchErr, mockLearningContent } = require('../../../test-helper'); -const { NotFoundError, UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); - -const getCampaign = require('../../../../lib/domain/usecases/get-campaign'); -const badgeRepository = require('../../../../lib/infrastructure/repositories/badge-repository'); -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const campaignReportRepository = require('../../../../lib/infrastructure/repositories/campaign-report-repository'); +import { expect, databaseBuilder, catchErr, mockLearningContent } from '../../../test-helper.js'; +import { NotFoundError, UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { getCampaign } from '../../../../lib/domain/usecases/get-campaign.js'; +import * as badgeRepository from '../../../../lib/infrastructure/repositories/badge-repository.js'; +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import * as campaignReportRepository from '../../../../lib/infrastructure/repositories/campaign-report-repository.js'; describe('Integration | UseCase | get-campaign', function () { context('Error case', function () { diff --git a/api/tests/integration/domain/usecases/get-certification-center-invitation_test.js b/api/tests/integration/domain/usecases/get-certification-center-invitation_test.js index 8787107cdc6..ea8d6aa3b73 100644 --- a/api/tests/integration/domain/usecases/get-certification-center-invitation_test.js +++ b/api/tests/integration/domain/usecases/get-certification-center-invitation_test.js @@ -1,11 +1,11 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); -const { +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; +import { NotFoundError, AlreadyExistingInvitationError, CancelledInvitationError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Integration | API | getCertificationCenterInvitation', function () { describe('when an invitation exists', function () { @@ -30,7 +30,7 @@ describe('Integration | API | getCertificationCenterInvitation', function () { await databaseBuilder.commit(); // when - const result = await useCases.getCertificationCenterInvitation({ + const result = await usecases.getCertificationCenterInvitation({ certificationCenterInvitationId: konohaInvitation.id, certificationCenterInvitationCode: 'PAIN999', }); @@ -62,7 +62,7 @@ describe('Integration | API | getCertificationCenterInvitation', function () { await databaseBuilder.commit(); // when - const error = await catchErr(useCases.getCertificationCenterInvitation)({ + const error = await catchErr(usecases.getCertificationCenterInvitation)({ certificationCenterInvitationId: konohaInvitation.id, certificationCenterInvitationCode: 'WRONGCODE01', }); @@ -88,7 +88,7 @@ describe('Integration | API | getCertificationCenterInvitation', function () { await databaseBuilder.commit(); // when - const error = await catchErr(useCases.getCertificationCenterInvitation)({ + const error = await catchErr(usecases.getCertificationCenterInvitation)({ certificationCenterInvitationId: killuaInvitation.id, certificationCenterInvitationCode: 'HXH456', }); @@ -114,7 +114,7 @@ describe('Integration | API | getCertificationCenterInvitation', function () { await databaseBuilder.commit(); // when - const error = await catchErr(useCases.getCertificationCenterInvitation)({ + const error = await catchErr(usecases.getCertificationCenterInvitation)({ certificationCenterInvitationId: dekuInvitation.id, certificationCenterInvitationCode: 'MHA789', }); diff --git a/api/tests/integration/domain/usecases/get-next-challenge-for-campaign-assessment_test.js b/api/tests/integration/domain/usecases/get-next-challenge-for-campaign-assessment_test.js index 9ce3f4830ab..8b0f25a30a2 100644 --- a/api/tests/integration/domain/usecases/get-next-challenge-for-campaign-assessment_test.js +++ b/api/tests/integration/domain/usecases/get-next-challenge-for-campaign-assessment_test.js @@ -1,10 +1,10 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getNextChallengeForCampaignAssessment } from '../../../../lib/domain/usecases/get-next-challenge-for-campaign-assessment.js'; +import * as dataFetcher from '../../../../lib/domain/services/algorithm-methods/data-fetcher.js'; -const getNextChallengeForCampaignAssessment = require('../../../../lib/domain/usecases/get-next-challenge-for-campaign-assessment'); -const flash = require('../../../../lib/domain/services/algorithm-methods/flash'); -const smartRandom = require('../../../../lib/domain/services/algorithm-methods/smart-random'); -const dataFetcher = require('../../../../lib/domain/services/algorithm-methods/data-fetcher'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_SPOKEN } = LOCALE; describe('Integration | Domain | Use Cases | get-next-challenge-for-campaign-assessment', function () { describe('#getNextChallengeForCampaignAssessment : case for SMART RANDOM', function () { @@ -29,6 +29,7 @@ describe('Integration | Domain | Use Cases | get-next-challenge-for-campaign-ass challengeWeb21, challengeWeb22, possibleSkillsForNextChallenge, + smartRandom, locale; beforeEach(async function () { @@ -78,10 +79,12 @@ describe('Integration | Domain | Use Cases | get-next-challenge-for-campaign-ass locale = FRENCH_SPOKEN; possibleSkillsForNextChallenge = [web2, url2, search2]; - sinon.stub(smartRandom, 'getPossibleSkillsForNextChallenge').returns({ - hasAssessmentEnded: false, - possibleSkillsForNextChallenge, - }); + smartRandom = { + getPossibleSkillsForNextChallenge: sinon.stub().returns({ + hasAssessmentEnded: false, + possibleSkillsForNextChallenge, + }), + }; actualNextChallenge = await getNextChallengeForCampaignAssessment({ assessment, @@ -94,7 +97,6 @@ describe('Integration | Domain | Use Cases | get-next-challenge-for-campaign-ass pickChallengeService, locale, smartRandom, - flash, dataFetcher, }); }); diff --git a/api/tests/integration/domain/usecases/get-organization-learner_test.js b/api/tests/integration/domain/usecases/get-organization-learner_test.js index 43e1aec5ef1..f41dae256f6 100644 --- a/api/tests/integration/domain/usecases/get-organization-learner_test.js +++ b/api/tests/integration/domain/usecases/get-organization-learner_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); +import { expect, databaseBuilder } from '../../../test-helper.js'; -const organizationLearnerRepository = require('../../../../lib/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository'); -const OrganizationLearner = require('../../../../lib/domain/read-models/organization-learner-follow-up/OrganizationLearner'); -const getOrganizationLearner = require('../../../../lib/domain/usecases/get-organization-learner'); +import * as organizationLearnerRepository from '../../../../lib/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository.js'; +import { OrganizationLearner } from '../../../../lib/domain/read-models/organization-learner-follow-up/OrganizationLearner.js'; +import { getOrganizationLearner } from '../../../../lib/domain/usecases/get-organization-learner.js'; describe('Integration | UseCases | get-organization-learner', function () { it('should return organization learner given organizationLearnerId', async function () { diff --git a/api/tests/integration/domain/usecases/get-paginated-participants-for-an-organization_test.js b/api/tests/integration/domain/usecases/get-paginated-participants-for-an-organization_test.js index eff994604e6..ed2dded0a19 100644 --- a/api/tests/integration/domain/usecases/get-paginated-participants-for-an-organization_test.js +++ b/api/tests/integration/domain/usecases/get-paginated-participants-for-an-organization_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const organizationParticipantRepository = require('../../../../lib/infrastructure/repositories/organization-participant-repository'); -const getPaginatedParticipantsForAnOrganization = require('../../../../lib/domain/usecases/get-paginated-participants-for-an-organization'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as organizationParticipantRepository from '../../../../lib/infrastructure/repositories/organization-participant-repository.js'; +import { getPaginatedParticipantsForAnOrganization } from '../../../../lib/domain/usecases/get-paginated-participants-for-an-organization.js'; describe('Integration | UseCases | get-paginated-participants-for-an-organization', function () { it('should get all participations for an organization', async function () { diff --git a/api/tests/integration/domain/usecases/get-participants-division_test.js b/api/tests/integration/domain/usecases/get-participants-division_test.js index 2a1f3e289ce..0d2b76a4825 100644 --- a/api/tests/integration/domain/usecases/get-participants-division_test.js +++ b/api/tests/integration/domain/usecases/get-participants-division_test.js @@ -1,6 +1,8 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const { getParticipantsDivision } = require('../../../../lib/domain/usecases/index'); -const { ForbiddenAccess } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { ForbiddenAccess } from '../../../../lib/domain/errors.js'; + +const { getParticipantsDivision } = usecases; describe('Integration | UseCase | get-participants-division', function () { context('when the use has access to the campaign', function () { diff --git a/api/tests/integration/domain/usecases/get-participants-group_test.js b/api/tests/integration/domain/usecases/get-participants-group_test.js index bc52d43dc65..ffc38b67f19 100644 --- a/api/tests/integration/domain/usecases/get-participants-group_test.js +++ b/api/tests/integration/domain/usecases/get-participants-group_test.js @@ -1,6 +1,8 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const { getParticipantsGroup } = require('../../../../lib/domain/usecases/index'); -const { ForbiddenAccess } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { ForbiddenAccess } from '../../../../lib/domain/errors.js'; + +const { getParticipantsGroup } = usecases; describe('Integration | UseCase | get-participants-group', function () { context('when the use has access to the campaign', function () { diff --git a/api/tests/integration/domain/usecases/get-pole-emploi-sendings_test.js b/api/tests/integration/domain/usecases/get-pole-emploi-sendings_test.js index b7af56e040f..5c46141ecda 100644 --- a/api/tests/integration/domain/usecases/get-pole-emploi-sendings_test.js +++ b/api/tests/integration/domain/usecases/get-pole-emploi-sendings_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const poleEmploiService = require('../../../../lib/domain/services/pole-emploi-service'); -const poleEmploiSendingRepository = require('../../../../lib/infrastructure/repositories/pole-emploi-sending-repository'); -const settings = require('../../../../lib/config'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import * as poleEmploiService from '../../../../lib/domain/services/pole-emploi-service.js'; +import * as poleEmploiSendingRepository from '../../../../lib/infrastructure/repositories/pole-emploi-sending-repository.js'; +import { config as settings } from '../../../../lib/config.js'; const poleEmploiSendingFactory = databaseBuilder.factory.poleEmploiSendingFactory; describe('Integration | UseCase | get-campaign-participations-counts-by-stage', function () { diff --git a/api/tests/integration/domain/usecases/get-prescriber_test.js b/api/tests/integration/domain/usecases/get-prescriber_test.js index f6cf8e90a57..84adf8ec629 100644 --- a/api/tests/integration/domain/usecases/get-prescriber_test.js +++ b/api/tests/integration/domain/usecases/get-prescriber_test.js @@ -1,10 +1,10 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; -const prescriberRepository = require('../../../../lib/infrastructure/repositories/prescriber-repository'); -const membershipRepository = require('../../../../lib/infrastructure/repositories/membership-repository'); -const userOrgaSettingsRepository = require('../../../../lib/infrastructure/repositories/user-orga-settings-repository'); +import * as prescriberRepository from '../../../../lib/infrastructure/repositories/prescriber-repository.js'; +import * as membershipRepository from '../../../../lib/infrastructure/repositories/membership-repository.js'; +import * as userOrgaSettingsRepository from '../../../../lib/infrastructure/repositories/user-orga-settings-repository.js'; -const getPrescriber = require('../../../../lib/domain/usecases/get-prescriber'); +import { getPrescriber } from '../../../../lib/domain/usecases/get-prescriber.js'; describe('Integration | UseCases | get-prescriber', function () { context('When prescriber does not have a userOrgaSettings', function () { diff --git a/api/tests/integration/domain/usecases/get-recently-used-tags_test.js b/api/tests/integration/domain/usecases/get-recently-used-tags_test.js index 1362c0727b3..81618437165 100644 --- a/api/tests/integration/domain/usecases/get-recently-used-tags_test.js +++ b/api/tests/integration/domain/usecases/get-recently-used-tags_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, databaseBuilder } = require('../../../test-helper'); -const getRecentlyUsedTags = require('../../../../lib/domain/usecases/get-recently-used-tags'); -const Tag = require('../../../../lib/domain/models/Tag'); -const organizationTagRepository = require('../../../../lib/infrastructure/repositories/organization-tag-repository'); +import _ from 'lodash'; +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { getRecentlyUsedTags } from '../../../../lib/domain/usecases/get-recently-used-tags.js'; +import { Tag } from '../../../../lib/domain/models/Tag.js'; +import * as organizationTagRepository from '../../../../lib/infrastructure/repositories/organization-tag-repository.js'; describe('Integration | UseCase | get-recently-used-tags', function () { it('returns 10 recently used tags based on a tag id and ordered by the most used first', async function () { diff --git a/api/tests/integration/domain/usecases/get-user-by-reset-password-demand_test.js b/api/tests/integration/domain/usecases/get-user-by-reset-password-demand_test.js index 40648cfe8c3..bf8054bc66b 100644 --- a/api/tests/integration/domain/usecases/get-user-by-reset-password-demand_test.js +++ b/api/tests/integration/domain/usecases/get-user-by-reset-password-demand_test.js @@ -1,18 +1,19 @@ -const { catchErr, expect, databaseBuilder } = require('../../../test-helper'); +import { catchErr, expect, databaseBuilder } from '../../../test-helper.js'; -const resetPasswordService = require('../../../../lib/domain/services/reset-password-service'); -const tokenService = require('../../../../lib/domain/services/token-service'); +import * as resetPasswordService from '../../../../lib/domain/services/reset-password-service.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; -const User = require('../../../../lib/domain/models/User'); -const { +import { User } from '../../../../lib/domain/models/User.js'; + +import { InvalidTemporaryKeyError, PasswordResetDemandNotFoundError, UserNotFoundError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; -const getUserByResetPasswordDemand = require('../../../../lib/domain/usecases/get-user-by-reset-password-demand'); +import { getUserByResetPasswordDemand } from '../../../../lib/domain/usecases/get-user-by-reset-password-demand.js'; describe('Integration | UseCases | get-user-by-reset-password-demand', function () { const email = 'user@example.net'; diff --git a/api/tests/integration/domain/usecases/handle-badge-acquisition_test.js b/api/tests/integration/domain/usecases/handle-badge-acquisition_test.js index 1d3a4db03ad..0b9788508ce 100644 --- a/api/tests/integration/domain/usecases/handle-badge-acquisition_test.js +++ b/api/tests/integration/domain/usecases/handle-badge-acquisition_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, knex, mockLearningContent, learningContentBuilder } = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { expect, databaseBuilder, knex, mockLearningContent, learningContentBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Integration | Usecase | Handle Badge Acquisition', function () { let userId, assessment, badgeCompleted; @@ -103,7 +103,7 @@ describe('Integration | Usecase | Handle Badge Acquisition', function () { type: Assessment.types.CAMPAIGN, }); - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); return databaseBuilder.commit(); @@ -117,7 +117,7 @@ describe('Integration | Usecase | Handle Badge Acquisition', function () { it('should not affect the database', async function () { await DomainTransaction.execute(async (domainTransaction) => { // when - await useCases.handleBadgeAcquisition({ + await usecases.handleBadgeAcquisition({ assessment, domainTransaction, }); diff --git a/api/tests/integration/domain/usecases/import-sup-organization-learners_test.js b/api/tests/integration/domain/usecases/import-sup-organization-learners_test.js index 4f51ee0d0a3..b3faedff964 100644 --- a/api/tests/integration/domain/usecases/import-sup-organization-learners_test.js +++ b/api/tests/integration/domain/usecases/import-sup-organization-learners_test.js @@ -1,11 +1,11 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const iconv = require('iconv-lite'); - -const importSupOrganizationLearner = require('../../../../lib/domain/usecases/import-sup-organization-learners'); -const supOrganizationLearnerRepository = require('../../../../lib/infrastructure/repositories/sup-organization-learner-repository'); -const SupOrganizationLearnerParser = require('../../../../lib/infrastructure/serializers/csv/sup-organization-learner-parser'); -const SupOrganizationLearnerImportHeader = require('../../../../lib/infrastructure/serializers/csv/sup-organization-learner-import-header'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import iconv from 'iconv-lite'; + +import { importSupOrganizationLearners as importSupOrganizationLearner } from '../../../../lib/domain/usecases/import-sup-organization-learners.js'; +import * as supOrganizationLearnerRepository from '../../../../lib/infrastructure/repositories/sup-organization-learner-repository.js'; +import { SupOrganizationLearnerParser } from '../../../../lib/infrastructure/serializers/csv/sup-organization-learner-parser.js'; +import { SupOrganizationLearnerImportHeader } from '../../../../lib/infrastructure/serializers/csv/sup-organization-learner-import-header.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; const i18n = getI18n(); diff --git a/api/tests/integration/domain/usecases/improve-competence-evaluation_test.js b/api/tests/integration/domain/usecases/improve-competence-evaluation_test.js index 519f495e57b..3e748a64d54 100644 --- a/api/tests/integration/domain/usecases/improve-competence-evaluation_test.js +++ b/api/tests/integration/domain/usecases/improve-competence-evaluation_test.js @@ -1,9 +1,9 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const improveCompetenceEvaluation = require('../../../../lib/domain/usecases/improve-competence-evaluation'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { improveCompetenceEvaluation } from '../../../../lib/domain/usecases/improve-competence-evaluation.js'; -const competenceEvaluationRepository = require('../../../../lib/infrastructure/repositories/competence-evaluation-repository'); -const assessmentRepository = require('../../../../lib/infrastructure/repositories/assessment-repository'); -const getCompetenceLevel = require('../../../../lib/domain/services/get-competence-level'); +import * as competenceEvaluationRepository from '../../../../lib/infrastructure/repositories/competence-evaluation-repository.js'; +import * as assessmentRepository from '../../../../lib/infrastructure/repositories/assessment-repository.js'; +import { getCompetenceLevel } from '../../../../lib/domain/services/get-competence-level.js'; describe('Integration | UseCase | Improve Competence Evaluation', function () { const competenceId = 'recCompetenceId'; diff --git a/api/tests/integration/domain/usecases/reconcile-sup-organization-learner_test.js b/api/tests/integration/domain/usecases/reconcile-sup-organization-learner_test.js index 589187b002c..5f53906f9d9 100644 --- a/api/tests/integration/domain/usecases/reconcile-sup-organization-learner_test.js +++ b/api/tests/integration/domain/usecases/reconcile-sup-organization-learner_test.js @@ -1,11 +1,10 @@ -const { expect, databaseBuilder, knex, catchErr } = require('../../../test-helper'); -const userReconciliationService = require('../../../../lib/domain/services/user-reconciliation-service'); -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const supOrganizationLearnerRepository = require('../../../../lib/infrastructure/repositories/sup-organization-learner-repository'); -const organizationLearnerRepository = require('../../../../lib/infrastructure/repositories/organization-learner-repository'); -const { NotFoundError, OrganizationLearnerAlreadyLinkedToUserError } = require('../../../../lib/domain/errors'); - -const reconcileSupOrganizationLearner = require('../../../../lib/domain/usecases/reconcile-sup-organization-learner'); +import { expect, databaseBuilder, knex, catchErr } from '../../../test-helper.js'; +import * as userReconciliationService from '../../../../lib/domain/services/user-reconciliation-service.js'; +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import * as supOrganizationLearnerRepository from '../../../../lib/infrastructure/repositories/sup-organization-learner-repository.js'; +import * as organizationLearnerRepository from '../../../../lib/infrastructure/repositories/organization-learner-repository.js'; +import { NotFoundError, OrganizationLearnerAlreadyLinkedToUserError } from '../../../../lib/domain/errors.js'; +import { reconcileSupOrganizationLearner } from '../../../../lib/domain/usecases/reconcile-sup-organization-learner.js'; describe('Integration | UseCases | reconcile-sup-organization-learner', function () { let userId; diff --git a/api/tests/integration/domain/usecases/save-admin-member_test.js b/api/tests/integration/domain/usecases/save-admin-member_test.js index 28e36e793a2..e9cf35b5592 100644 --- a/api/tests/integration/domain/usecases/save-admin-member_test.js +++ b/api/tests/integration/domain/usecases/save-admin-member_test.js @@ -1,8 +1,11 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const saveAdminMember = require('../../../../lib/domain/usecases/save-admin-member'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; -const adminMemberRepository = require('../../../../lib/infrastructure/repositories/admin-member-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { saveAdminMember } from '../../../../lib/domain/usecases/save-admin-member.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; + +import * as adminMemberRepository from '../../../../lib/infrastructure/repositories/admin-member-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; describe('Integration | UseCases | save-admin-member', function () { context('when admin member exists and is disabled', function () { diff --git a/api/tests/integration/domain/usecases/send-shared-participation-results-to-pole-emploi_test.js b/api/tests/integration/domain/usecases/send-shared-participation-results-to-pole-emploi_test.js index e52af3d8a77..349fbf6a15a 100644 --- a/api/tests/integration/domain/usecases/send-shared-participation-results-to-pole-emploi_test.js +++ b/api/tests/integration/domain/usecases/send-shared-participation-results-to-pole-emploi_test.js @@ -1,21 +1,23 @@ -const { +import { expect, databaseBuilder, knex, mockLearningContent, learningContentBuilder, sinon, -} = require('../../../test-helper'); -const useCases = require('../../../../lib/domain/usecases/index.js'); -const poleEmploiNotifier = require('../../../../lib/infrastructure/externals/pole-emploi/pole-emploi-notifier.js'); +} from '../../../test-helper.js'; + +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Integration | Domain | UseCases | send-shared-participation-results-to-pole-emploi', function () { let campaignParticipationId, userId, responseCode; + let poleEmploiNotifier; beforeEach(async function () { responseCode = Symbol('responseCode'); - sinon.stub(poleEmploiNotifier, 'notify'); - poleEmploiNotifier.notify.resolves({ isSuccessful: true, code: responseCode }); + poleEmploiNotifier = { + notify: sinon.stub(), + }; userId = databaseBuilder.factory.buildUser().id; databaseBuilder.factory.buildAuthenticationMethod.withPoleEmploiAsIdentityProvider({ userId }); @@ -27,7 +29,7 @@ describe('Integration | Domain | UseCases | send-shared-participation-results-to databaseBuilder.factory.buildCampaignSkill({ campaignId }); campaignParticipationId = databaseBuilder.factory.buildCampaignParticipation({ campaignId, userId }).id; databaseBuilder.factory.buildAssessment({ campaignParticipationId, userId }); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([]); + const learningContentObjects = learningContentBuilder.fromAreas([]); mockLearningContent(learningContentObjects); return databaseBuilder.commit(); }); @@ -36,9 +38,14 @@ describe('Integration | Domain | UseCases | send-shared-participation-results-to await knex('pole-emploi-sendings').delete(); }); - it('should notify pole emploi and save success of this notification', async function () { - await useCases.sendSharedParticipationResultsToPoleEmploi({ campaignParticipationId }); + it('should save success of this notification', async function () { + // given + poleEmploiNotifier.notify.resolves({ isSuccessful: true, code: responseCode }); + + // when + await usecases.sendSharedParticipationResultsToPoleEmploi({ campaignParticipationId, poleEmploiNotifier }); + // then const poleEmploiSendings = await knex('pole-emploi-sendings').where({ campaignParticipationId }); expect(poleEmploiSendings.length).to.equal(1); expect(poleEmploiSendings[0].responseCode).to.equal(responseCode.toString()); diff --git a/api/tests/integration/domain/usecases/simulate-flash-scoring_test.js b/api/tests/integration/domain/usecases/simulate-flash-scoring_test.js index 37c3d2d850e..264707aa0d5 100644 --- a/api/tests/integration/domain/usecases/simulate-flash-scoring_test.js +++ b/api/tests/integration/domain/usecases/simulate-flash-scoring_test.js @@ -1,9 +1,9 @@ -const { expect, mockLearningContent, domainBuilder } = require('../../../test-helper'); -const ScoringSimulationContext = require('../../../../lib/domain/models/ScoringSimulationContext'); -const ScoringSimulation = require('../../../../lib/domain/models/ScoringSimulation'); -const ScoringSimulationResult = require('../../../../lib/domain/models/ScoringSimulationResult'); -const usecases = require('../../../../lib/domain/usecases/'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); +import { expect, mockLearningContent, domainBuilder } from '../../../test-helper.js'; +import { ScoringSimulationContext } from '../../../../lib/domain/models/ScoringSimulationContext.js'; +import { ScoringSimulation } from '../../../../lib/domain/models/ScoringSimulation.js'; +import { ScoringSimulationResult } from '../../../../lib/domain/models/ScoringSimulationResult.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; describe('Integration | UseCases | simulateFlashScoring', function () { const locale = 'fr-fr'; diff --git a/api/tests/integration/domain/usecases/simulate-old-scoring_test.js b/api/tests/integration/domain/usecases/simulate-old-scoring_test.js index 90452194f2e..46a5faa2660 100644 --- a/api/tests/integration/domain/usecases/simulate-old-scoring_test.js +++ b/api/tests/integration/domain/usecases/simulate-old-scoring_test.js @@ -1,7 +1,7 @@ -const { expect, mockLearningContent, domainBuilder } = require('../../../test-helper'); -const ScoringSimulation = require('../../../../lib/domain/models/ScoringSimulation'); -const ScoringSimulationResult = require('../../../../lib/domain/models/ScoringSimulationResult'); -const usecases = require('../../../../lib/domain/usecases/'); +import { expect, mockLearningContent, domainBuilder } from '../../../test-helper.js'; +import { ScoringSimulation } from '../../../../lib/domain/models/ScoringSimulation.js'; +import { ScoringSimulationResult } from '../../../../lib/domain/models/ScoringSimulationResult.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Integration | UseCases | simulateOldScoring', function () { beforeEach(function () { diff --git a/api/tests/integration/domain/usecases/start-campaign-participation_test.js b/api/tests/integration/domain/usecases/start-campaign-participation_test.js index 178b179fd7c..ea7ddc41f5f 100644 --- a/api/tests/integration/domain/usecases/start-campaign-participation_test.js +++ b/api/tests/integration/domain/usecases/start-campaign-participation_test.js @@ -1,7 +1,6 @@ -const { expect, databaseBuilder, knex, mockLearningContent } = require('../../../test-helper'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); - -const usecases = require('../../../../lib/domain/usecases/'); +import { expect, databaseBuilder, knex, mockLearningContent } from '../../../test-helper.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Integration | UseCases | startCampaignParticipation', function () { afterEach(async function () { diff --git a/api/tests/integration/domain/usecases/start-writing-campaign-assessment-results-to-stream_test.js b/api/tests/integration/domain/usecases/start-writing-campaign-assessment-results-to-stream_test.js index 27279e79906..c6ef6fa300d 100644 --- a/api/tests/integration/domain/usecases/start-writing-campaign-assessment-results-to-stream_test.js +++ b/api/tests/integration/domain/usecases/start-writing-campaign-assessment-results-to-stream_test.js @@ -1,9 +1,11 @@ -const { PassThrough } = require('stream'); -const { expect, mockLearningContent, databaseBuilder, streamToPromise } = require('../../../test-helper'); +import stream from 'stream'; -const usecases = require('../../../../lib/domain/usecases/index.js'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +const { PassThrough } = stream; + +import { expect, mockLearningContent, databaseBuilder, streamToPromise } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; describe('Integration | Domain | Use Cases | start-writing-campaign-assessment-results-to-stream', function () { describe('#startWritingCampaignAssessmentResultsToStream', function () { diff --git a/api/tests/integration/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream_test.js b/api/tests/integration/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream_test.js index 97b76c1f7e5..5758f5416fb 100644 --- a/api/tests/integration/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream_test.js +++ b/api/tests/integration/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream_test.js @@ -1,15 +1,17 @@ -const { PassThrough } = require('stream'); -const { expect, mockLearningContent, databaseBuilder, streamToPromise } = require('../../../test-helper'); - -const startWritingCampaignProfilesCollectionResultsToStream = require('../../../../lib/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream'); - -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const campaignParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-repository'); -const competenceRepository = require('../../../../lib/infrastructure/repositories/competence-repository'); -const organizationRepository = require('../../../../lib/infrastructure/repositories/organization-repository'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); -const placementProfileService = require('../../../../lib/domain/services/placement-profile-service'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import stream from 'stream'; + +const { PassThrough } = stream; + +import { expect, mockLearningContent, databaseBuilder, streamToPromise } from '../../../test-helper.js'; +import { startWritingCampaignProfilesCollectionResultsToStream } from '../../../../lib/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream.js'; + +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import * as campaignParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-participation-repository.js'; +import * as competenceRepository from '../../../../lib/infrastructure/repositories/competence-repository.js'; +import * as organizationRepository from '../../../../lib/infrastructure/repositories/organization-repository.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; +import * as placementProfileService from '../../../../lib/domain/services/placement-profile-service.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; describe('Integration | Domain | Use Cases | start-writing-profiles-collection-campaign-results-to-stream', function () { describe('#startWritingCampaignProfilesCollectionResultsToStream', function () { diff --git a/api/tests/integration/domain/usecases/unblock-user-account_test.js b/api/tests/integration/domain/usecases/unblock-user-account_test.js index 4d99e697683..296ae324405 100644 --- a/api/tests/integration/domain/usecases/unblock-user-account_test.js +++ b/api/tests/integration/domain/usecases/unblock-user-account_test.js @@ -1,7 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); -const UserLogin = require('../../../../lib/domain/models/UserLogin'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserLogin } from '../../../../lib/domain/models/UserLogin.js'; describe('Integration | UseCases | unblockUserAccount', function () { it('should reset failure count, temporary blocked until date and blocked at date', async function () { diff --git a/api/tests/integration/domain/usecases/update-campaign-details-management_test.js b/api/tests/integration/domain/usecases/update-campaign-details-management_test.js index b44ad67d1a9..e68f321415e 100644 --- a/api/tests/integration/domain/usecases/update-campaign-details-management_test.js +++ b/api/tests/integration/domain/usecases/update-campaign-details-management_test.js @@ -1,10 +1,10 @@ -const { expect, databaseBuilder, mockLearningContent, knex, catchErr } = require('../../../test-helper'); +import { expect, databaseBuilder, mockLearningContent, knex, catchErr } from '../../../test-helper.js'; -const campaignManagementRepository = require('../../../../lib/infrastructure/repositories/campaign-management-repository'); -const campaignValidator = require('../../../../lib/domain/validators/campaign-validator.js'); -const updateCampaignDetailsManagement = require('../../../../lib/domain/usecases/update-campaign-details-management'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import * as campaignManagementRepository from '../../../../lib/infrastructure/repositories/campaign-management-repository.js'; +import * as campaignValidator from '../../../../lib/domain/validators/campaign-validator.js'; +import { updateCampaignDetailsManagement } from '../../../../lib/domain/usecases/update-campaign-details-management.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; const { SHARED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/domain/usecases/update-certification-center-data-protection-officer-information_test.js b/api/tests/integration/domain/usecases/update-certification-center-data-protection-officer-information_test.js index bb4d29de564..c28b35329e4 100644 --- a/api/tests/integration/domain/usecases/update-certification-center-data-protection-officer-information_test.js +++ b/api/tests/integration/domain/usecases/update-certification-center-data-protection-officer-information_test.js @@ -1,7 +1,7 @@ -const { knex, expect, databaseBuilder } = require('../../../test-helper'); -const DataProtectionOfficer = require('../../../../lib/domain/models/DataProtectionOfficer'); -const updateCertificationCenterDataProtectionOfficerInformation = require('../../../../lib/domain/usecases/update-certification-center-data-protection-officer-information'); -const dataProtectionOfficerRepository = require('../../../../lib/infrastructure/repositories/data-protection-officer-repository'); +import { knex, expect, databaseBuilder } from '../../../test-helper.js'; +import { DataProtectionOfficer } from '../../../../lib/domain/models/DataProtectionOfficer.js'; +import { updateCertificationCenterDataProtectionOfficerInformation } from '../../../../lib/domain/usecases/update-certification-center-data-protection-officer-information.js'; +import * as dataProtectionOfficerRepository from '../../../../lib/infrastructure/repositories/data-protection-officer-repository.js'; describe('Integration | UseCases | update-certification-center-data-protection-officer-information', function () { afterEach(async function () { diff --git a/api/tests/integration/domain/usecases/update-certification-center_test.js b/api/tests/integration/domain/usecases/update-certification-center_test.js index 784ee9c7dc4..fcff69f7c89 100644 --- a/api/tests/integration/domain/usecases/update-certification-center_test.js +++ b/api/tests/integration/domain/usecases/update-certification-center_test.js @@ -1,9 +1,9 @@ -const { databaseBuilder, domainBuilder, expect, knex } = require('../../../test-helper'); -const CertificationCenterForAdmin = require('../../../../lib/domain/models/CertificationCenterForAdmin'); -const updateCertificationCenter = require('../../../../lib/domain/usecases/update-certification-center'); -const certificationCenterForAdminRepository = require('../../../../lib/infrastructure/repositories/certification-center-for-admin-repository'); -const complementaryCertificationHabilitationRepository = require('../../../../lib/infrastructure/repositories/complementary-certification-habilitation-repository'); -const dataProtectionOfficerRepository = require('../../../../lib/infrastructure/repositories/data-protection-officer-repository'); +import { databaseBuilder, domainBuilder, expect, knex } from '../../../test-helper.js'; +import { CertificationCenterForAdmin } from '../../../../lib/domain/models/CertificationCenterForAdmin.js'; +import { updateCertificationCenter } from '../../../../lib/domain/usecases/update-certification-center.js'; +import * as certificationCenterForAdminRepository from '../../../../lib/infrastructure/repositories/certification-center-for-admin-repository.js'; +import * as complementaryCertificationHabilitationRepository from '../../../../lib/infrastructure/repositories/complementary-certification-habilitation-repository.js'; +import * as dataProtectionOfficerRepository from '../../../../lib/infrastructure/repositories/data-protection-officer-repository.js'; describe('Integration | UseCases | update-certification-center', function () { afterEach(async function () { diff --git a/api/tests/integration/domain/usecases/update-membership_test.js b/api/tests/integration/domain/usecases/update-membership_test.js index 1c3ff66bdc5..da91e99682a 100644 --- a/api/tests/integration/domain/usecases/update-membership_test.js +++ b/api/tests/integration/domain/usecases/update-membership_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); +import { expect, databaseBuilder } from '../../../test-helper.js'; -const membershipRepository = require('../../../../lib/infrastructure/repositories/membership-repository'); -const Membership = require('../../../../lib/domain/models/Membership'); -const updateMembership = require('../../../../lib/domain/usecases/update-membership'); +import * as membershipRepository from '../../../../lib/infrastructure/repositories/membership-repository.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { updateMembership } from '../../../../lib/domain/usecases/update-membership.js'; describe('Integration | UseCases | update-membership', function () { it('should update membership', async function () { diff --git a/api/tests/integration/domain/usecases/update-organization-data-protection-officer-information_test.js b/api/tests/integration/domain/usecases/update-organization-data-protection-officer-information_test.js index 5cfabe912b2..349461b6d0d 100644 --- a/api/tests/integration/domain/usecases/update-organization-data-protection-officer-information_test.js +++ b/api/tests/integration/domain/usecases/update-organization-data-protection-officer-information_test.js @@ -1,7 +1,7 @@ -const { knex, expect, databaseBuilder } = require('../../../test-helper'); -const DataProtectionOfficer = require('../../../../lib/domain/models/DataProtectionOfficer'); -const updateOrganizationDataProtectionOfficerInformation = require('../../../../lib/domain/usecases/update-organization-data-protection-officer-information'); -const dataProtectionOfficerRepository = require('../../../../lib/infrastructure/repositories/data-protection-officer-repository'); +import { knex, expect, databaseBuilder } from '../../../test-helper.js'; +import { DataProtectionOfficer } from '../../../../lib/domain/models/DataProtectionOfficer.js'; +import { updateOrganizationDataProtectionOfficerInformation } from '../../../../lib/domain/usecases/update-organization-data-protection-officer-information.js'; +import * as dataProtectionOfficerRepository from '../../../../lib/infrastructure/repositories/data-protection-officer-repository.js'; describe('Integration | UseCases | update-organization-data-protection-officer-information', function () { afterEach(async function () { diff --git a/api/tests/integration/domain/usecases/update-user-details-for-administration_test.js b/api/tests/integration/domain/usecases/update-user-details-for-administration_test.js index 8fec78c5cc7..1350a2cdda2 100644 --- a/api/tests/integration/domain/usecases/update-user-details-for-administration_test.js +++ b/api/tests/integration/domain/usecases/update-user-details-for-administration_test.js @@ -1,11 +1,9 @@ -const { expect, catchErr, databaseBuilder } = require('../../../test-helper'); +import { expect, catchErr, databaseBuilder } from '../../../test-helper.js'; +import { AlreadyRegisteredEmailError, AlreadyRegisteredUsernameError } from '../../../../lib/domain/errors.js'; -const { AlreadyRegisteredEmailError, AlreadyRegisteredUsernameError } = require('../../../../lib/domain/errors'); - -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); -const UserDetailsForAdmin = require('../../../../lib/domain/models/UserDetailsForAdmin'); - -const updateUserDetailsForAdministration = require('../../../../lib/domain/usecases/update-user-details-for-administration'); +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; +import { UserDetailsForAdmin } from '../../../../lib/domain/models/UserDetailsForAdmin.js'; +import { updateUserDetailsForAdministration } from '../../../../lib/domain/usecases/update-user-details-for-administration.js'; describe('Integration | UseCases | updateUserDetailsForAdministration', function () { let userId; diff --git a/api/tests/integration/infrastructure/event-dispatcher-logger_test.js b/api/tests/integration/infrastructure/event-dispatcher-logger_test.js index 4bc88ed02d0..3a39f1f73ab 100644 --- a/api/tests/integration/infrastructure/event-dispatcher-logger_test.js +++ b/api/tests/integration/infrastructure/event-dispatcher-logger_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../test-helper'); -const EventDispatcherLogger = require('../../../lib/infrastructure/events/EventDispatcherLogger'); +import { expect, sinon } from '../../test-helper.js'; +import { EventDispatcherLogger } from '../../../lib/infrastructure/events/EventDispatcherLogger.js'; describe('Integration | Infrastructure | EventHandlerLogger', function () { context('when logging on event dispatch start is enabled', function () { diff --git a/api/tests/integration/infrastructure/event-dispatcher_test.js b/api/tests/integration/infrastructure/event-dispatcher_test.js index 6a240aa110c..6612d793a41 100644 --- a/api/tests/integration/infrastructure/event-dispatcher_test.js +++ b/api/tests/integration/infrastructure/event-dispatcher_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../test-helper'); -const EventDispatcher = require('../../../lib/infrastructure/events/EventDispatcher'); +import { expect, sinon } from '../../test-helper.js'; +import { EventDispatcher } from '../../../lib/infrastructure/events/EventDispatcher.js'; function getEventHandlerMock() { return sinon.stub(); diff --git a/api/tests/integration/infrastructure/jobs/JobQueue_test.js b/api/tests/integration/infrastructure/jobs/JobQueue_test.js index d82673db9de..a4eaa173682 100644 --- a/api/tests/integration/infrastructure/jobs/JobQueue_test.js +++ b/api/tests/integration/infrastructure/jobs/JobQueue_test.js @@ -1,7 +1,7 @@ -const { expect, knex } = require('../../../test-helper'); -const JobQueue = require('../../../../lib/infrastructure/jobs/JobQueue'); -const Job = require('../../../../lib/infrastructure/jobs/JobPgBoss'); -const PgBoss = require('pg-boss'); +import { expect, knex } from '../../../test-helper.js'; +import { JobQueue } from '../../../../lib/infrastructure/jobs/JobQueue.js'; +import { JobPgBoss as Job } from '../../../../lib/infrastructure/jobs/JobPgBoss.js'; +import PgBoss from 'pg-boss'; describe('Integration | Infrastructure | Jobs | JobQueue', function () { it('executes job when a job is added to the queue', async function () { diff --git a/api/tests/integration/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob_test.js b/api/tests/integration/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob_test.js index f78dee00d1b..67f51ddc5f3 100644 --- a/api/tests/integration/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob_test.js +++ b/api/tests/integration/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob_test.js @@ -1,5 +1,5 @@ -const { expect, knex } = require('../../../../test-helper'); -const ParticipationResultCalculationJob = require('../../../../../lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob'); +import { expect, knex } from '../../../../test-helper.js'; +import { ParticipationResultCalculationJob } from '../../../../../lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob.js'; describe('Integration | Infrastructure | Jobs | CampaignResult | ParticipationResultCalculation', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob_test.js b/api/tests/integration/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob_test.js index 81b95237674..8025807a25a 100644 --- a/api/tests/integration/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob_test.js +++ b/api/tests/integration/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob_test.js @@ -1,5 +1,5 @@ -const { expect, knex } = require('../../../../test-helper'); -const SendSharedParticipationResultsToPoleEmploiJob = require('../../../../../lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob'); +import { expect, knex } from '../../../../test-helper.js'; +import { SendSharedParticipationResultsToPoleEmploiJob } from '../../../../../lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob.js'; describe('Integration | Infrastructure | Jobs | CampaignResult | ParticipationResultCalculation', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/jobs/cpf-export/handlers/create-and-upload_test.js b/api/tests/integration/infrastructure/jobs/cpf-export/handlers/create-and-upload_test.js index ce26d1280fc..871e1d18ffc 100644 --- a/api/tests/integration/infrastructure/jobs/cpf-export/handlers/create-and-upload_test.js +++ b/api/tests/integration/infrastructure/jobs/cpf-export/handlers/create-and-upload_test.js @@ -1,16 +1,22 @@ -const { domainBuilder, expect, sinon } = require('../../../../../test-helper'); -const createAndUpload = require('../../../../../../lib/infrastructure/jobs/cpf-export/handlers/create-and-upload'); -const { createUnzip } = require('node:zlib'); -const fs = require('fs'); -const noop = require('lodash/noop'); -const proxyquire = require('proxyquire'); -const dayjs = require('dayjs'); -const utc = require('dayjs/plugin/utc'); -const timezone = require('dayjs/plugin/timezone'); +import { domainBuilder, expect, sinon } from '../../../../../test-helper.js'; +import { createAndUpload } from '../../../../../../lib/infrastructure/jobs/cpf-export/handlers/create-and-upload.js'; +import * as cpfCertificationXmlExportService from '../../../../../../lib/domain/services/cpf-certification-xml-export-service.js'; +import { createUnzip } from 'node:zlib'; + +import fs from 'fs'; +import lodash from 'lodash'; +const { noop } = lodash; +import dayjs from 'dayjs'; +import utc from 'dayjs/plugin/utc.js'; +import timezone from 'dayjs/plugin/timezone.js'; dayjs.extend(utc); dayjs.extend(timezone); -const { PassThrough } = require('stream'); +import stream from 'stream'; +const { PassThrough } = stream; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | Infrastructure | jobs | cpf-export | create-and-upload', function () { let cpfCertificationResultRepository; @@ -18,11 +24,13 @@ describe('Integration | Infrastructure | jobs | cpf-export | create-and-upload', let clock; const expectedFileName = 'pix-cpf-export-20220102-114327.xml.gz'; let logger; + let uuidService; beforeEach(function () { const now = dayjs('2022-01-02T10:43:27Z').tz('Europe/Paris').toDate(); clock = sinon.useFakeTimers(now); logger = { error: noop, info: noop }; + uuidService = { v4: sinon.stub() }; }); afterEach(function () { @@ -49,14 +57,7 @@ describe('Integration | Infrastructure | jobs | cpf-export | create-and-upload', cpfCertificationResultRepository.findByBatchId.withArgs(batchId).resolves(cpfCertificationResults); - const cpfCertificationXmlExportService = proxyquire( - '../../../../../../lib/domain/services/cpf-certification-xml-export-service', - { - uuid: { - v4: () => 'xxx-yyy-zzz', - }, - } - ); + uuidService.v4.returns('xxx-yyy-zzz'); cpfExternalStorage.upload .withArgs({ @@ -77,6 +78,7 @@ describe('Integration | Infrastructure | jobs | cpf-export | create-and-upload', cpfCertificationXmlExportService, cpfExternalStorage, logger, + uuidService, }); // then diff --git a/api/tests/integration/infrastructure/knex-database-connection_test.js b/api/tests/integration/infrastructure/knex-database-connection_test.js index aa9fd42f17f..3d3d2a4dd73 100644 --- a/api/tests/integration/infrastructure/knex-database-connection_test.js +++ b/api/tests/integration/infrastructure/knex-database-connection_test.js @@ -1,10 +1,8 @@ -const { expect, databaseBuilder } = require('../../test-helper'); +import { expect, databaseBuilder } from '../../test-helper.js'; +import { knex, emptyAllTables } from '../../../db/knex-database-connection.js'; -const knexDatabaseConnection = require('../../../db/knex-database-connection'); -const knex = knexDatabaseConnection.knex; - -const { UserNotFoundError } = require('../../../lib/domain/errors'); -const userRepository = require('../../../lib/infrastructure/repositories/user-repository'); +import { UserNotFoundError } from '../../../lib/domain/errors.js'; +import * as userRepository from '../../../lib/infrastructure/repositories/user-repository.js'; describe('Integration | Infrastructure | knex-database-connection', function () { it('should connect to the database', async function () { @@ -21,7 +19,7 @@ describe('Integration | Infrastructure | knex-database-connection', function () await databaseBuilder.commit(); // when - await knexDatabaseConnection.emptyAllTables(); + await emptyAllTables(); // then await expect(userRepository.get(id)).to.be.rejectedWith(UserNotFoundError); diff --git a/api/tests/integration/infrastructure/knex-database-performance-monitoring_test.js b/api/tests/integration/infrastructure/knex-database-performance-monitoring_test.js index eaa1ebdebac..a464cec9a68 100644 --- a/api/tests/integration/infrastructure/knex-database-performance-monitoring_test.js +++ b/api/tests/integration/infrastructure/knex-database-performance-monitoring_test.js @@ -1,8 +1,7 @@ -const { expect, sinon } = require('../../test-helper'); -const knexDatabaseConnection = require('../../../db/knex-database-connection'); -const knex = knexDatabaseConnection.knex; -const { asyncLocalStorageForTests: asyncLocalStorage } = require('../../../lib/infrastructure/monitoring-tools.js'); -const config = require('../../../lib/config'); +import { expect, sinon } from '../../test-helper.js'; +import { knex } from '../../../db/knex-database-connection.js'; +import { asyncLocalStorage } from '../../../lib/infrastructure/monitoring-tools.js'; +import { config } from '../../../lib/config.js'; const selectQuery = knex.raw('SELECT 1 as value'); describe('Integration | Infrastructure | knex-database-performance-monitoring', function () { diff --git a/api/tests/integration/infrastructure/plugins/pino_test.js b/api/tests/integration/infrastructure/plugins/pino_test.js index 859add6e2e0..6441df28c26 100644 --- a/api/tests/integration/infrastructure/plugins/pino_test.js +++ b/api/tests/integration/infrastructure/plugins/pino_test.js @@ -1,9 +1,9 @@ -const split = require('split2'); -const writeStream = require('flush-write-stream'); -const config = require('../../../../lib/config'); -const { expect, HttpTestServer, generateValidRequestAuthorizationHeader, sinon } = require('../../../test-helper'); -const pinoPlugin = require('../../../../lib/infrastructure/plugins/pino'); -const monitoringTools = require('../../../../lib/infrastructure/monitoring-tools'); +import split from 'split2'; +import writeStream from 'flush-write-stream'; +import { config } from '../../../../lib/config.js'; +import { expect, HttpTestServer, generateValidRequestAuthorizationHeader, sinon } from '../../../test-helper.js'; +import * as pinoPlugin from '../../../../lib/infrastructure/plugins/pino.js'; +import { monitoringTools } from '../../../../lib/infrastructure/monitoring-tools.js'; function sink(func) { const result = split(JSON.parse); diff --git a/api/tests/integration/infrastructure/repositories/account-recovery-demand-repository_test.js b/api/tests/integration/infrastructure/repositories/account-recovery-demand-repository_test.js index 7ab2b2882c8..1dd9a2b9ce9 100644 --- a/api/tests/integration/infrastructure/repositories/account-recovery-demand-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/account-recovery-demand-repository_test.js @@ -1,9 +1,10 @@ -const { expect, knex, databaseBuilder, domainBuilder, catchErr } = require('../../../test-helper'); -const accountRecoveryDemandRepository = require('../../../../lib/infrastructure/repositories/account-recovery-demand-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const AccountRecoveryDemand = require('../../../../lib/domain/models/AccountRecoveryDemand'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const omit = require('lodash/omit'); +import { expect, knex, databaseBuilder, domainBuilder, catchErr } from '../../../test-helper.js'; +import * as accountRecoveryDemandRepository from '../../../../lib/infrastructure/repositories/account-recovery-demand-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { AccountRecoveryDemand } from '../../../../lib/domain/models/AccountRecoveryDemand.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import lodash from 'lodash'; +const { omit } = lodash; describe('Integration | Infrastructure | Repository | account-recovery-demand-repository', function () { afterEach(function () { diff --git a/api/tests/integration/infrastructure/repositories/admin-member-repository_test.js b/api/tests/integration/infrastructure/repositories/admin-member-repository_test.js index f20ae34fe73..d67c210c40d 100644 --- a/api/tests/integration/infrastructure/repositories/admin-member-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/admin-member-repository_test.js @@ -1,9 +1,12 @@ -const sinon = require('sinon'); -const { expect, databaseBuilder, knex, catchErr } = require('../../../test-helper'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; -const adminMemberRepository = require('../../../../lib/infrastructure/repositories/admin-member-repository'); -const AdminMember = require('../../../../lib/domain/models/AdminMember'); -const { AdminMemberError } = require('../../../../lib/domain/errors'); +import sinon from 'sinon'; +import { expect, databaseBuilder, knex, catchErr } from '../../../test-helper.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; + +import * as adminMemberRepository from '../../../../lib/infrastructure/repositories/admin-member-repository.js'; +import { AdminMember } from '../../../../lib/domain/models/AdminMember.js'; +import { AdminMemberError } from '../../../../lib/domain/errors.js'; describe('Integration | Infrastructure | Repository | adminMemberRepository', function () { describe('#findAll', function () { diff --git a/api/tests/integration/infrastructure/repositories/answer-repository_test.js b/api/tests/integration/infrastructure/repositories/answer-repository_test.js index 5f675d67651..ac6aa01781a 100644 --- a/api/tests/integration/infrastructure/repositories/answer-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/answer-repository_test.js @@ -1,8 +1,8 @@ -const { expect, knex, domainBuilder, databaseBuilder, catchErr } = require('../../../test-helper'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const { ChallengeAlreadyAnsweredError, NotFoundError } = require('../../../../lib/domain/errors'); -const answerRepository = require('../../../../lib/infrastructure/repositories/answer-repository'); +import { expect, knex, domainBuilder, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { ChallengeAlreadyAnsweredError, NotFoundError } from '../../../../lib/domain/errors.js'; +import * as answerRepository from '../../../../lib/infrastructure/repositories/answer-repository.js'; describe('Integration | Repository | answerRepository', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/area-repository_test.js b/api/tests/integration/infrastructure/repositories/area-repository_test.js index 722bdb4f653..a5e17ad6716 100644 --- a/api/tests/integration/infrastructure/repositories/area-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/area-repository_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, domainBuilder, mockLearningContent, catchErr } = require('../../../test-helper'); -const Area = require('../../../../lib/domain/models/Area'); -const areaRepository = require('../../../../lib/infrastructure/repositories/area-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import _ from 'lodash'; +import { expect, domainBuilder, mockLearningContent, catchErr } from '../../../test-helper.js'; +import { Area } from '../../../../lib/domain/models/Area.js'; +import * as areaRepository from '../../../../lib/infrastructure/repositories/area-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | area-repository', function () { describe('#list', function () { diff --git a/api/tests/integration/infrastructure/repositories/assessment-repository_test.js b/api/tests/integration/infrastructure/repositories/assessment-repository_test.js index f5ead258730..04331d0435c 100644 --- a/api/tests/integration/infrastructure/repositories/assessment-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/assessment-repository_test.js @@ -1,11 +1,11 @@ -const { expect, knex, databaseBuilder, domainBuilder, catchErr } = require('../../../test-helper'); -const _ = require('lodash'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const assessmentRepository = require('../../../../lib/infrastructure/repositories/assessment-repository'); -const Answer = require('../../../../lib/domain/models/Answer'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); +import { expect, knex, databaseBuilder, domainBuilder, catchErr } from '../../../test-helper.js'; +import _ from 'lodash'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as assessmentRepository from '../../../../lib/infrastructure/repositories/assessment-repository.js'; +import { Answer } from '../../../../lib/domain/models/Answer.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; describe('Integration | Infrastructure | Repositories | assessment-repository', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/repositories/assessment-result-repository_test.js b/api/tests/integration/infrastructure/repositories/assessment-result-repository_test.js index fa644bc2283..ddbc2b4e633 100644 --- a/api/tests/integration/infrastructure/repositories/assessment-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/assessment-result-repository_test.js @@ -1,8 +1,8 @@ -const { expect, knex, databaseBuilder, domainBuilder, catchErr } = require('../../../test-helper'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const assessmentResultRepository = require('../../../../lib/infrastructure/repositories/assessment-result-repository'); -const { MissingAssessmentId } = require('../../../../lib/domain/errors'); +import { expect, knex, databaseBuilder, domainBuilder, catchErr } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import * as assessmentResultRepository from '../../../../lib/infrastructure/repositories/assessment-result-repository.js'; +import { MissingAssessmentId } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | AssessmentResult', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/authentication-method-repository_test.js b/api/tests/integration/infrastructure/repositories/authentication-method-repository_test.js index 45c95a457a5..224628bca13 100644 --- a/api/tests/integration/infrastructure/repositories/authentication-method-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/authentication-method-repository_test.js @@ -1,9 +1,9 @@ -const { catchErr, databaseBuilder, domainBuilder, expect, knex, sinon } = require('../../../test-helper'); -const { AlreadyExistingEntityError, AuthenticationMethodNotFoundError } = require('../../../../lib/domain/errors'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); -const authenticationMethodRepository = require('../../../../lib/infrastructure/repositories/authentication-method-repository'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { catchErr, databaseBuilder, domainBuilder, expect, knex, sinon } from '../../../test-helper.js'; +import { AlreadyExistingEntityError, AuthenticationMethodNotFoundError } from '../../../../lib/domain/errors.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; +import * as authenticationMethodRepository from '../../../../lib/infrastructure/repositories/authentication-method-repository.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Integration | Repository | AuthenticationMethod', function () { const hashedPassword = 'ABCDEF1234'; diff --git a/api/tests/integration/infrastructure/repositories/badge-acquisition-repository_test.js b/api/tests/integration/infrastructure/repositories/badge-acquisition-repository_test.js index 3ef10158c16..9dfa9f586e2 100644 --- a/api/tests/integration/infrastructure/repositories/badge-acquisition-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/badge-acquisition-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const _ = require('lodash'); -const badgeAcquisitionRepository = require('../../../../lib/infrastructure/repositories/badge-acquisition-repository'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import _ from 'lodash'; +import * as badgeAcquisitionRepository from '../../../../lib/infrastructure/repositories/badge-acquisition-repository.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Integration | Repository | Badge Acquisition', function () { describe('#createOrUpdate', function () { diff --git a/api/tests/integration/infrastructure/repositories/badge-criteria-repository_test.js b/api/tests/integration/infrastructure/repositories/badge-criteria-repository_test.js index d807058416a..88b834d8650 100644 --- a/api/tests/integration/infrastructure/repositories/badge-criteria-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/badge-criteria-repository_test.js @@ -1,7 +1,8 @@ -const { knex, expect, databaseBuilder } = require('../../../test-helper'); -const badgeCriteriaRepository = require('../../../../lib/infrastructure/repositories/badge-criteria-repository'); -const omit = require('lodash/omit'); -const BadgeCriterion = require('../../../../lib/domain/models/BadgeCriterion'); +import { knex, expect, databaseBuilder } from '../../../test-helper.js'; +import * as badgeCriteriaRepository from '../../../../lib/infrastructure/repositories/badge-criteria-repository.js'; +import lodash from 'lodash'; +const { omit } = lodash; +import { BadgeCriterion } from '../../../../lib/domain/models/BadgeCriterion.js'; describe('Integration | Repository | Badge Criteria Repository', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/repositories/badge-for-calculation-repository_test.js b/api/tests/integration/infrastructure/repositories/badge-for-calculation-repository_test.js index ac4d25bbae0..cb5295effcb 100644 --- a/api/tests/integration/infrastructure/repositories/badge-for-calculation-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/badge-for-calculation-repository_test.js @@ -1,12 +1,13 @@ -const { +import { expect, databaseBuilder, domainBuilder, mockLearningContent, learningContentBuilder, -} = require('../../../test-helper'); -const badgeForCalculationRepository = require('../../../../lib/infrastructure/repositories/badge-for-calculation-repository'); -const BadgeCriterion = require('../../../../lib/domain/models/BadgeCriterion'); +} from '../../../test-helper.js'; + +import * as badgeForCalculationRepository from '../../../../lib/infrastructure/repositories/badge-for-calculation-repository.js'; +import { BadgeCriterion } from '../../../../lib/domain/models/BadgeCriterion.js'; describe('Integration | Repository | BadgeForCalculation', function () { const campaignSkillsId = [ @@ -99,7 +100,7 @@ describe('Integration | Repository | BadgeForCalculation', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); targetProfileId = databaseBuilder.factory.buildTargetProfile().id; campaignId = databaseBuilder.factory.buildCampaign({ targetProfileId }).id; diff --git a/api/tests/integration/infrastructure/repositories/badge-repository_test.js b/api/tests/integration/infrastructure/repositories/badge-repository_test.js index 25b22a30163..b2b42805b48 100644 --- a/api/tests/integration/infrastructure/repositories/badge-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/badge-repository_test.js @@ -1,10 +1,11 @@ -const { expect, databaseBuilder, knex, catchErr } = require('../../../test-helper'); -const badgeRepository = require('../../../../lib/infrastructure/repositories/badge-repository'); -const Badge = require('../../../../lib/domain/models/Badge'); -const BadgeCriterion = require('../../../../lib/domain/models/BadgeCriterion'); -const SkillSet = require('../../../../lib/domain/models/SkillSet'); -const omit = require('lodash/omit'); -const { AlreadyExistingEntityError } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, knex, catchErr } from '../../../test-helper.js'; +import * as badgeRepository from '../../../../lib/infrastructure/repositories/badge-repository.js'; +import { Badge } from '../../../../lib/domain/models/Badge.js'; +import { BadgeCriterion } from '../../../../lib/domain/models/BadgeCriterion.js'; +import { SkillSet } from '../../../../lib/domain/models/SkillSet.js'; +import lodash from 'lodash'; +const { omit } = lodash; +import { AlreadyExistingEntityError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | Badge', function () { let targetProfileWithSkillSets; @@ -499,7 +500,7 @@ describe('Integration | Repository | Badge', function () { await databaseBuilder.commit(); // when - const isDeleted = await badgeRepository.delete(badgeId); + const isDeleted = await badgeRepository.remove(badgeId); // then expect(isDeleted).to.be.true; @@ -511,7 +512,7 @@ describe('Integration | Repository | Badge', function () { const badgeId = badgeWithSameTargetProfile_1.id; const badgeRowsCountBeforeDeletion = await knex('badges').where({ id: badgeId }).count(); // when - await badgeRepository.delete(badgeId); + await badgeRepository.remove(badgeId); const badgeRowsCountAfterDeletion = await knex('badges').where({ id: badgeId }).count(); // then @@ -525,7 +526,7 @@ describe('Integration | Repository | Badge', function () { const badgeId = badgeWithSameTargetProfile_1.id; // when - const isDeleted = await badgeRepository.delete(badgeId); + const isDeleted = await badgeRepository.remove(badgeId); // then const badge = await knex.select().from('badges').where({ id: badgeId }).first(); diff --git a/api/tests/integration/infrastructure/repositories/campaign-analysis-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-analysis-repository_test.js index ce3ce3681ad..af35697c060 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-analysis-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-analysis-repository_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, domainBuilder, knex } = require('../../../test-helper'); -const campaignAnalysisRepository = require('../../../../lib/infrastructure/repositories/campaign-analysis-repository'); -const CampaignAnalysis = require('../../../../lib/domain/read-models/CampaignAnalysis'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import _ from 'lodash'; +import { expect, databaseBuilder, domainBuilder, knex } from '../../../test-helper.js'; +import * as campaignAnalysisRepository from '../../../../lib/infrastructure/repositories/campaign-analysis-repository.js'; +import { CampaignAnalysis } from '../../../../lib/domain/read-models/CampaignAnalysis.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED, SHARED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-repository_test.js index 07085caf94a..3e5f22bae24 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-repository_test.js @@ -1,10 +1,10 @@ -const { expect, databaseBuilder, mockLearningContent, knex, catchErr } = require('../../../test-helper'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const CampaignAssessmentParticipation = require('../../../../lib/domain/read-models/CampaignAssessmentParticipation'); -const campaignAssessmentParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-assessment-participation-repository'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, mockLearningContent, knex, catchErr } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { CampaignAssessmentParticipation } from '../../../../lib/domain/read-models/CampaignAssessmentParticipation.js'; +import * as campaignAssessmentParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-assessment-participation-repository.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-result-list-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-result-list-repository_test.js index c0989578b7f..6e727b5f027 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-result-list-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-result-list-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, knex, mockLearningContent, learningContentBuilder } = require('../../../test-helper'); -const campaignAssessmentParticipationResultListRepository = require('../../../../lib/infrastructure/repositories/campaign-assessment-participation-result-list-repository'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder, knex, mockLearningContent, learningContentBuilder } from '../../../test-helper.js'; +import * as campaignAssessmentParticipationResultListRepository from '../../../../lib/infrastructure/repositories/campaign-assessment-participation-result-list-repository.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; @@ -55,7 +55,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -110,7 +110,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -156,7 +156,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -213,7 +213,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -261,7 +261,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -307,7 +307,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -365,7 +365,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); // when @@ -408,7 +408,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -523,7 +523,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); // when @@ -568,7 +568,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); it('returns participants which have one badge', async function () { @@ -721,7 +721,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); @@ -1007,7 +1007,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); // when @@ -1046,7 +1046,7 @@ describe('Integration | Repository | Campaign Assessment Participation Result Li ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-result-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-result-repository_test.js index cc1ddbb56d4..a75668ba6be 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-assessment-participation-result-repository_test.js @@ -1,8 +1,11 @@ -const { expect, databaseBuilder, mockLearningContent, knex, catchErr } = require('../../../test-helper'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const campaignAssessmentParticipationResultRepository = require('../../../../lib/infrastructure/repositories/campaign-assessment-participation-result-repository'); -const { ENGLISH_SPOKEN, FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, mockLearningContent, knex, catchErr } from '../../../test-helper.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import * as campaignAssessmentParticipationResultRepository from '../../../../lib/infrastructure/repositories/campaign-assessment-participation-result-repository.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { ENGLISH_SPOKEN, FRENCH_SPOKEN } = LOCALE; + +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | Campaign Assessment Participation Result', function () { describe('#getByCampaignIdAndCampaignParticipationId', function () { diff --git a/api/tests/integration/infrastructure/repositories/campaign-collective-result-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-collective-result-repository_test.js index 9f134889996..4f62e4b2e8c 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-collective-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-collective-result-repository_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, domainBuilder, knex } = require('../../../test-helper'); -const campaignCollectiveResultRepository = require('../../../../lib/infrastructure/repositories/campaign-collective-result-repository'); -const CampaignCollectiveResult = require('../../../../lib/domain/read-models/CampaignCollectiveResult'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import _ from 'lodash'; +import { expect, databaseBuilder, domainBuilder, knex } from '../../../test-helper.js'; +import * as campaignCollectiveResultRepository from '../../../../lib/infrastructure/repositories/campaign-collective-result-repository.js'; +import { CampaignCollectiveResult } from '../../../../lib/domain/read-models/CampaignCollectiveResult.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-creator-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-creator-repository_test.js index 296ec862178..7fd9ff118cd 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-creator-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-creator-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const campaignCreatorRepository = require('../../../../lib/infrastructure/repositories/campaign-creator-repository'); -const { UserNotAuthorizedToCreateCampaignError } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import * as campaignCreatorRepository from '../../../../lib/infrastructure/repositories/campaign-creator-repository.js'; +import { UserNotAuthorizedToCreateCampaignError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | CampaignCreatorRepository', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/campaign-management-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-management-repository_test.js index b189f20dbef..83c1e90758e 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-management-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-management-repository_test.js @@ -1,9 +1,9 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const campaignManagementRepository = require('../../../../lib/infrastructure/repositories/campaign-management-repository'); -const _ = require('lodash'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const { knex } = require('../../../../lib/infrastructure/bookshelf'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as campaignManagementRepository from '../../../../lib/infrastructure/repositories/campaign-management-repository.js'; +import _ from 'lodash'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { knex } from '../../../../lib/infrastructure/bookshelf.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED, TO_SHARE, STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-participant-activity-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-participant-activity-repository_test.js index e8835b7fb1e..047453588ab 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-participant-activity-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-participant-activity-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const campaignParticipantActivityRepository = require('../../../../lib/infrastructure/repositories/campaign-participant-activity-repository'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { campaignParticipantActivityRepository } from '../../../../lib/infrastructure/repositories/campaign-participant-activity-repository.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED, SHARED, TO_SHARE } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-participant-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-participant-repository_test.js index 21ff234ee88..42d14e0f3be 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-participant-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-participant-repository_test.js @@ -1,11 +1,12 @@ -const { expect, databaseBuilder, mockLearningContent, catchErr } = require('../../../test-helper'); -const { knex } = require('../../../../db/knex-database-connection'); -const campaignParticipantRepository = require('../../../../lib/infrastructure/repositories/campaign-participant-repository'); -const CampaignParticipant = require('../../../../lib/domain/models/CampaignParticipant'); -const CampaignToStartParticipation = require('../../../../lib/domain/models/CampaignToStartParticipation'); -const pick = require('lodash/pick'); -const { AlreadyExistingCampaignParticipationError, NotFoundError } = require('../../../../lib/domain/errors'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { expect, databaseBuilder, mockLearningContent, catchErr } from '../../../test-helper.js'; +import { knex } from '../../../../db/knex-database-connection.js'; +import * as campaignParticipantRepository from '../../../../lib/infrastructure/repositories/campaign-participant-repository.js'; +import { CampaignParticipant } from '../../../../lib/domain/models/CampaignParticipant.js'; +import { CampaignToStartParticipation } from '../../../../lib/domain/models/CampaignToStartParticipation.js'; +import lodash from 'lodash'; +const { pick } = lodash; +import { AlreadyExistingCampaignParticipationError, NotFoundError } from '../../../../lib/domain/errors.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; const campaignParticipationDBAttributes = [ 'id', 'campaignId', diff --git a/api/tests/integration/infrastructure/repositories/campaign-participation-info-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-participation-info-repository_test.js index bc328230098..03dbf67a5b3 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-participation-info-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-participation-info-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const campaignParticipationInfoRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-info-repository'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import * as campaignParticipationInfoRepository from '../../../../lib/infrastructure/repositories/campaign-participation-info-repository.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-participation-overview-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-participation-overview-repository_test.js index 89131c0331d..523e8d4f175 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-participation-overview-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-participation-overview-repository_test.js @@ -1,16 +1,17 @@ -const { +import { expect, databaseBuilder, mockLearningContent, learningContentBuilder, domainBuilder, -} = require('../../../test-helper'); +} from '../../../test-helper.js'; + const { campaignParticipationOverviewFactory } = databaseBuilder.factory; -const Assessment = require('../../../../lib/domain/models/Assessment'); -const campaignParticipationOverviewRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-overview-repository'); -const _ = require('lodash'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import * as campaignParticipationOverviewRepository from '../../../../lib/infrastructure/repositories/campaign-participation-overview-repository.js'; +import _ from 'lodash'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; let userId; @@ -39,7 +40,7 @@ describe('Integration | Repository | Campaign Participation Overview', function ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); targetProfile = databaseBuilder.factory.buildTargetProfile(); databaseBuilder.factory.buildStage({ targetProfileId: targetProfile.id }); diff --git a/api/tests/integration/infrastructure/repositories/campaign-participation-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-participation-repository_test.js index ec43581d8cc..3bb21c8b6d9 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-participation-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-participation-repository_test.js @@ -1,13 +1,13 @@ -const _ = require('lodash'); -const { sinon, expect, knex, databaseBuilder, catchErr } = require('../../../test-helper'); -const Campaign = require('../../../../lib/domain/models/Campaign'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const CampaignParticipation = require('../../../../lib/domain/models/CampaignParticipation'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const campaignParticipationRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-repository'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import _ from 'lodash'; +import { sinon, expect, knex, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { Campaign } from '../../../../lib/domain/models/Campaign.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { CampaignParticipation } from '../../../../lib/domain/models/CampaignParticipation.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import * as campaignParticipationRepository from '../../../../lib/infrastructure/repositories/campaign-participation-repository.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; const { STARTED, SHARED, TO_SHARE } = CampaignParticipationStatuses; @@ -1351,7 +1351,7 @@ describe('Integration | Repository | Campaign Participation', function () { campaignParticipation.deletedBy = ownerId; await DomainTransaction.execute((domainTransaction) => { - return campaignParticipationRepository.delete({ + return campaignParticipationRepository.remove({ id: campaignParticipation.id, deletedAt: campaignParticipation.deletedAt, deletedBy: campaignParticipation.deletedBy, diff --git a/api/tests/integration/infrastructure/repositories/campaign-participation-result-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-participation-result-repository_test.js index 1b52af04550..80abdbde946 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-participation-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-participation-result-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, mockLearningContent } = require('../../../test-helper'); -const campaignParticipationResultRepository = require('../../../../lib/infrastructure/repositories/campaign-participation-result-repository'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder, mockLearningContent } from '../../../test-helper.js'; +import { campaignParticipationResultRepository } from '../../../../lib/infrastructure/repositories/campaign-participation-result-repository.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-participations-stats-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-participations-stats-repository_test.js index ee3c4c8f940..71ae106ba1e 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-participations-stats-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-participations-stats-repository_test.js @@ -1,6 +1,6 @@ -const campaignParticipationsStatsRepository = require('../../../../lib/infrastructure/repositories/campaign-participations-stats-repository'); -const { expect, databaseBuilder } = require('../../../test-helper'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { CampaignParticipationsStatsRepository as campaignParticipationsStatsRepository } from '../../../../lib/infrastructure/repositories/campaign-participations-stats-repository.js'; +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-profile-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-profile-repository_test.js index 217623453b5..5e57c35f435 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-profile-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-profile-repository_test.js @@ -1,8 +1,9 @@ -const { expect, databaseBuilder, mockLearningContent, catchErr } = require('../../../test-helper'); -const CampaignProfileRepository = require('../../../../lib/infrastructure/repositories/campaign-profile-repository'); -const { PIX_COUNT_BY_LEVEL } = require('../../../../lib/domain/constants'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const { ENGLISH_SPOKEN, FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { expect, databaseBuilder, mockLearningContent, catchErr } from '../../../test-helper.js'; +import * as CampaignProfileRepository from '../../../../lib/infrastructure/repositories/campaign-profile-repository.js'; +import { PIX_COUNT_BY_LEVEL, LOCALE } from '../../../../lib/domain/constants.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; + +const { ENGLISH_SPOKEN, FRENCH_SPOKEN } = LOCALE; describe('Integration | Repository | CampaignProfileRepository', function () { const locale = FRENCH_SPOKEN; diff --git a/api/tests/integration/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository_test.js index 3a0befa96f4..3379c4af059 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, mockLearningContent, knex } = require('../../../test-helper'); -const CampaignProfilesCollectionParticipationSummary = require('../../../../lib/domain/read-models/CampaignProfilesCollectionParticipationSummary'); -const campaignProfilesCollectionParticipationSummaryRepository = require('../../../../lib/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder, mockLearningContent, knex } from '../../../test-helper.js'; +import { CampaignProfilesCollectionParticipationSummary } from '../../../../lib/domain/read-models/CampaignProfilesCollectionParticipationSummary.js'; +import * as campaignProfilesCollectionParticipationSummaryRepository from '../../../../lib/infrastructure/repositories/campaign-profiles-collection-participation-summary-repository.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-report-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-report-repository_test.js index 5590a1b2e2b..0398252d2ab 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-report-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-report-repository_test.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, catchErr, mockLearningContent } = require('../../../test-helper'); -const campaignReportRepository = require('../../../../lib/infrastructure/repositories/campaign-report-repository'); -const CampaignReport = require('../../../../lib/domain/read-models/CampaignReport'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import _ from 'lodash'; +import { expect, databaseBuilder, catchErr, mockLearningContent } from '../../../test-helper.js'; +import * as campaignReportRepository from '../../../../lib/infrastructure/repositories/campaign-report-repository.js'; +import { CampaignReport } from '../../../../lib/domain/read-models/CampaignReport.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED, SHARED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/campaign-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-repository_test.js index 36a117d6d1c..58167f98b42 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-repository_test.js @@ -1,4 +1,4 @@ -const { +import { expect, domainBuilder, databaseBuilder, @@ -6,13 +6,13 @@ const { mockLearningContent, sinon, catchErr, -} = require('../../../test-helper'); -const campaignRepository = require('../../../../lib/infrastructure/repositories/campaign-repository'); -const skillRepository = require('../../../../lib/infrastructure/repositories/skill-repository'); -const Campaign = require('../../../../lib/domain/models/Campaign'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const _ = require('lodash'); +} from '../../../test-helper.js'; + +import * as campaignRepository from '../../../../lib/infrastructure/repositories/campaign-repository.js'; +import { Campaign } from '../../../../lib/domain/models/Campaign.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import _ from 'lodash'; describe('Integration | Repository | Campaign', function () { describe('#isCodeAvailable', function () { @@ -277,8 +277,9 @@ describe('Integration | Repository | Campaign', function () { it('should not save anything if something goes wrong between campaign creation and skills computation', async function () { // given - const findActiveStub = sinon.stub(skillRepository, 'findActiveByTubeId'); - findActiveStub.rejects(new Error('Forcing rollback')); + const skillRepository = { + findActiveByTubeId: sinon.stub().rejects(new Error('Forcing rollback')), + }; const learningContent = { areas: [{ id: 'recArea1', competenceIds: ['recCompetence1'] }], competences: [ @@ -327,7 +328,7 @@ describe('Integration | Repository | Campaign', function () { }; // when - await catchErr(campaignRepository.save)(campaignToSave); + await catchErr(campaignRepository.save)(campaignToSave, { skillRepository }); // then const skillIds = await knex('campaign_skills').pluck('skillId'); diff --git a/api/tests/integration/infrastructure/repositories/campaign-to-join-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign-to-join-repository_test.js index 43706d11ac2..463e4a8a33c 100644 --- a/api/tests/integration/infrastructure/repositories/campaign-to-join-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign-to-join-repository_test.js @@ -1,9 +1,9 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const campaignToJoinRepository = require('../../../../lib/infrastructure/repositories/campaign-to-join-repository'); -const CampaignToJoin = require('../../../../lib/domain/read-models/CampaignToJoin'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import * as campaignToJoinRepository from '../../../../lib/infrastructure/repositories/campaign-to-join-repository.js'; +import { CampaignToJoin } from '../../../../lib/domain/read-models/CampaignToJoin.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; describe('Integration | Repository | CampaignToJoin', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/campaign/campaign-for-archiving-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign/campaign-for-archiving-repository_test.js index 98fa5cbea91..96f1635d4cc 100644 --- a/api/tests/integration/infrastructure/repositories/campaign/campaign-for-archiving-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign/campaign-for-archiving-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, catchErr } = require('../../../../test-helper'); -const campaignForArchivingRepository = require('../../../../../lib/infrastructure/repositories/campaign/campaign-for-archiving-repository'); -const Campaign = require('../../../../../lib/domain/models/CampaignForArchiving'); -const { NotFoundError, UserNotFoundError } = require('../../../../../lib/domain/errors'); +import { expect, databaseBuilder, catchErr } from '../../../../test-helper.js'; +import * as campaignForArchivingRepository from '../../../../../lib/infrastructure/repositories/campaign/campaign-for-archiving-repository.js'; +import { CampaignForArchiving as Campaign } from '../../../../../lib/domain/models/CampaignForArchiving.js'; +import { NotFoundError, UserNotFoundError } from '../../../../../lib/domain/errors.js'; describe('Integration | Infrastructure | Repository | campaign-for-archiving-repository', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/campaign/target-profile-for-specifier-repository_test.js b/api/tests/integration/infrastructure/repositories/campaign/target-profile-for-specifier-repository_test.js index f84522ee0fd..d1354dac444 100644 --- a/api/tests/integration/infrastructure/repositories/campaign/target-profile-for-specifier-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaign/target-profile-for-specifier-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder } = require('../../../../test-helper'); -const TargetProfileForSpecifierRepository = require('../../../../../lib/infrastructure/repositories/campaign/target-profile-for-specifier-repository'); -const TargetProfileForSpecifier = require('../../../../../lib/domain/read-models/campaign/TargetProfileForSpecifier'); -const { categories } = require('../../../../../lib/domain/models/TargetProfile'); +import { expect, databaseBuilder } from '../../../../test-helper.js'; +import * as TargetProfileForSpecifierRepository from '../../../../../lib/infrastructure/repositories/campaign/target-profile-for-specifier-repository.js'; +import { TargetProfileForSpecifier } from '../../../../../lib/domain/read-models/campaign/TargetProfileForSpecifier.js'; +import { categories } from '../../../../../lib/domain/models/TargetProfile.js'; describe('Integration | Infrastructure | Repository | target-profile-for-campaign-repository', function () { describe('#availableForOrganization', function () { diff --git a/api/tests/integration/infrastructure/repositories/campaigns-administration/campaign-repository_test.js b/api/tests/integration/infrastructure/repositories/campaigns-administration/campaign-repository_test.js index 54ff4689d06..b248d27bd41 100644 --- a/api/tests/integration/infrastructure/repositories/campaigns-administration/campaign-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/campaigns-administration/campaign-repository_test.js @@ -1,5 +1,5 @@ -const { expect, knex, databaseBuilder, sinon } = require('../../../../test-helper'); -const campaignRepository = require('../../../../../lib/infrastructure/repositories/campaigns-administration/campaign-repository'); +import { expect, knex, databaseBuilder, sinon } from '../../../../test-helper.js'; +import * as campaignRepository from '../../../../../lib/infrastructure/repositories/campaigns-administration/campaign-repository.js'; describe('Integration | Infrastructure | Repository | Campaign Administration | campaign-repository', function () { let clock; diff --git a/api/tests/integration/infrastructure/repositories/certifiable-badge-acquisition-repository_test.js b/api/tests/integration/infrastructure/repositories/certifiable-badge-acquisition-repository_test.js index 3f76b7724d1..2b5e405f768 100644 --- a/api/tests/integration/infrastructure/repositories/certifiable-badge-acquisition-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certifiable-badge-acquisition-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const certifiableBadgeAcquisitionRepository = require('../../../../lib/infrastructure/repositories/certifiable-badge-acquisition-repository'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as certifiableBadgeAcquisitionRepository from '../../../../lib/infrastructure/repositories/certifiable-badge-acquisition-repository.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Integration | Repository | Certifiable Badge Acquisition', function () { describe('#findHighestCertifiable', function () { diff --git a/api/tests/integration/infrastructure/repositories/certifiable-profile-for-learning-content-repository_test.js b/api/tests/integration/infrastructure/repositories/certifiable-profile-for-learning-content-repository_test.js index 51ada56d825..9cc80b456e9 100644 --- a/api/tests/integration/infrastructure/repositories/certifiable-profile-for-learning-content-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certifiable-profile-for-learning-content-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const certifiableProfileForLearningContentRepository = require('../../../../lib/infrastructure/repositories/certifiable-profile-for-learning-content-repository'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const CertifiableProfileForLearningContent = require('../../../../lib/domain/models/CertifiableProfileForLearningContent'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as certifiableProfileForLearningContentRepository from '../../../../lib/infrastructure/repositories/certifiable-profile-for-learning-content-repository.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { CertifiableProfileForLearningContent } from '../../../../lib/domain/models/CertifiableProfileForLearningContent.js'; describe('Integration | Repository | certifiable-profile-for-learning-content', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/certificate-repository_attestation_test.js b/api/tests/integration/infrastructure/repositories/certificate-repository_attestation_test.js index 301cda6d950..f7858104366 100644 --- a/api/tests/integration/infrastructure/repositories/certificate-repository_attestation_test.js +++ b/api/tests/integration/infrastructure/repositories/certificate-repository_attestation_test.js @@ -1,14 +1,15 @@ -const { +import { expect, databaseBuilder, domainBuilder, catchErr, learningContentBuilder, mockLearningContent, -} = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const certificationRepository = require('../../../../lib/infrastructure/repositories/certificate-repository'); -const { status } = require('../../../../lib/domain/models/AssessmentResult'); +} from '../../../test-helper.js'; + +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as certificationRepository from '../../../../lib/infrastructure/repositories/certificate-repository.js'; +import { status } from '../../../../lib/domain/models/AssessmentResult.js'; describe('Integration | Infrastructure | Repository | Certification Attestation', function () { const minimalLearningContent = [ @@ -189,7 +190,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should return a CertificationAttestation', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); const certificationAttestationData = { @@ -301,9 +302,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' framework: null, }); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ - { ...area1, title_i18n: { fr: area1.title } }, - ]); + const learningContentObjects = learningContentBuilder.fromAreas([{ ...area1, title_i18n: { fr: area1.title } }]); mockLearningContent(learningContentObjects); // when @@ -320,7 +319,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should take into account the latest validated assessment result of a student', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); const certificationAttestationData = { id: 123, @@ -365,7 +364,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' context('acquired certifiable badges', function () { it(`should get the certified badge images when the certifications were acquired`, async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); const certificationAttestationData = { id: 123, @@ -478,7 +477,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' describe('#findByDivisionForScoIsManagingStudentsOrganization', function () { it('should return an empty array when there are no certification attestations for given organization', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); databaseBuilder.factory.buildOrganization({ id: 456, type: 'SCO', isManagingStudents: true }); @@ -527,7 +526,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should return an empty array when the organization is not SCO IS MANAGING STUDENTS', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SUP', isManagingStudents: false }); const certificationAttestationData = { @@ -575,7 +574,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should return an empty array when the certification does not belong to an organization learner in the right division', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); const certificationAttestationData = { @@ -623,7 +622,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should not return certifications that have no validated assessment-result', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); const certificationAttestationData = { @@ -671,7 +670,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should not return cancelled certifications', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); const certificationAttestationData = { @@ -719,7 +718,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should not return non published certifications', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); const certificationAttestationData = { @@ -767,7 +766,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should return an array of certification attestations ordered by last name, first name', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); const certificationAttestationDataA = { @@ -891,7 +890,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should ignore disabled shooling-registrations', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); const certificationAttestationDataA = { @@ -1013,7 +1012,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' describe('when the last certification is rejected', function () { it('should take into account the latest valid certification', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); const certificationAttestationData = { @@ -1096,7 +1095,7 @@ describe('Integration | Infrastructure | Repository | Certification Attestation' it('should take into account the latest certification of an organization learner', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); databaseBuilder.factory.buildOrganization({ id: 123, type: 'SCO', isManagingStudents: true }); const organizationLearnerId = databaseBuilder.factory.buildOrganizationLearner({ diff --git a/api/tests/integration/infrastructure/repositories/certificate-repository_private_test.js b/api/tests/integration/infrastructure/repositories/certificate-repository_private_test.js index 3641a1ca5d5..af894b37d68 100644 --- a/api/tests/integration/infrastructure/repositories/certificate-repository_private_test.js +++ b/api/tests/integration/infrastructure/repositories/certificate-repository_private_test.js @@ -1,13 +1,14 @@ -const { +import { expect, databaseBuilder, domainBuilder, catchErr, learningContentBuilder, mockLearningContent, -} = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const certificateRepository = require('../../../../lib/infrastructure/repositories/certificate-repository'); +} from '../../../test-helper.js'; + +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as certificateRepository from '../../../../lib/infrastructure/repositories/certificate-repository.js'; describe('Integration | Infrastructure | Repository | Certificate_private', function () { const minimalLearningContent = [ @@ -247,7 +248,7 @@ describe('Integration | Infrastructure | Repository | Certificate_private', func it('should return a PrivateCertificate', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); const userId = databaseBuilder.factory.buildUser().id; @@ -349,7 +350,7 @@ describe('Integration | Infrastructure | Repository | Certificate_private', func framework: null, }); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContentObjects = learningContentBuilder.fromAreas([ { ...area1, title_i18n: { fr: area1.title, en: 'title en' }, @@ -460,7 +461,7 @@ describe('Integration | Infrastructure | Repository | Certificate_private', func framework: null, }); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContentObjects = learningContentBuilder.fromAreas([ { ...area1, title_i18n: { fr: area1.title, en: 'title en' }, @@ -525,7 +526,7 @@ describe('Integration | Infrastructure | Repository | Certificate_private', func hasExternalJury: true, }).id; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); const userId = databaseBuilder.factory.buildUser().id; diff --git a/api/tests/integration/infrastructure/repositories/certificate-repository_shareable_test.js b/api/tests/integration/infrastructure/repositories/certificate-repository_shareable_test.js index 97ab3ecb7a6..d586c22179f 100644 --- a/api/tests/integration/infrastructure/repositories/certificate-repository_shareable_test.js +++ b/api/tests/integration/infrastructure/repositories/certificate-repository_shareable_test.js @@ -1,13 +1,14 @@ -const { +import { expect, databaseBuilder, domainBuilder, catchErr, learningContentBuilder, mockLearningContent, -} = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const certificateRepository = require('../../../../lib/infrastructure/repositories/certificate-repository'); +} from '../../../test-helper.js'; + +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as certificateRepository from '../../../../lib/infrastructure/repositories/certificate-repository.js'; describe('Integration | Infrastructure | Repository | Shareable Certificate', function () { const minimalLearningContent = [ @@ -304,7 +305,7 @@ describe('Integration | Infrastructure | Repository | Shareable Certificate', fu framework: null, }); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContentObjects = learningContentBuilder.fromAreas([ { ...area1, title_i18n: { fr: area1.title, en: 'title en' }, @@ -416,7 +417,7 @@ describe('Integration | Infrastructure | Repository | Shareable Certificate', fu framework: null, }); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContentObjects = learningContentBuilder.fromAreas([ { ...area1, title_i18n: { fr: area1.title, en: 'title en' }, @@ -484,7 +485,7 @@ describe('Integration | Infrastructure | Repository | Shareable Certificate', fu hasExternalJury: true, }).id; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(minimalLearningContent); + const learningContentObjects = learningContentBuilder.fromAreas(minimalLearningContent); mockLearningContent(learningContentObjects); const userId = databaseBuilder.factory.buildUser().id; const shareableCertificateData = { diff --git a/api/tests/integration/infrastructure/repositories/certification-assessment-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-assessment-repository_test.js index fcf5e5c2f8b..3feb043f585 100644 --- a/api/tests/integration/infrastructure/repositories/certification-assessment-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-assessment-repository_test.js @@ -1,10 +1,10 @@ -const { expect, databaseBuilder, mockLearningContent, catchErr } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const certificationAssessmentRepository = require('../../../../lib/infrastructure/repositories/certification-assessment-repository'); -const CertificationAssessment = require('../../../../lib/domain/models/CertificationAssessment'); -const Challenge = require('../../../../lib/domain/models/Challenge'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const _ = require('lodash'); +import { expect, databaseBuilder, mockLearningContent, catchErr } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as certificationAssessmentRepository from '../../../../lib/infrastructure/repositories/certification-assessment-repository.js'; +import { CertificationAssessment } from '../../../../lib/domain/models/CertificationAssessment.js'; +import { Challenge } from '../../../../lib/domain/models/Challenge.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import _ from 'lodash'; describe('Integration | Infrastructure | Repositories | certification-assessment-repository', function () { beforeEach(function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-candidate-for-supervising-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-candidate-for-supervising-repository_test.js index c2ac04ecafb..e34564798b9 100644 --- a/api/tests/integration/infrastructure/repositories/certification-candidate-for-supervising-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-candidate-for-supervising-repository_test.js @@ -1,7 +1,7 @@ -const { catchErr, databaseBuilder, expect, knex, domainBuilder } = require('../../../test-helper'); -const certificationCandidateForSupervisingRepository = require('../../../../lib/infrastructure/repositories/certification-candidate-for-supervising-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { catchErr, databaseBuilder, expect, knex, domainBuilder } from '../../../test-helper.js'; +import * as certificationCandidateForSupervisingRepository from '../../../../lib/infrastructure/repositories/certification-candidate-for-supervising-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Integration | Repository | certification candidate for supervising', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-candidate-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-candidate-repository_test.js index a9d7346210e..ed24db044dd 100644 --- a/api/tests/integration/infrastructure/repositories/certification-candidate-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-candidate-repository_test.js @@ -1,12 +1,12 @@ -const { databaseBuilder, expect, knex, domainBuilder, catchErr } = require('../../../test-helper'); -const BookshelfCertificationCandidate = require('../../../../lib/infrastructure/orm-models/CertificationCandidate'); -const certificationCandidateRepository = require('../../../../lib/infrastructure/repositories/certification-candidate-repository'); -const { +import { databaseBuilder, expect, knex, domainBuilder, catchErr } from '../../../test-helper.js'; +import { BookshelfCertificationCandidate } from '../../../../lib/infrastructure/orm-models/CertificationCandidate.js'; +import * as certificationCandidateRepository from '../../../../lib/infrastructure/repositories/certification-candidate-repository.js'; +import { NotFoundError, CertificationCandidateMultipleUserLinksWithinSessionError, -} = require('../../../../lib/domain/errors'); -const ComplementaryCertification = require('../../../../lib/domain/models/ComplementaryCertification'); -const _ = require('lodash'); +} from '../../../../lib/domain/errors.js'; +import { ComplementaryCertification } from '../../../../lib/domain/models/ComplementaryCertification.js'; +import _ from 'lodash'; describe('Integration | Repository | CertificationCandidate', function () { describe('#saveInSession', function () { @@ -175,7 +175,7 @@ describe('Integration | Repository | CertificationCandidate', function () { it('should return true when deletion goes well', async function () { // when - const isDeleted = await certificationCandidateRepository.delete(certificationCandidateToDeleteId); + const isDeleted = await certificationCandidateRepository.remove(certificationCandidateToDeleteId); // then expect(isDeleted).to.be.true; @@ -184,7 +184,7 @@ describe('Integration | Repository | CertificationCandidate', function () { it('should delete a single row in the table', async function () { const nbCertifCandidatesBeforeDeletion = await BookshelfCertificationCandidate.count(); // when - await certificationCandidateRepository.delete(certificationCandidateToDeleteId); + await certificationCandidateRepository.remove(certificationCandidateToDeleteId); const nbCertifCandidatesAfterDeletion = await BookshelfCertificationCandidate.count(); // then @@ -204,7 +204,7 @@ describe('Integration | Repository | CertificationCandidate', function () { await databaseBuilder.commit(); // when - const isDeleted = await certificationCandidateRepository.delete(certificationCandidateId); + const isDeleted = await certificationCandidateRepository.remove(certificationCandidateId); // then const complementaryCertificationSubscriptions = await knex diff --git a/api/tests/integration/infrastructure/repositories/certification-center-for-admin-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-center-for-admin-repository_test.js index 6b5b8c30a9e..b3fc658c50c 100644 --- a/api/tests/integration/infrastructure/repositories/certification-center-for-admin-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-center-for-admin-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, domainBuilder, catchErr, sinon } = require('../../../test-helper'); -const certificationCenterForAdminRepository = require('../../../../lib/infrastructure/repositories/certification-center-for-admin-repository'); -const CertificationCenterForAdmin = require('../../../../lib/domain/models/CertificationCenterForAdmin'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, domainBuilder, catchErr, sinon } from '../../../test-helper.js'; +import * as certificationCenterForAdminRepository from '../../../../lib/infrastructure/repositories/certification-center-for-admin-repository.js'; +import { CertificationCenterForAdmin } from '../../../../lib/domain/models/CertificationCenterForAdmin.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | certification-center-for-admin', function () { let clock; diff --git a/api/tests/integration/infrastructure/repositories/certification-center-invited-user-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-center-invited-user-repository_test.js index 0552d9a403e..05bdf21887d 100644 --- a/api/tests/integration/infrastructure/repositories/certification-center-invited-user-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-center-invited-user-repository_test.js @@ -1,10 +1,12 @@ -const { omit } = require('lodash'); +import lodash from 'lodash'; -const { expect, databaseBuilder, catchErr, sinon, knex } = require('../../../test-helper'); -const certificationCenterInvitedUserRepository = require('../../../../lib/infrastructure/repositories/certification-center-invited-user-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); -const CertificationCenterInvitedUser = require('../../../../lib/domain/models/CertificationCenterInvitedUser'); +const { omit } = lodash; + +import { expect, databaseBuilder, catchErr, sinon, knex } from '../../../test-helper.js'; +import * as certificationCenterInvitedUserRepository from '../../../../lib/infrastructure/repositories/certification-center-invited-user-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; +import { CertificationCenterInvitedUser } from '../../../../lib/domain/models/CertificationCenterInvitedUser.js'; describe('Integration | Repository | CertificationCenterInvitedUserRepository', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-center-membership-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-center-membership-repository_test.js index c3546b24061..a02f4326bae 100644 --- a/api/tests/integration/infrastructure/repositories/certification-center-membership-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-center-membership-repository_test.js @@ -1,19 +1,17 @@ -const pick = require('lodash/pick'); -const omit = require('lodash/omit'); - -const { expect, knex, databaseBuilder, catchErr, sinon, domainBuilder } = require('../../../test-helper'); - -const BookshelfCertificationCenterMembership = require('../../../../lib/infrastructure/orm-models/CertificationCenterMembership'); -const CertificationCenter = require('../../../../lib/domain/models/CertificationCenter'); -const CertificationCenterMembership = require('../../../../lib/domain/models/CertificationCenterMembership'); -const User = require('../../../../lib/domain/models/User'); - -const { +import lodash from 'lodash'; +const { omit, pick } = lodash; + +import { expect, knex, databaseBuilder, catchErr, sinon, domainBuilder } from '../../../test-helper.js'; +import { BookshelfCertificationCenterMembership } from '../../../../lib/infrastructure/orm-models/CertificationCenterMembership.js'; +import { CertificationCenter } from '../../../../lib/domain/models/CertificationCenter.js'; +import { CertificationCenterMembership } from '../../../../lib/domain/models/CertificationCenterMembership.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { CertificationCenterMembershipDisableError, AlreadyExistingMembershipError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; -const certificationCenterMembershipRepository = require('../../../../lib/infrastructure/repositories/certification-center-membership-repository'); +import * as certificationCenterMembershipRepository from '../../../../lib/infrastructure/repositories/certification-center-membership-repository.js'; describe('Integration | Repository | Certification Center Membership', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-center-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-center-repository_test.js index eb71ff5befe..fc6cb4bb7a0 100644 --- a/api/tests/integration/infrastructure/repositories/certification-center-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-center-repository_test.js @@ -1,8 +1,8 @@ -const { expect, knex, databaseBuilder, domainBuilder, catchErr, sinon } = require('../../../test-helper'); -const certificationCenterRepository = require('../../../../lib/infrastructure/repositories/certification-center-repository'); -const CertificationCenter = require('../../../../lib/domain/models/CertificationCenter'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const _ = require('lodash'); +import { expect, knex, databaseBuilder, domainBuilder, catchErr, sinon } from '../../../test-helper.js'; +import * as certificationCenterRepository from '../../../../lib/infrastructure/repositories/certification-center-repository.js'; +import { CertificationCenter } from '../../../../lib/domain/models/CertificationCenter.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import _ from 'lodash'; describe('Integration | Repository | Certification Center', function () { let clock, now; diff --git a/api/tests/integration/infrastructure/repositories/certification-challenge-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-challenge-repository_test.js index f8d364bd110..8afb1693bd4 100644 --- a/api/tests/integration/infrastructure/repositories/certification-challenge-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-challenge-repository_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, knex, domainBuilder, databaseBuilder } = require('../../../test-helper'); -const CertificationChallenge = require('../../../../lib/domain/models/CertificationChallenge'); -const { AssessmentEndedError } = require('../../../../lib/domain/errors'); -const certificationChallengeRepository = require('../../../../lib/infrastructure/repositories/certification-challenge-repository'); +import _ from 'lodash'; +import { expect, knex, domainBuilder, databaseBuilder } from '../../../test-helper.js'; +import { CertificationChallenge } from '../../../../lib/domain/models/CertificationChallenge.js'; +import { AssessmentEndedError } from '../../../../lib/domain/errors.js'; +import * as certificationChallengeRepository from '../../../../lib/infrastructure/repositories/certification-challenge-repository.js'; describe('Integration | Repository | Certification Challenge', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-course-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-course-repository_test.js index a1df9bebdf5..b246875b983 100644 --- a/api/tests/integration/infrastructure/repositories/certification-course-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-course-repository_test.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const { catchErr, expect, databaseBuilder, domainBuilder, knex } = require('../../../test-helper'); -const certificationCourseRepository = require('../../../../lib/infrastructure/repositories/certification-course-repository'); -const BookshelfCertificationCourse = require('../../../../lib/infrastructure/orm-models/CertificationCourse'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const CertificationCourse = require('../../../../lib/domain/models/CertificationCourse'); +import _ from 'lodash'; +import { catchErr, expect, databaseBuilder, domainBuilder, knex } from '../../../test-helper.js'; +import * as certificationCourseRepository from '../../../../lib/infrastructure/repositories/certification-course-repository.js'; +import { BookshelfCertificationCourse } from '../../../../lib/infrastructure/orm-models/CertificationCourse.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { CertificationCourse } from '../../../../lib/domain/models/CertificationCourse.js'; describe('Integration | Repository | Certification Course', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-cpf-city-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-cpf-city-repository_test.js index a0faa94f080..b611b7b8d2e 100644 --- a/api/tests/integration/infrastructure/repositories/certification-cpf-city-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-cpf-city-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const certificationCpfCityRepository = require('../../../../lib/infrastructure/repositories/certification-cpf-city-repository'); -const CertificationCpfCity = require('../../../../lib/domain/models/CertificationCpfCity'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as certificationCpfCityRepository from '../../../../lib/infrastructure/repositories/certification-cpf-city-repository.js'; +import { CertificationCpfCity } from '../../../../lib/domain/models/CertificationCpfCity.js'; describe('Integration | Repository | certificationCpfCityRepository', function () { describe('#findByINSEECode', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-cpf-country-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-cpf-country-repository_test.js index 04ff46d7a9b..81552fff682 100644 --- a/api/tests/integration/infrastructure/repositories/certification-cpf-country-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-cpf-country-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const certificationCpfCountryRepository = require('../../../../lib/infrastructure/repositories/certification-cpf-country-repository'); -const CertificationCpfCountry = require('../../../../lib/domain/models/CertificationCpfCountry'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as certificationCpfCountryRepository from '../../../../lib/infrastructure/repositories/certification-cpf-country-repository.js'; +import { CertificationCpfCountry } from '../../../../lib/domain/models/CertificationCpfCountry.js'; describe('Integration | Repository | certificationCpfCountryRepository', function () { describe('#getByMatcher', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-issue-report-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-issue-report-repository_test.js index e8cece7b410..d61e7172563 100644 --- a/api/tests/integration/infrastructure/repositories/certification-issue-report-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-issue-report-repository_test.js @@ -1,11 +1,11 @@ -const _ = require('lodash'); -const { expect, domainBuilder, databaseBuilder, knex } = require('../../../test-helper'); -const certificationIssueReportRepository = require('../../../../lib/infrastructure/repositories/certification-issue-report-repository'); -const CertificationIssueReport = require('../../../../lib/domain/models/CertificationIssueReport'); -const { - CertificationIssueReportCategories, +import _ from 'lodash'; +import { expect, domainBuilder, databaseBuilder, knex } from '../../../test-helper.js'; +import * as certificationIssueReportRepository from '../../../../lib/infrastructure/repositories/certification-issue-report-repository.js'; +import { CertificationIssueReport } from '../../../../lib/domain/models/CertificationIssueReport.js'; +import { + CertificationIssueReportCategory, CertificationIssueReportSubcategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); +} from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; describe('Integration | Repository | Certification Issue Report', function () { afterEach(async function () { @@ -23,7 +23,7 @@ describe('Integration | Repository | Certification Issue Report', function () { const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ id: undefined, certificationCourseId, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, categoryId: null, description: 'Un gros problème', subcategory: CertificationIssueReportSubcategories.IMAGE_NOT_DISPLAYING, @@ -38,7 +38,7 @@ describe('Integration | Repository | Certification Issue Report', function () { // then const expectedSavedCertificationIssueReport = domainBuilder.buildCertificationIssueReport({ certificationCourseId, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, categoryId: null, description: 'Un gros problème', isActionRequired: true, @@ -61,16 +61,16 @@ describe('Integration | Repository | Certification Issue Report', function () { const certificationCourseId = databaseBuilder.factory.buildCertificationCourse().id; databaseBuilder.factory.buildIssueReportCategory({ id: 123, - name: CertificationIssueReportCategories.IN_CHALLENGE, + name: CertificationIssueReportCategory.IN_CHALLENGE, }); const categoryId = databaseBuilder.factory.buildIssueReportCategory({ issueReportCategoryId: 2, - name: CertificationIssueReportCategories.IMAGE_NOT_DISPLAYING, + name: CertificationIssueReportCategory.IMAGE_NOT_DISPLAYING, }).id; const certificationIssueReport = databaseBuilder.factory.buildCertificationIssueReport({ id: 1234, certificationCourseId, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, categoryId, description: 'Un gros problème', subcategory: CertificationIssueReportSubcategories.IMAGE_NOT_DISPLAYING, @@ -94,7 +94,7 @@ describe('Integration | Repository | Certification Issue Report', function () { const expectedSavedCertificationIssueReport = domainBuilder.buildCertificationIssueReport({ id: 1234, certificationCourseId, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, categoryId, description: 'Un gros problème', isActionRequired: true, @@ -117,7 +117,7 @@ describe('Integration | Repository | Certification Issue Report', function () { await databaseBuilder.commit(); // when - await certificationIssueReportRepository.delete(certificationIssueReportToDeleteId); + await certificationIssueReportRepository.remove(certificationIssueReportToDeleteId); // then const exists = await knex('certification-issue-reports') @@ -151,22 +151,22 @@ describe('Integration | Repository | Certification Issue Report', function () { // given const targetCertificationCourse = databaseBuilder.factory.buildCertificationCourse(); const categoryId = databaseBuilder.factory.buildIssueReportCategory({ - name: CertificationIssueReportCategories.OTHER, + name: CertificationIssueReportCategory.OTHER, }).id; const otherCertificationCourse = databaseBuilder.factory.buildCertificationCourse(); const issueReportForTargetCourse1 = databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId: targetCertificationCourse.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, categoryId, }); const issueReportForTargetCourse2 = databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId: targetCertificationCourse.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, categoryId, }); databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId: otherCertificationCourse.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, categoryId, }); await databaseBuilder.commit(); diff --git a/api/tests/integration/infrastructure/repositories/certification-livret-scolaire-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-livret-scolaire-repository_test.js index 33202a122eb..925430b2c58 100644 --- a/api/tests/integration/infrastructure/repositories/certification-livret-scolaire-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-livret-scolaire-repository_test.js @@ -1,8 +1,8 @@ -const certificationLsRepository = require('../../../../lib/infrastructure/repositories/certification-livret-scolaire-repository'); -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const status = require('../../../../lib/domain/read-models/livret-scolaire/CertificateStatus'); +import * as certificationLsRepository from '../../../../lib/infrastructure/repositories/certification-livret-scolaire-repository.js'; +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { status } from '../../../../lib/domain/read-models/livret-scolaire/CertificateStatus.js'; -const { +import { buildUser, buildOrganizationLearner, buildOrganization, @@ -12,7 +12,7 @@ const { buildCancelledCertificationData, buildRejectedPublishedCertificationData, buildErrorUnpublishedCertificationData, -} = require('../../../../tests/tooling/domain-builder/factory/build-certifications-results-for-ls'); +} from '../../../../tests/tooling/domain-builder/factory/build-certifications-results-for-ls.js'; describe('Integration | Repository | Certification-ls ', function () { const pixScore = 400; diff --git a/api/tests/integration/infrastructure/repositories/certification-officer-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-officer-repository_test.js index 91136013517..2b0c3cbd446 100644 --- a/api/tests/integration/infrastructure/repositories/certification-officer-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-officer-repository_test.js @@ -1,8 +1,8 @@ -const { databaseBuilder, expect, catchErr } = require('../../../test-helper'); -const certificationOfficerRepository = require('../../../../lib/infrastructure/repositories/certification-officer-repository'); +import { databaseBuilder, expect, catchErr } from '../../../test-helper.js'; +import * as certificationOfficerRepository from '../../../../lib/infrastructure/repositories/certification-officer-repository.js'; -const { UserNotFoundError } = require('../../../../lib/domain/errors'); -const CertificationOfficer = require('../../../../lib/domain/models/CertificationOfficer'); +import { UserNotFoundError } from '../../../../lib/domain/errors.js'; +import { CertificationOfficer } from '../../../../lib/domain/models/CertificationOfficer.js'; describe('Integration | Repository | CertificationOfficer', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-point-of-contact-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-point-of-contact-repository_test.js index cf86a16ad7f..596989a86ea 100644 --- a/api/tests/integration/infrastructure/repositories/certification-point-of-contact-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-point-of-contact-repository_test.js @@ -1,8 +1,8 @@ -const { databaseBuilder, expect, domainBuilder, catchErr } = require('../../../test-helper'); -const CertificationCenter = require('../../../../lib/domain/models/CertificationCenter'); -const Organization = require('../../../../lib/domain/models/Organization'); -const certificationPointOfContactRepository = require('../../../../lib/infrastructure/repositories/certification-point-of-contact-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { databaseBuilder, expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { CertificationCenter } from '../../../../lib/domain/models/CertificationCenter.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import * as certificationPointOfContactRepository from '../../../../lib/infrastructure/repositories/certification-point-of-contact-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | CertificationPointOfContact', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-report-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-report-repository_test.js index cae1fd60d37..f49ba6b782f 100644 --- a/api/tests/integration/infrastructure/repositories/certification-report-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-report-repository_test.js @@ -1,12 +1,10 @@ -const _ = require('lodash'); -const { databaseBuilder, domainBuilder, expect, catchErr, knex } = require('../../../test-helper'); -const CertificationReport = require('../../../../lib/domain/models/CertificationReport'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const certificationReportRepository = require('../../../../lib/infrastructure/repositories/certification-report-repository'); -const { CertificationCourseUpdateError } = require('../../../../lib/domain/errors'); -const { - CertificationIssueReportCategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); +import _ from 'lodash'; +import { databaseBuilder, domainBuilder, expect, catchErr, knex } from '../../../test-helper.js'; +import { CertificationReport } from '../../../../lib/domain/models/CertificationReport.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import * as certificationReportRepository from '../../../../lib/infrastructure/repositories/certification-report-repository.js'; +import { CertificationCourseUpdateError } from '../../../../lib/domain/errors.js'; +import { CertificationIssueReportCategory } from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; describe('Integration | Repository | CertificationReport', function () { describe('#findBySessionId', function () { @@ -28,7 +26,7 @@ describe('Integration | Repository | CertificationReport', function () { }); const certificationIssueReport1 = databaseBuilder.factory.buildCertificationIssueReport({ certificationCourseId: certificationCourse1.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, description: 'Houston, nous avons un problème', }); // In other session diff --git a/api/tests/integration/infrastructure/repositories/certification-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-repository_test.js index 07e67ed26d3..58d8015ba5f 100644 --- a/api/tests/integration/infrastructure/repositories/certification-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, catchErr, knex } = require('../../../test-helper'); -const certificationRepository = require('../../../../lib/infrastructure/repositories/certification-repository'); -const { CertificationCourseNotPublishableError } = require('../../../../lib/domain/errors'); -const { status } = require('../../../../lib/domain/models/AssessmentResult'); +import { expect, databaseBuilder, catchErr, knex } from '../../../test-helper.js'; +import * as certificationRepository from '../../../../lib/infrastructure/repositories/certification-repository.js'; +import { CertificationCourseNotPublishableError } from '../../../../lib/domain/errors.js'; +import { status } from '../../../../lib/domain/models/AssessmentResult.js'; describe('Integration | Repository | Certification', function () { describe('#publishCertificationCoursesBySessionId', function () { diff --git a/api/tests/integration/infrastructure/repositories/certification-result-repository_test.js b/api/tests/integration/infrastructure/repositories/certification-result-repository_test.js index 2e35879e34a..e5e3440f2ff 100644 --- a/api/tests/integration/infrastructure/repositories/certification-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certification-result-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const certificationResultRepository = require('../../../../lib/infrastructure/repositories/certification-result-repository'); -const CertificationResult = require('../../../../lib/domain/models/CertificationResult'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as certificationResultRepository from '../../../../lib/infrastructure/repositories/certification-result-repository.js'; +import { CertificationResult } from '../../../../lib/domain/models/CertificationResult.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; describe('Integration | Infrastructure | Repository | Certification Result', function () { describe('#findBySessionId', function () { diff --git a/api/tests/integration/infrastructure/repositories/certified-profile-repository_test.js b/api/tests/integration/infrastructure/repositories/certified-profile-repository_test.js index 4c707581b0c..466667d9868 100644 --- a/api/tests/integration/infrastructure/repositories/certified-profile-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/certified-profile-repository_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder, mockLearningContent, domainBuilder, catchErr } = require('../../../test-helper'); -const { CertifiedProfile } = require('../../../../lib/domain/read-models/CertifiedProfile'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const certifiedProfileRepository = require('../../../../lib/infrastructure/repositories/certified-profile-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, mockLearningContent, domainBuilder, catchErr } from '../../../test-helper.js'; +import { CertifiedProfile } from '../../../../lib/domain/read-models/CertifiedProfile.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import * as certifiedProfileRepository from '../../../../lib/infrastructure/repositories/certified-profile-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | Certified Profile', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/challenge-for-pix-auto-answer-repository_test.js b/api/tests/integration/infrastructure/repositories/challenge-for-pix-auto-answer-repository_test.js index 497a7a60505..b270bf2a80f 100644 --- a/api/tests/integration/infrastructure/repositories/challenge-for-pix-auto-answer-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/challenge-for-pix-auto-answer-repository_test.js @@ -1,5 +1,5 @@ -const { expect, mockLearningContent } = require('../../../test-helper'); -const challengeForPixAutoAnswerRepository = require('../../../../lib/infrastructure/repositories/challenge-for-pix-auto-answer-repository'); +import { expect, mockLearningContent } from '../../../test-helper.js'; +import * as challengeForPixAutoAnswerRepository from '../../../../lib/infrastructure/repositories/challenge-for-pix-auto-answer-repository.js'; describe('Integration | Repository | challenge-for-pix-auto-answer-repository', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/challenge-repository_test.js b/api/tests/integration/infrastructure/repositories/challenge-repository_test.js index 45d24c3b0fb..c2075f3c216 100644 --- a/api/tests/integration/infrastructure/repositories/challenge-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/challenge-repository_test.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const { expect, mockLearningContent, domainBuilder, catchErr } = require('../../../test-helper'); -const Challenge = require('../../../../lib/domain/models/Challenge'); -const Validator = require('../../../../lib/domain/models/Validator'); -const challengeRepository = require('../../../../lib/infrastructure/repositories/challenge-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import _ from 'lodash'; +import { expect, mockLearningContent, domainBuilder, catchErr } from '../../../test-helper.js'; +import { Challenge } from '../../../../lib/domain/models/Challenge.js'; +import { Validator } from '../../../../lib/domain/models/Validator.js'; +import * as challengeRepository from '../../../../lib/infrastructure/repositories/challenge-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | challenge-repository', function () { describe('#get', function () { @@ -482,9 +482,13 @@ describe('Integration | Repository | challenge-repository', function () { it('should return only flash compatible challenges with skills', async function () { // given const locale = 'fr-fr'; + const successProbabilityThreshold = 0.95; // when - const actualChallenges = await challengeRepository.findActiveFlashCompatible({ locale }); + const actualChallenges = await challengeRepository.findActiveFlashCompatible({ + locale, + successProbabilityThreshold, + }); // then expect(actualChallenges).to.have.lengthOf(1); diff --git a/api/tests/integration/infrastructure/repositories/clea-certified-candidate-repository_test.js b/api/tests/integration/infrastructure/repositories/clea-certified-candidate-repository_test.js index 23d117c4e28..a28184729e6 100644 --- a/api/tests/integration/infrastructure/repositories/clea-certified-candidate-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/clea-certified-candidate-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const cleaCertifiedCandidateRepository = require('../../../../lib/infrastructure/repositories/clea-certified-candidate-repository'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as cleaCertifiedCandidateRepository from '../../../../lib/infrastructure/repositories/clea-certified-candidate-repository.js'; describe('Integration | Repository | clea-certified-candidate-repository', function () { describe('#getBySessionId', function () { diff --git a/api/tests/integration/infrastructure/repositories/competence-evaluation-repository_test.js b/api/tests/integration/infrastructure/repositories/competence-evaluation-repository_test.js index afa3254ab73..9341a2f3d8b 100644 --- a/api/tests/integration/infrastructure/repositories/competence-evaluation-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/competence-evaluation-repository_test.js @@ -1,10 +1,10 @@ -const { expect, knex, databaseBuilder, catchErr } = require('../../../test-helper'); -const CompetenceEvaluation = require('../../../../lib/domain/models/CompetenceEvaluation'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const competenceEvaluationRepository = require('../../../../lib/infrastructure/repositories/competence-evaluation-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const _ = require('lodash'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { expect, knex, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { CompetenceEvaluation } from '../../../../lib/domain/models/CompetenceEvaluation.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import * as competenceEvaluationRepository from '../../../../lib/infrastructure/repositories/competence-evaluation-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import _ from 'lodash'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Integration | Repository | Competence Evaluation', function () { const STARTED = 'started'; diff --git a/api/tests/integration/infrastructure/repositories/competence-mark-repository_test.js b/api/tests/integration/infrastructure/repositories/competence-mark-repository_test.js index 379e0822319..8aaa26a085e 100644 --- a/api/tests/integration/infrastructure/repositories/competence-mark-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/competence-mark-repository_test.js @@ -1,8 +1,8 @@ -const { expect, knex, domainBuilder, databaseBuilder } = require('../../../test-helper'); -const _ = require('lodash'); +import { expect, knex, domainBuilder, databaseBuilder } from '../../../test-helper.js'; +import _ from 'lodash'; -const CompetenceMark = require('../../../../lib/domain/models/CompetenceMark'); -const competenceMarkRepository = require('../../../../lib/infrastructure/repositories/competence-mark-repository'); +import { CompetenceMark } from '../../../../lib/domain/models/CompetenceMark.js'; +import * as competenceMarkRepository from '../../../../lib/infrastructure/repositories/competence-mark-repository.js'; describe('Integration | Repository | CompetenceMark', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/competence-repository_test.js b/api/tests/integration/infrastructure/repositories/competence-repository_test.js index 2650e7b5fa8..d7a523b4e53 100644 --- a/api/tests/integration/infrastructure/repositories/competence-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/competence-repository_test.js @@ -1,5 +1,5 @@ -const { expect, mockLearningContent, domainBuilder } = require('../../../test-helper'); -const competenceRepository = require('../../../../lib/infrastructure/repositories/competence-repository'); +import { expect, mockLearningContent, domainBuilder } from '../../../test-helper.js'; +import * as competenceRepository from '../../../../lib/infrastructure/repositories/competence-repository.js'; describe('Integration | Repository | competence-repository', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/complementary-certification-course-repository_test.js b/api/tests/integration/infrastructure/repositories/complementary-certification-course-repository_test.js index 30297f7c700..e5a253e4a5a 100644 --- a/api/tests/integration/infrastructure/repositories/complementary-certification-course-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/complementary-certification-course-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const complementaryCertificationCourseRepository = require('../../../../lib/infrastructure/repositories/complementary-certification-course-repository'); -const { PIX_PLUS_DROIT, PIX_PLUS_EDU_1ER_DEGRE } = require('../../../../lib/domain/models/ComplementaryCertification'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as complementaryCertificationCourseRepository from '../../../../lib/infrastructure/repositories/complementary-certification-course-repository.js'; +import { PIX_PLUS_DROIT, PIX_PLUS_EDU_1ER_DEGRE } from '../../../../lib/domain/models/ComplementaryCertification.js'; describe('Integration | Repository | complementary-certification-courses-repository', function () { describe('#getComplementaryCertificationCourseId', function () { diff --git a/api/tests/integration/infrastructure/repositories/complementary-certification-course-result-repository_test.js b/api/tests/integration/infrastructure/repositories/complementary-certification-course-result-repository_test.js index b2a610d011b..89a651ef706 100644 --- a/api/tests/integration/infrastructure/repositories/complementary-certification-course-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/complementary-certification-course-result-repository_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const { knex } = require('../../../../lib/infrastructure/bookshelf'); -const _ = require('lodash'); -const complementaryCertificationCourseResultRepository = require('../../../../lib/infrastructure/repositories/complementary-certification-course-result-repository'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import { knex } from '../../../../lib/infrastructure/bookshelf.js'; +import _ from 'lodash'; +import * as complementaryCertificationCourseResultRepository from '../../../../lib/infrastructure/repositories/complementary-certification-course-result-repository.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; describe('Integration | Repository | complementary-certification-courses-result-repository', function () { describe('#getPixSourceResultByComplementaryCertificationCourseId', function () { diff --git a/api/tests/integration/infrastructure/repositories/complementary-certification-habilitation-repository_test.js b/api/tests/integration/infrastructure/repositories/complementary-certification-habilitation-repository_test.js index bc71990fcb3..455c1cc74d6 100644 --- a/api/tests/integration/infrastructure/repositories/complementary-certification-habilitation-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/complementary-certification-habilitation-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const complementaryCertificationHabilitationRepository = require('../../../../lib/infrastructure/repositories/complementary-certification-habilitation-repository'); -const { knex } = require('../../../../lib/infrastructure/bookshelf'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as complementaryCertificationHabilitationRepository from '../../../../lib/infrastructure/repositories/complementary-certification-habilitation-repository.js'; +import { knex } from '../../../../lib/infrastructure/bookshelf.js'; describe('Integration | Infrastructure | Repository | complementary-certification-habilitation-repository', function () { context('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/complementary-certification-repository_test.js b/api/tests/integration/infrastructure/repositories/complementary-certification-repository_test.js index acb4da3dad8..276e7d54e74 100644 --- a/api/tests/integration/infrastructure/repositories/complementary-certification-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/complementary-certification-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const complementaryCertificationRepository = require('../../../../lib/infrastructure/repositories/complementary-certification-repository'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as complementaryCertificationRepository from '../../../../lib/infrastructure/repositories/complementary-certification-repository.js'; describe('Integration | Repository | complementary-certification-repository', function () { describe('#findAll', function () { diff --git a/api/tests/integration/infrastructure/repositories/complementary-certification-scoring-criteria-repository_test.js b/api/tests/integration/infrastructure/repositories/complementary-certification-scoring-criteria-repository_test.js index 61e3e5a1819..47875795953 100644 --- a/api/tests/integration/infrastructure/repositories/complementary-certification-scoring-criteria-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/complementary-certification-scoring-criteria-repository_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder, databaseBuilder } = require('../../../test-helper'); -const complementaryCertificationScoringCriteriaRepository = require('../../../../lib/infrastructure/repositories/complementary-certification-scoring-criteria-repository'); +import { expect, domainBuilder, databaseBuilder } from '../../../test-helper.js'; +import * as complementaryCertificationScoringCriteriaRepository from '../../../../lib/infrastructure/repositories/complementary-certification-scoring-criteria-repository.js'; describe('Integration | Repository | complementary certification scoring criteria', function () { describe('#findByCertificationCourseId', function () { diff --git a/api/tests/integration/infrastructure/repositories/complementary-certification-subscription-repository_test.js b/api/tests/integration/infrastructure/repositories/complementary-certification-subscription-repository_test.js index bdf012a6b4c..aac21c537e8 100644 --- a/api/tests/integration/infrastructure/repositories/complementary-certification-subscription-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/complementary-certification-subscription-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const complementaryCertificationSubscriptionRepository = require('../../../../lib/infrastructure/repositories/complementary-certification-subscription-repository'); -const { knex } = require('../../../../lib/infrastructure/bookshelf'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as complementaryCertificationSubscriptionRepository from '../../../../lib/infrastructure/repositories/complementary-certification-subscription-repository.js'; +import { knex } from '../../../../lib/infrastructure/bookshelf.js'; describe('Integration | Infrastructure | Repository | complementary-certification-subscription-repository', function () { context('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/country-repository_test.js b/api/tests/integration/infrastructure/repositories/country-repository_test.js index d6b024f1b12..a62b17a627a 100644 --- a/api/tests/integration/infrastructure/repositories/country-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/country-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const countryRepository = require('../../../../lib/infrastructure/repositories/country-repository'); -const { Country } = require('../../../../lib/domain/read-models/Country'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as countryRepository from '../../../../lib/infrastructure/repositories/country-repository.js'; +import { Country } from '../../../../lib/domain/read-models/Country.js'; describe('Integration | Repository | country-repository', function () { describe('#findAll', function () { diff --git a/api/tests/integration/infrastructure/repositories/course-repository_test.js b/api/tests/integration/infrastructure/repositories/course-repository_test.js index ea1796ad8a5..0aa09785c77 100644 --- a/api/tests/integration/infrastructure/repositories/course-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/course-repository_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder, catchErr, mockLearningContent } = require('../../../test-helper'); -const Course = require('../../../../lib/domain/models/Course'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const courseRepository = require('../../../../lib/infrastructure/repositories/course-repository'); +import { expect, domainBuilder, catchErr, mockLearningContent } from '../../../test-helper.js'; +import { Course } from '../../../../lib/domain/models/Course.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as courseRepository from '../../../../lib/infrastructure/repositories/course-repository.js'; describe('Integration | Repository | course-repository', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/cpf-certification-result-repository_test.js b/api/tests/integration/infrastructure/repositories/cpf-certification-result-repository_test.js index c12ba92b816..85f277b7499 100644 --- a/api/tests/integration/infrastructure/repositories/cpf-certification-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/cpf-certification-result-repository_test.js @@ -1,7 +1,7 @@ -const { databaseBuilder, expect, knex, domainBuilder } = require('../../../test-helper'); -const cpfCertificationResultRepository = require('../../../../lib/infrastructure/repositories/cpf-certification-result-repository'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const { cpfImportStatus } = require('../../../../lib/domain/models/CertificationCourse'); +import { databaseBuilder, expect, knex, domainBuilder } from '../../../test-helper.js'; +import * as cpfCertificationResultRepository from '../../../../lib/infrastructure/repositories/cpf-certification-result-repository.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import { cpfImportStatus } from '../../../../lib/domain/models/CertificationCourse.js'; describe('Integration | Repository | CpfCertificationResult', function () { describe('#countByTimeRange', function () { diff --git a/api/tests/integration/infrastructure/repositories/data-protection-officer-repository_test.js b/api/tests/integration/infrastructure/repositories/data-protection-officer-repository_test.js index 232538a5339..eeffb1aed4d 100644 --- a/api/tests/integration/infrastructure/repositories/data-protection-officer-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/data-protection-officer-repository_test.js @@ -1,6 +1,6 @@ -const { databaseBuilder, expect, knex } = require('../../../test-helper'); -const DataProtectionOfficer = require('../../../../lib/domain/models/DataProtectionOfficer'); -const dataProtectionOfficerRepository = require('../../../../lib/infrastructure/repositories/data-protection-officer-repository'); +import { databaseBuilder, expect, knex } from '../../../test-helper.js'; +import { DataProtectionOfficer } from '../../../../lib/domain/models/DataProtectionOfficer.js'; +import * as dataProtectionOfficerRepository from '../../../../lib/infrastructure/repositories/data-protection-officer-repository.js'; describe('Integration | Repository | data-protection-officer', function () { const now = new Date('2022-09-27T16:30:00Z'); diff --git a/api/tests/integration/infrastructure/repositories/division-repository_test.js b/api/tests/integration/infrastructure/repositories/division-repository_test.js index a8856fcfbe7..8546e7b27da 100644 --- a/api/tests/integration/infrastructure/repositories/division-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/division-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const divisionRepository = require('../../../../lib/infrastructure/repositories/division-repository'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as divisionRepository from '../../../../lib/infrastructure/repositories/division-repository.js'; describe('Integration | Repository | Division', function () { describe('#findByCampaignId', function () { diff --git a/api/tests/integration/infrastructure/repositories/flash-assessment-result-repository_test.js b/api/tests/integration/infrastructure/repositories/flash-assessment-result-repository_test.js index cd226ca8974..94e49c3a84b 100644 --- a/api/tests/integration/infrastructure/repositories/flash-assessment-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/flash-assessment-result-repository_test.js @@ -1,5 +1,5 @@ -const { expect, knex, databaseBuilder } = require('../../../test-helper'); -const flashAssessmentResultRepository = require('../../../../lib/infrastructure/repositories/flash-assessment-result-repository'); +import { expect, knex, databaseBuilder } from '../../../test-helper.js'; +import * as flashAssessmentResultRepository from '../../../../lib/infrastructure/repositories/flash-assessment-result-repository.js'; describe('Integration | Infrastructure | Repository | FlashAssessmentResultRepository', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/repositories/framework-repository_test.js b/api/tests/integration/infrastructure/repositories/framework-repository_test.js index d3fba2b3e2a..d4f3e3059de 100644 --- a/api/tests/integration/infrastructure/repositories/framework-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/framework-repository_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, mockLearningContent, catchErr } = require('../../../test-helper'); -const frameworkRepository = require('../../../../lib/infrastructure/repositories/framework-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, domainBuilder, mockLearningContent, catchErr } from '../../../test-helper.js'; +import * as frameworkRepository from '../../../../lib/infrastructure/repositories/framework-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | framework-repository', function () { const framework0 = { diff --git a/api/tests/integration/infrastructure/repositories/group-repository_test.js b/api/tests/integration/infrastructure/repositories/group-repository_test.js index 948b1c01a91..40d976788f2 100644 --- a/api/tests/integration/infrastructure/repositories/group-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/group-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const groupRepository = require('../../../../lib/infrastructure/repositories/group-repository'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as groupRepository from '../../../../lib/infrastructure/repositories/group-repository.js'; describe('Integration | Repository | Group', function () { describe('#findByCampaignId', function () { diff --git a/api/tests/integration/infrastructure/repositories/issue-report-categories-repository_test.js b/api/tests/integration/infrastructure/repositories/issue-report-categories-repository_test.js index 0677ae30604..b05426b78d6 100644 --- a/api/tests/integration/infrastructure/repositories/issue-report-categories-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/issue-report-categories-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const issueReportCategoryRepository = require('../../../../lib/infrastructure/repositories/issue-report-category-repository'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import * as issueReportCategoryRepository from '../../../../lib/infrastructure/repositories/issue-report-category-repository.js'; describe('Integration | Repository | Issue Report Categories', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/repositories/jury-certification-repository_test.js b/api/tests/integration/infrastructure/repositories/jury-certification-repository_test.js index 0d348512b1c..f970eba28df 100644 --- a/api/tests/integration/infrastructure/repositories/jury-certification-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/jury-certification-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, domainBuilder, catchErr } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const juryCertificationRepository = require('../../../../lib/infrastructure/repositories/jury-certification-repository'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); +import { expect, databaseBuilder, domainBuilder, catchErr } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as juryCertificationRepository from '../../../../lib/infrastructure/repositories/jury-certification-repository.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; describe('Integration | Infrastructure | Repository | Jury Certification', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/jury-certification-summary-repository_test.js b/api/tests/integration/infrastructure/repositories/jury-certification-summary-repository_test.js index 97e00a13ae4..a4809b19bc2 100644 --- a/api/tests/integration/infrastructure/repositories/jury-certification-summary-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/jury-certification-summary-repository_test.js @@ -1,14 +1,16 @@ -const { databaseBuilder, domainBuilder, expect } = require('../../../test-helper'); -const JuryCertificationSummary = require('../../../../lib/domain/read-models/JuryCertificationSummary'); -const CertificationIssueReport = require('../../../../lib/domain/models/CertificationIssueReport'); -const { - CertificationIssueReportCategories, +import { databaseBuilder, domainBuilder, expect } from '../../../test-helper.js'; +import { JuryCertificationSummary } from '../../../../lib/domain/read-models/JuryCertificationSummary.js'; +import { CertificationIssueReport } from '../../../../lib/domain/models/CertificationIssueReport.js'; + +import { + CertificationIssueReportCategory, CertificationIssueReportSubcategories, ImpactfulSubcategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); -const { status: assessmentResultStatuses } = require('../../../../lib/domain/models/AssessmentResult'); -const juryCertificationSummaryRepository = require('../../../../lib/infrastructure/repositories/jury-certification-summary-repository'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +} from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; + +import { status as assessmentResultStatuses } from '../../../../lib/domain/models/AssessmentResult.js'; +import * as juryCertificationSummaryRepository from '../../../../lib/infrastructure/repositories/jury-certification-summary-repository.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Integration | Repository | JuryCertificationSummary', function () { describe('#findBySessionId', function () { @@ -51,13 +53,13 @@ describe('Integration | Repository | JuryCertificationSummary', function () { dbf.buildAssessment({ certificationCourseId: startedCertification.id }); categoryId = dbf.buildIssueReportCategory({ - name: CertificationIssueReportCategories.OTHER, + name: CertificationIssueReportCategory.OTHER, isImpactful: false, }).id; certificationIssueReport = dbf.buildCertificationIssueReport({ certificationCourseId: manyAsrCertification.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, categoryId, description, }); @@ -98,7 +100,7 @@ describe('Integration | Repository | JuryCertificationSummary', function () { categoryId, subcategory: null, questionNumber: null, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, hasBeenAutomaticallyResolved: null, resolvedAt: null, resolution: null, @@ -183,20 +185,20 @@ describe('Integration | Repository | JuryCertificationSummary', function () { const manyAsrAssessmentId = dbf.buildAssessment({ certificationCourseId: manyAsrCertification.id }).id; const categoryId = dbf.buildIssueReportCategory({ - name: CertificationIssueReportCategories.OTHER, + name: CertificationIssueReportCategory.OTHER, isImpactful: false, }).id; const issueReport1 = dbf.buildCertificationIssueReport({ certificationCourseId: manyAsrCertification.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, categoryId, description: 'first certification issue report', hasBeenAutomaticallyResolved: false, }); const issueReport2 = dbf.buildCertificationIssueReport({ certificationCourseId: manyAsrCertification.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, categoryId, description: 'second certification issue report', hasBeenAutomaticallyResolved: false, @@ -316,25 +318,25 @@ describe('Integration | Repository | JuryCertificationSummary', function () { }); const categoryId = dbf.buildIssueReportCategory({ - name: CertificationIssueReportCategories.OTHER, + name: CertificationIssueReportCategory.OTHER, isImpactful: false, }).id; const issueReport1 = dbf.buildCertificationIssueReport({ certificationCourseId: manyAsrCertification.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, categoryId, description: 'first certification issue report', hasBeenAutomaticallyResolved: false, }); dbf.buildIssueReportCategory({ - name: CertificationIssueReportCategories.OTHER, + name: CertificationIssueReportCategory.OTHER, isImpactful: true, isDeprecated: true, }); const issueReport2 = dbf.buildCertificationIssueReport({ certificationCourseId: manyAsrCertification.id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, categoryId, description: 'second certification issue report', hasBeenAutomaticallyResolved: false, @@ -513,7 +515,7 @@ describe('Integration | Repository | JuryCertificationSummary', function () { dbf.buildIssueReportCategory({ id: 3, - name: CertificationIssueReportCategories.IN_CHALLENGE, + name: CertificationIssueReportCategory.IN_CHALLENGE, isImpactful: true, isDeprecated: false, }); diff --git a/api/tests/integration/infrastructure/repositories/knowledge-element-repository_test.js b/api/tests/integration/infrastructure/repositories/knowledge-element-repository_test.js index 749d1be6726..6bd5fd6fac9 100644 --- a/api/tests/integration/infrastructure/repositories/knowledge-element-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/knowledge-element-repository_test.js @@ -1,10 +1,9 @@ -const _ = require('lodash'); -const { expect, knex, domainBuilder, databaseBuilder, sinon } = require('../../../test-helper'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const knowledgeElementRepository = require('../../../../lib/infrastructure/repositories/knowledge-element-repository'); -const knowledgeElementSnapshotRepository = require('../../../../lib/infrastructure/repositories/knowledge-element-snapshot-repository'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import _ from 'lodash'; +import { expect, knex, domainBuilder, databaseBuilder, sinon } from '../../../test-helper.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import * as knowledgeElementRepository from '../../../../lib/infrastructure/repositories/knowledge-element-repository.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; @@ -2031,7 +2030,6 @@ describe('Integration | Repository | knowledgeElementRepository', function () { it('should return the knowledge elements in the snapshot', async function () { // given - sandbox.spy(knowledgeElementSnapshotRepository); const dateSharedAtUserId1 = new Date('2020-01-03'); const knowledgeElement = databaseBuilder.factory.buildKnowledgeElement({ userId: userId1 }); databaseBuilder.factory.buildKnowledgeElementSnapshot({ @@ -2048,14 +2046,6 @@ describe('Integration | Repository | knowledgeElementRepository', function () { // then expect(knowledgeElementsByUserIdAndCompetenceId[userId1][0]).to.deep.equal(knowledgeElement); - expect(knowledgeElementSnapshotRepository.findByUserIdsAndSnappedAtDates).to.have.been.calledWith({ - [userId1]: dateSharedAtUserId1, - }); - await expect( - knowledgeElementSnapshotRepository.findByUserIdsAndSnappedAtDates.firstCall.returnValue - ).to.eventually.deep.equal({ - [userId1]: [knowledgeElement], - }); }); }); diff --git a/api/tests/integration/infrastructure/repositories/knowledge-element-snapshot-repository_test.js b/api/tests/integration/infrastructure/repositories/knowledge-element-snapshot-repository_test.js index 2f1396152ca..98d2cfda91c 100644 --- a/api/tests/integration/infrastructure/repositories/knowledge-element-snapshot-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/knowledge-element-snapshot-repository_test.js @@ -1,8 +1,8 @@ -const { knex, expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const knowledgeElementSnapshotRepository = require('../../../../lib/infrastructure/repositories/knowledge-element-snapshot-repository'); -const { AlreadyExistingEntityError } = require('../../../../lib/domain/errors'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { knex, expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import * as knowledgeElementSnapshotRepository from '../../../../lib/infrastructure/repositories/knowledge-element-snapshot-repository.js'; +import { AlreadyExistingEntityError } from '../../../../lib/domain/errors.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Integration | Repository | KnowledgeElementSnapshotRepository', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/learning-content-repository_test.js b/api/tests/integration/infrastructure/repositories/learning-content-repository_test.js index 3e7a557bd5f..d51b7d7b635 100644 --- a/api/tests/integration/infrastructure/repositories/learning-content-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/learning-content-repository_test.js @@ -1,13 +1,14 @@ -const { +import { expect, databaseBuilder, catchErr, mockLearningContent, domainBuilder, learningContentBuilder, -} = require('../../../test-helper'); -const { NoSkillsInCampaignError, NotFoundError } = require('../../../../lib/domain/errors'); -const learningContentRepository = require('../../../../lib/infrastructure/repositories/learning-content-repository'); +} from '../../../test-helper.js'; + +import { NoSkillsInCampaignError, NotFoundError } from '../../../../lib/domain/errors.js'; +import * as learningContentRepository from '../../../../lib/infrastructure/repositories/learning-content-repository.js'; describe('Integration | Repository | learning-content', function () { let learningContent; @@ -19,7 +20,7 @@ describe('Integration | Repository | learning-content', function () { let skill1, skill2, skill3, skill8; beforeEach(function () { - learningContent = learningContentBuilder.buildLearningContent([ + learningContent = learningContentBuilder([ { id: 'recFramework1', name: 'Mon référentiel 1', diff --git a/api/tests/integration/infrastructure/repositories/membership-repository_test.js b/api/tests/integration/infrastructure/repositories/membership-repository_test.js index 2a1a4d1f233..1d73a6d8cce 100644 --- a/api/tests/integration/infrastructure/repositories/membership-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/membership-repository_test.js @@ -1,10 +1,10 @@ -const { expect, knex, databaseBuilder, catchErr, sinon } = require('../../../test-helper'); -const _ = require('lodash'); -const membershipRepository = require('../../../../lib/infrastructure/repositories/membership-repository'); -const { MembershipCreationError, MembershipUpdateError, NotFoundError } = require('../../../../lib/domain/errors'); -const Membership = require('../../../../lib/domain/models/Membership'); -const Organization = require('../../../../lib/domain/models/Organization'); -const User = require('../../../../lib/domain/models/User'); +import { expect, knex, databaseBuilder, catchErr, sinon } from '../../../test-helper.js'; +import _ from 'lodash'; +import * as membershipRepository from '../../../../lib/infrastructure/repositories/membership-repository.js'; +import { MembershipCreationError, MembershipUpdateError, NotFoundError } from '../../../../lib/domain/errors.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { User } from '../../../../lib/domain/models/User.js'; describe('Integration | Infrastructure | Repository | membership-repository', function () { let clock; diff --git a/api/tests/integration/infrastructure/repositories/organization-for-admin-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-for-admin-repository_test.js index c27d651c0af..b42b6f68c63 100644 --- a/api/tests/integration/infrastructure/repositories/organization-for-admin-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-for-admin-repository_test.js @@ -1,10 +1,10 @@ -const { catchErr, expect, domainBuilder, databaseBuilder, sinon, knex } = require('../../../test-helper'); -const { NotFoundError, MissingAttributesError } = require('../../../../lib/domain/errors'); -const OrganizationForAdmin = require('../../../../lib/domain/models/organizations-administration/Organization'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const organizationForAdminRepository = require('../../../../lib/infrastructure/repositories/organization-for-admin-repository'); -const { SamlIdentityProviders } = require('../../../../lib/domain/constants/saml-identity-providers'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); +import { catchErr, expect, domainBuilder, databaseBuilder, sinon, knex } from '../../../test-helper.js'; +import { NotFoundError, MissingAttributesError } from '../../../../lib/domain/errors.js'; +import { OrganizationForAdmin } from '../../../../lib/domain/models/organizations-administration/Organization.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import * as organizationForAdminRepository from '../../../../lib/infrastructure/repositories/organization-for-admin-repository.js'; +import { SamlIdentityProviders } from '../../../../lib/domain/constants/saml-identity-providers.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; describe('Integration | Repository | Organization-for-admin', function () { let clock; diff --git a/api/tests/integration/infrastructure/repositories/organization-invitation-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-invitation-repository_test.js index e31255a5770..673c1811d96 100644 --- a/api/tests/integration/infrastructure/repositories/organization-invitation-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-invitation-repository_test.js @@ -1,10 +1,10 @@ -const _ = require('lodash'); -const { expect, knex, databaseBuilder, catchErr, sinon } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const Membership = require('../../../../lib/domain/models/Membership'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const organizationInvitationRepository = require('../../../../lib/infrastructure/repositories/organization-invitation-repository'); -const BookshelfOrganizationInvitation = require('../../../../lib/infrastructure/orm-models/OrganizationInvitation'); +import _ from 'lodash'; +import { expect, knex, databaseBuilder, catchErr, sinon } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import * as organizationInvitationRepository from '../../../../lib/infrastructure/repositories/organization-invitation-repository.js'; +import { BookshelfOrganizationInvitation } from '../../../../lib/infrastructure/orm-models/OrganizationInvitation.js'; describe('Integration | Repository | OrganizationInvitationRepository', function () { describe('#create', function () { diff --git a/api/tests/integration/infrastructure/repositories/organization-invited-user-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-invited-user-repository_test.js index 8adccf095c3..60fdb32522c 100644 --- a/api/tests/integration/infrastructure/repositories/organization-invited-user-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-invited-user-repository_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder, catchErr, knex, sinon } = require('../../../test-helper'); -const organizationInvitedUserRepository = require('../../../../lib/infrastructure/repositories/organization-invited-user-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const OrganizationInvitedUser = require('../../../../lib/domain/models/OrganizationInvitedUser'); +import { expect, databaseBuilder, catchErr, knex, sinon } from '../../../test-helper.js'; +import * as organizationInvitedUserRepository from '../../../../lib/infrastructure/repositories/organization-invited-user-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import { OrganizationInvitedUser } from '../../../../lib/domain/models/OrganizationInvitedUser.js'; describe('Integration | Repository | OrganizationInvitedUserRepository', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/repositories/organization-learner-activity-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-learner-activity-repository_test.js index 63bc298909e..e0dfebf0ed5 100644 --- a/api/tests/integration/infrastructure/repositories/organization-learner-activity-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-learner-activity-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const organizationLearnerActivityRepository = require('../../../../lib/infrastructure/repositories/organization-learner-activity-repository'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as organizationLearnerActivityRepository from '../../../../lib/infrastructure/repositories/organization-learner-activity-repository.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; describe('Integration | Infrastructure | Repository | organization-learner-activity', function () { diff --git a/api/tests/integration/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository_test.js index 9e1d01805ca..3c4f08972fd 100644 --- a/api/tests/integration/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, catchErr } = require('../../../../test-helper'); -const organizationLearnerFollowUpRepository = require('../../../../../lib/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); -const AuthenticationMethod = require('../../../../../lib/domain/models/AuthenticationMethod'); +import { expect, databaseBuilder, catchErr } from '../../../../test-helper.js'; +import * as organizationLearnerFollowUpRepository from '../../../../../lib/infrastructure/repositories/organization-learner-follow-up/organization-learner-repository.js'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; +import { AuthenticationMethod } from '../../../../../lib/domain/models/AuthenticationMethod.js'; describe('Integration | Infrastructure | Repository | Organization Learner Follow Up | Organization Learner', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/organization-learner-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-learner-repository_test.js index f4e70c89d0b..50b91b2acc0 100644 --- a/api/tests/integration/infrastructure/repositories/organization-learner-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-learner-repository_test.js @@ -1,20 +1,19 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { expect, domainBuilder, databaseBuilder, knex, catchErr, sinon } = require('../../../test-helper'); +import { expect, domainBuilder, databaseBuilder, knex, catchErr, sinon } from '../../../test-helper.js'; +import { OrganizationLearner } from '../../../../lib/domain/models/OrganizationLearner.js'; +import { OrganizationLearnerForAdmin } from '../../../../lib/domain/read-models/OrganizationLearnerForAdmin.js'; -const OrganizationLearner = require('../../../../lib/domain/models/OrganizationLearner'); -const OrganizationLearnerForAdmin = require('../../../../lib/domain/read-models/OrganizationLearnerForAdmin'); - -const { +import { NotFoundError, OrganizationLearnersCouldNotBeSavedError, OrganizationLearnerNotFound, UserCouldNotBeReconciledError, UserNotFoundError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; -const organizationLearnerRepository = require('../../../../lib/infrastructure/repositories/organization-learner-repository'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import * as organizationLearnerRepository from '../../../../lib/infrastructure/repositories/organization-learner-repository.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Integration | Infrastructure | Repository | organization-learner-repository', function () { describe('#findByIds', function () { diff --git a/api/tests/integration/infrastructure/repositories/organization-member-identity-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-member-identity-repository_test.js index 0cb4e09bc8b..83855083f76 100644 --- a/api/tests/integration/infrastructure/repositories/organization-member-identity-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-member-identity-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const OrganizationMemberIdentity = require('../../../../lib/domain/models/OrganizationMemberIdentity'); -const organizationMemberIdentityRepository = require('../../../../lib/infrastructure/repositories/organization-member-identity-repository'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { OrganizationMemberIdentity } from '../../../../lib/domain/models/OrganizationMemberIdentity.js'; +import * as organizationMemberIdentityRepository from '../../../../lib/infrastructure/repositories/organization-member-identity-repository.js'; describe('Integration | Repository | organizationMemberIdentityRepository', function () { describe('#findAllByOrganizationId', function () { diff --git a/api/tests/integration/infrastructure/repositories/organization-participant-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-participant-repository_test.js index f6fb48aca28..d464481d25e 100644 --- a/api/tests/integration/infrastructure/repositories/organization-participant-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-participant-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const organizationParticipantRepository = require('../../../../lib/infrastructure/repositories/organization-participant-repository'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as organizationParticipantRepository from '../../../../lib/infrastructure/repositories/organization-participant-repository.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; function buildLearnerWithParticipation({ organizationId, diff --git a/api/tests/integration/infrastructure/repositories/organization-places-capacity-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-places-capacity-repository_test.js index 89dbb008abb..fe29cfdccef 100644 --- a/api/tests/integration/infrastructure/repositories/organization-places-capacity-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-places-capacity-repository_test.js @@ -1,7 +1,7 @@ -const sinon = require('sinon'); -const { expect, databaseBuilder } = require('../../../test-helper'); -const organizationPlacesCapacityRepository = require('../../../../lib/infrastructure/repositories/organization-places-capacity-repository'); -const categories = require('../../../../lib/domain/constants/organization-places-categories'); +import sinon from 'sinon'; +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as organizationPlacesCapacityRepository from '../../../../lib/infrastructure/repositories/organization-places-capacity-repository.js'; +import * as categories from '../../../../lib/domain/constants/organization-places-categories.js'; describe('Integration | Infrastructure | Repository | OrganizationPlacesCapacityRepository', function () { describe('#findByOrganizationId', function () { diff --git a/api/tests/integration/infrastructure/repositories/organization-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-repository_test.js index 2087d2d339a..f8243253722 100644 --- a/api/tests/integration/infrastructure/repositories/organization-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-repository_test.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const { catchErr, expect, knex, domainBuilder, databaseBuilder } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const Organization = require('../../../../lib/domain/models/Organization'); -const organizationRepository = require('../../../../lib/infrastructure/repositories/organization-repository'); -const { SamlIdentityProviders } = require('../../../../lib/domain/constants/saml-identity-providers'); +import _ from 'lodash'; +import { catchErr, expect, knex, domainBuilder, databaseBuilder } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import * as organizationRepository from '../../../../lib/infrastructure/repositories/organization-repository.js'; +import { SamlIdentityProviders } from '../../../../lib/domain/constants/saml-identity-providers.js'; describe('Integration | Repository | Organization', function () { describe('#create', function () { diff --git a/api/tests/integration/infrastructure/repositories/organization-tag-repository_test.js b/api/tests/integration/infrastructure/repositories/organization-tag-repository_test.js index ad2ca123465..eb8253ad154 100644 --- a/api/tests/integration/infrastructure/repositories/organization-tag-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organization-tag-repository_test.js @@ -1,9 +1,10 @@ -const { expect, knex, domainBuilder, databaseBuilder, catchErr } = require('../../../test-helper'); -const OrganizationTag = require('../../../../lib/domain/models/OrganizationTag'); -const { AlreadyExistingEntityError, OrganizationTagNotFound } = require('../../../../lib/domain/errors'); -const organizationTagRepository = require('../../../../lib/infrastructure/repositories/organization-tag-repository'); -const omit = require('lodash/omit'); -const BookshelfOrganizationTag = require('../../../../lib/infrastructure/orm-models/OrganizationTag'); +import { expect, knex, domainBuilder, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { OrganizationTag } from '../../../../lib/domain/models/OrganizationTag.js'; +import { AlreadyExistingEntityError, OrganizationTagNotFound } from '../../../../lib/domain/errors.js'; +import * as organizationTagRepository from '../../../../lib/infrastructure/repositories/organization-tag-repository.js'; +import lodash from 'lodash'; +const { omit } = lodash; +import { BookshelfOrganizationTag } from '../../../../lib/infrastructure/orm-models/OrganizationTag.js'; describe('Integration | Repository | OrganizationTagRepository', function () { describe('#create', function () { @@ -61,7 +62,7 @@ describe('Integration | Repository | OrganizationTagRepository', function () { await databaseBuilder.commit(); // when - await organizationTagRepository.delete({ organizationTagId: organizationTagToBeDeleteId }); + await organizationTagRepository.remove({ organizationTagId: organizationTagToBeDeleteId }); // then const nbOrganizationTagAfterDeletion = await BookshelfOrganizationTag.count(); @@ -81,7 +82,7 @@ describe('Integration | Repository | OrganizationTagRepository', function () { // when const inexistingOranizationTagId = organizationTagId + 1; - const error = await catchErr(organizationTagRepository.delete)({ + const error = await catchErr(organizationTagRepository.remove)({ organizationTagId: inexistingOranizationTagId, }); diff --git a/api/tests/integration/infrastructure/repositories/organizations-administration/organization-feature-repository_test.js b/api/tests/integration/infrastructure/repositories/organizations-administration/organization-feature-repository_test.js index 00ef30a5850..e9a33284c0f 100644 --- a/api/tests/integration/infrastructure/repositories/organizations-administration/organization-feature-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organizations-administration/organization-feature-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../../test-helper'); -const { knex } = require('../../../../../db/knex-database-connection'); -const organizationFeatureRepository = require('../../../../../lib/infrastructure/repositories/organizations-administration/organization-feature-repository'); +import { expect, databaseBuilder } from '../../../../test-helper.js'; +import { knex } from '../../../../../db/knex-database-connection.js'; +import * as organizationFeatureRepository from '../../../../../lib/infrastructure/repositories/organizations-administration/organization-feature-repository.js'; describe('Integration | Repository | Organization feature', function () { let organizationId; diff --git a/api/tests/integration/infrastructure/repositories/organizations-to-attach-to-target-profile-repository_test.js b/api/tests/integration/infrastructure/repositories/organizations-to-attach-to-target-profile-repository_test.js index 993213dd3dd..46bb082ca7b 100644 --- a/api/tests/integration/infrastructure/repositories/organizations-to-attach-to-target-profile-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organizations-to-attach-to-target-profile-repository_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, databaseBuilder, knex, catchErr } = require('../../../test-helper'); -const organizationsToAttachToTargetProfileRepository = require('../../../../lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, domainBuilder, databaseBuilder, knex, catchErr } from '../../../test-helper.js'; +import * as organizationsToAttachToTargetProfileRepository from '../../../../lib/infrastructure/repositories/organizations-to-attach-to-target-profile-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | Organizations-to-attach-to-target-profile', function () { describe('#attachOrganizations', function () { diff --git a/api/tests/integration/infrastructure/repositories/organizations/organization-places-lot-repository_test.js b/api/tests/integration/infrastructure/repositories/organizations/organization-places-lot-repository_test.js index e6540fbbada..ffddf34c215 100644 --- a/api/tests/integration/infrastructure/repositories/organizations/organization-places-lot-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/organizations/organization-places-lot-repository_test.js @@ -1,10 +1,10 @@ -const { expect, databaseBuilder, catchErr, sinon } = require('../../../../test-helper'); -const { knex } = require('../../../../../db/knex-database-connection'); -const organizationPlacesLotRepository = require('../../../../../lib/infrastructure/repositories/organizations/organization-places-lot-repository'); -const OrganizationPlacesLotManagement = require('../../../../../lib/domain/read-models/OrganizationPlacesLotManagement'); -const OrganizationPlacesLot = require('../../../../../lib/domain/models/OrganizationPlacesLot'); -const categories = require('../../../../../lib/domain/constants/organization-places-categories'); -const { NotFoundError, DeletedError } = require('../../../../../lib/domain/errors'); +import { expect, databaseBuilder, catchErr, sinon } from '../../../../test-helper.js'; +import { knex } from '../../../../../db/knex-database-connection.js'; +import * as organizationPlacesLotRepository from '../../../../../lib/infrastructure/repositories/organizations/organization-places-lot-repository.js'; +import { OrganizationPlacesLotManagement } from '../../../../../lib/domain/read-models/OrganizationPlacesLotManagement.js'; +import { OrganizationPlacesLot } from '../../../../../lib/domain/models/OrganizationPlacesLot.js'; +import * as categories from '../../../../../lib/domain/constants/organization-places-categories.js'; +import { NotFoundError, DeletedError } from '../../../../../lib/domain/errors.js'; describe('Integration | Repository | Organization Place', function () { describe('#findByOrganizationId', function () { @@ -262,7 +262,7 @@ describe('Integration | Repository | Organization Place', function () { await databaseBuilder.commit(); // when - await organizationPlacesLotRepository.delete({ + await organizationPlacesLotRepository.remove({ id: organizationPlace.id, deletedBy: user.id, }); @@ -284,7 +284,7 @@ describe('Integration | Repository | Organization Place', function () { await databaseBuilder.commit(); // when - const error = await catchErr(organizationPlacesLotRepository.delete)({ + const error = await catchErr(organizationPlacesLotRepository.remove)({ id: organizationPlace.id, deletedBy: user.id, }); @@ -304,7 +304,7 @@ describe('Integration | Repository | Organization Place', function () { await databaseBuilder.commit(); // when - await catchErr(organizationPlacesLotRepository.delete)({ + await catchErr(organizationPlacesLotRepository.remove)({ id: organizationPlace.id, deletedBy: user.id, }); diff --git a/api/tests/integration/infrastructure/repositories/participant-result-repository_test.js b/api/tests/integration/infrastructure/repositories/participant-result-repository_test.js index 7c36c2ad7da..4f3d2915f29 100644 --- a/api/tests/integration/infrastructure/repositories/participant-result-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/participant-result-repository_test.js @@ -1,9 +1,9 @@ -const { catchErr, expect, databaseBuilder, mockLearningContent, domainBuilder } = require('../../../test-helper'); -const participantResultRepository = require('../../../../lib/infrastructure/repositories/participant-result-repository'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { catchErr, expect, databaseBuilder, mockLearningContent, domainBuilder } from '../../../test-helper.js'; +import * as participantResultRepository from '../../../../lib/infrastructure/repositories/participant-result-repository.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/participant-results-shared-repository_test.js b/api/tests/integration/infrastructure/repositories/participant-results-shared-repository_test.js index 7c576faf587..1eedd47218b 100644 --- a/api/tests/integration/infrastructure/repositories/participant-results-shared-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/participant-results-shared-repository_test.js @@ -1,7 +1,7 @@ -const { expect, knex, databaseBuilder, mockLearningContent } = require('../../../test-helper'); -const participantResultsSharedRepository = require('../../../../lib/infrastructure/repositories/participant-results-shared-repository'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const { MAX_REACHABLE_PIX_BY_COMPETENCE } = require('../../../../lib/domain/constants'); +import { expect, knex, databaseBuilder, mockLearningContent } from '../../../test-helper.js'; +import { participantResultsSharedRepository } from '../../../../lib/infrastructure/repositories/participant-results-shared-repository.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { MAX_REACHABLE_PIX_BY_COMPETENCE } from '../../../../lib/domain/constants.js'; describe('Integration | Repository | Campaign Participant Result Shared Repository', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/participations-for-campaign-management-repository_test.js b/api/tests/integration/infrastructure/repositories/participations-for-campaign-management-repository_test.js index 748d2c31576..3073eaf9a1d 100644 --- a/api/tests/integration/infrastructure/repositories/participations-for-campaign-management-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/participations-for-campaign-management-repository_test.js @@ -1,9 +1,9 @@ -const { expect, databaseBuilder, catchErr, knex } = require('../../../test-helper'); -const participationsForCampaignManagementRepository = require('../../../../lib/infrastructure/repositories/participations-for-campaign-management-repository'); -const _ = require('lodash'); -const ParticipationForCampaignManagement = require('../../../../lib/domain/models/ParticipationForCampaignManagement'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder, catchErr, knex } from '../../../test-helper.js'; +import * as participationsForCampaignManagementRepository from '../../../../lib/infrastructure/repositories/participations-for-campaign-management-repository.js'; +import _ from 'lodash'; +import { ParticipationForCampaignManagement } from '../../../../lib/domain/models/ParticipationForCampaignManagement.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/participations-for-user-management-repository_test.js b/api/tests/integration/infrastructure/repositories/participations-for-user-management-repository_test.js index 01cb2ad9b4d..3b814cde9cb 100644 --- a/api/tests/integration/infrastructure/repositories/participations-for-user-management-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/participations-for-user-management-repository_test.js @@ -1,8 +1,8 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const participationsForUserManagementRepository = require('../../../../lib/infrastructure/repositories/participations-for-user-management-repository'); -const _ = require('lodash'); -const CampaignParticipationForUserManagement = require('../../../../lib/domain/read-models/CampaignParticipationForUserManagement'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as participationsForUserManagementRepository from '../../../../lib/infrastructure/repositories/participations-for-user-management-repository.js'; +import _ from 'lodash'; +import { CampaignParticipationForUserManagement } from '../../../../lib/domain/read-models/CampaignParticipationForUserManagement.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/infrastructure/repositories/partner-certification-scoring-repository_test.js b/api/tests/integration/infrastructure/repositories/partner-certification-scoring-repository_test.js index 61079bd083f..4e6556fd17f 100644 --- a/api/tests/integration/infrastructure/repositories/partner-certification-scoring-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/partner-certification-scoring-repository_test.js @@ -1,7 +1,8 @@ -const { expect, databaseBuilder, domainBuilder, knex, sinon } = require('../../../test-helper'); -const omit = require('lodash/omit'); -const partnerCertificationScoringRepository = require('../../../../lib/infrastructure/repositories/partner-certification-scoring-repository'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); +import { expect, databaseBuilder, domainBuilder, knex, sinon } from '../../../test-helper.js'; +import lodash from 'lodash'; +const { omit } = lodash; +import * as partnerCertificationScoringRepository from '../../../../lib/infrastructure/repositories/partner-certification-scoring-repository.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; describe('Integration | Repository | Partner Certification Scoring', function () { const COMPLEMENTARY_CERTIFICATION_COURSE_RESULTS_TABLE_NAME = 'complementary-certification-course-results'; diff --git a/api/tests/integration/infrastructure/repositories/pole-emploi-sending-repository_test.js b/api/tests/integration/infrastructure/repositories/pole-emploi-sending-repository_test.js index b31bf75d01e..ceccaa91623 100644 --- a/api/tests/integration/infrastructure/repositories/pole-emploi-sending-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/pole-emploi-sending-repository_test.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, knex, domainBuilder } = require('../../../test-helper'); -const poleEmploiSendingRepository = require('../../../../lib/infrastructure/repositories/pole-emploi-sending-repository'); -const settings = require('../../../../lib/config'); +import _ from 'lodash'; +import { expect, databaseBuilder, knex, domainBuilder } from '../../../test-helper.js'; +import * as poleEmploiSendingRepository from '../../../../lib/infrastructure/repositories/pole-emploi-sending-repository.js'; +import { config as settings } from '../../../../lib/config.js'; const poleEmploiSendingFactory = databaseBuilder.factory.poleEmploiSendingFactory; describe('Integration | Repository | PoleEmploiSending', function () { diff --git a/api/tests/integration/infrastructure/repositories/prescriber-repository_test.js b/api/tests/integration/infrastructure/repositories/prescriber-repository_test.js index 335ffd376f1..737c8c71751 100644 --- a/api/tests/integration/infrastructure/repositories/prescriber-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/prescriber-repository_test.js @@ -1,15 +1,14 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const bcrypt = require('bcrypt'); -const settings = require('../../../../lib/config'); - -const { ForbiddenAccess, UserNotFoundError } = require('../../../../lib/domain/errors'); -const prescriberRepository = require('../../../../lib/infrastructure/repositories/prescriber-repository'); -const Prescriber = require('../../../../lib/domain/read-models/Prescriber'); -const Membership = require('../../../../lib/domain/models/Membership'); -const UserOrgaSettings = require('../../../../lib/domain/models/UserOrgaSettings'); -const Organization = require('../../../../lib/domain/models/Organization'); -const Tag = require('../../../../lib/domain/models/Tag'); -const apps = require('../../../../lib/domain/constants.js'); +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import bcrypt from 'bcrypt'; +import { config as settings } from '../../../../lib/config.js'; +import { ForbiddenAccess, UserNotFoundError } from '../../../../lib/domain/errors.js'; +import * as prescriberRepository from '../../../../lib/infrastructure/repositories/prescriber-repository.js'; +import { Prescriber } from '../../../../lib/domain/read-models/Prescriber.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { UserOrgaSettings } from '../../../../lib/domain/models/UserOrgaSettings.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { Tag } from '../../../../lib/domain/models/Tag.js'; +import * as apps from '../../../../lib/domain/constants.js'; describe('Integration | Infrastructure | Repository | Prescriber', function () { const userToInsert = { diff --git a/api/tests/integration/infrastructure/repositories/prescriber-role-repository_test.js b/api/tests/integration/infrastructure/repositories/prescriber-role-repository_test.js index 945315de708..875c339bb62 100644 --- a/api/tests/integration/infrastructure/repositories/prescriber-role-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/prescriber-role-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const prescriberRoleRepository = require('../../../../lib/infrastructure/repositories/prescriber-role-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import * as prescriberRoleRepository from '../../../../lib/infrastructure/repositories/prescriber-role-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | Campaign', function () { describe('#getForCampaign', function () { diff --git a/api/tests/integration/infrastructure/repositories/reset-password-demands-repository_test.js b/api/tests/integration/infrastructure/repositories/reset-password-demands-repository_test.js index c1ba5850083..eb88d586c8d 100644 --- a/api/tests/integration/infrastructure/repositories/reset-password-demands-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/reset-password-demands-repository_test.js @@ -1,6 +1,6 @@ -const { expect, knex, databaseBuilder, catchErr } = require('../../../test-helper'); -const resetPasswordDemandsRepository = require('../../../../lib/infrastructure/repositories/reset-password-demands-repository'); -const { PasswordResetDemandNotFoundError } = require('../../../../lib/domain/errors'); +import { expect, knex, databaseBuilder, catchErr } from '../../../test-helper.js'; +import * as resetPasswordDemandsRepository from '../../../../lib/infrastructure/repositories/reset-password-demands-repository.js'; +import { PasswordResetDemandNotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Infrastructure | Repository | reset-password-demands-repository', function () { afterEach(function () { diff --git a/api/tests/integration/infrastructure/repositories/sco-certification-candidate-repository_test.js b/api/tests/integration/infrastructure/repositories/sco-certification-candidate-repository_test.js index a66b998d3aa..10d2f889c3e 100644 --- a/api/tests/integration/infrastructure/repositories/sco-certification-candidate-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sco-certification-candidate-repository_test.js @@ -1,6 +1,6 @@ -const { databaseBuilder, expect, knex, domainBuilder } = require('../../../test-helper'); -const scoCertificationCandidateRepository = require('../../../../lib/infrastructure/repositories/sco-certification-candidate-repository'); -const _ = require('lodash'); +import { databaseBuilder, expect, knex, domainBuilder } from '../../../test-helper.js'; +import * as scoCertificationCandidateRepository from '../../../../lib/infrastructure/repositories/sco-certification-candidate-repository.js'; +import _ from 'lodash'; describe('Integration | Repository | SCOCertificationCandidate', function () { describe('#addNonEnrolledCandidatesToSession', function () { diff --git a/api/tests/integration/infrastructure/repositories/sco-organization-participant-repository_test.js b/api/tests/integration/infrastructure/repositories/sco-organization-participant-repository_test.js index bb6f1ec46b4..5f4dbc0c081 100644 --- a/api/tests/integration/infrastructure/repositories/sco-organization-participant-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sco-organization-participant-repository_test.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const { expect, databaseBuilder } = require('../../../test-helper'); -const scoOrganizationParticipantRepository = require('../../../../lib/infrastructure/repositories/sco-organization-participant-repository'); -const ScoOrganizationParticipant = require('../../../../lib/domain/read-models/ScoOrganizationParticipant'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import _ from 'lodash'; +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as scoOrganizationParticipantRepository from '../../../../lib/infrastructure/repositories/sco-organization-participant-repository.js'; +import { ScoOrganizationParticipant } from '../../../../lib/domain/read-models/ScoOrganizationParticipant.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; describe('Integration | Infrastructure | Repository | sco-organization-participant-repository', function () { describe('#findPaginatedFilteredScoParticipants', function () { diff --git a/api/tests/integration/infrastructure/repositories/sessions/finalized-session-repository_test.js b/api/tests/integration/infrastructure/repositories/sessions/finalized-session-repository_test.js index 5092de33b2b..23c873777e5 100644 --- a/api/tests/integration/infrastructure/repositories/sessions/finalized-session-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sessions/finalized-session-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, knex, catchErr } = require('../../../../test-helper'); -const finalizedSessionRepository = require('../../../../../lib/infrastructure/repositories/sessions/finalized-session-repository'); -const FinalizedSession = require('../../../../../lib/domain/models/FinalizedSession'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); +import { expect, databaseBuilder, knex, catchErr } from '../../../../test-helper.js'; +import * as finalizedSessionRepository from '../../../../../lib/infrastructure/repositories/sessions/finalized-session-repository.js'; +import { FinalizedSession } from '../../../../../lib/domain/models/FinalizedSession.js'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; describe('Integration | Repository | Finalized-session', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/sessions/jury-session-repository_test.js b/api/tests/integration/infrastructure/repositories/sessions/jury-session-repository_test.js index 7ea1236f837..08318c2feca 100644 --- a/api/tests/integration/infrastructure/repositories/sessions/jury-session-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sessions/jury-session-repository_test.js @@ -1,10 +1,9 @@ -const _ = require('lodash'); -const { databaseBuilder, expect, catchErr, domainBuilder } = require('../../../../test-helper'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); -const JurySession = require('../../../../../lib/domain/models/JurySession'); -const { statuses } = require('../../../../../lib/domain/models/JurySession'); -const CertificationOfficer = require('../../../../../lib/domain/models/CertificationOfficer'); -const jurySessionRepository = require('../../../../../lib/infrastructure/repositories/sessions/jury-session-repository'); +import _ from 'lodash'; +import { databaseBuilder, expect, catchErr, domainBuilder } from '../../../../test-helper.js'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; +import { JurySession, statuses } from '../../../../../lib/domain/models/JurySession.js'; +import { CertificationOfficer } from '../../../../../lib/domain/models/CertificationOfficer.js'; +import * as jurySessionRepository from '../../../../../lib/infrastructure/repositories/sessions/jury-session-repository.js'; describe('Integration | Repository | JurySession', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/sessions/session-for-attendance-sheet-repository_test.js b/api/tests/integration/infrastructure/repositories/sessions/session-for-attendance-sheet-repository_test.js index 8ba2eecd594..a7334d1d35c 100644 --- a/api/tests/integration/infrastructure/repositories/sessions/session-for-attendance-sheet-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sessions/session-for-attendance-sheet-repository_test.js @@ -1,8 +1,8 @@ -const { databaseBuilder, expect, catchErr } = require('../../../../test-helper'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); -const sessionForAttendanceSheetRepository = require('../../../../../lib/infrastructure/repositories/sessions/session-for-attendance-sheet-repository'); -const SessionForAttendanceSheet = require('../../../../../lib/domain/read-models/SessionForAttendanceSheet'); -const CertificationCandidateForAttendanceSheet = require('../../../../../lib/domain/read-models/CertificationCandidateForAttendanceSheet'); +import { databaseBuilder, expect, catchErr } from '../../../../test-helper.js'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; +import * as sessionForAttendanceSheetRepository from '../../../../../lib/infrastructure/repositories/sessions/session-for-attendance-sheet-repository.js'; +import { SessionForAttendanceSheet } from '../../../../../lib/domain/read-models/SessionForAttendanceSheet.js'; +import { CertificationCandidateForAttendanceSheet } from '../../../../../lib/domain/read-models/CertificationCandidateForAttendanceSheet.js'; describe('Integration | Repository | Session-for-attendance-sheet', function () { describe('#getWithCertificationCandidates', function () { diff --git a/api/tests/integration/infrastructure/repositories/sessions/session-for-supervising-repository_test.js b/api/tests/integration/infrastructure/repositories/sessions/session-for-supervising-repository_test.js index 3a07f33280b..bce25dcf8f3 100644 --- a/api/tests/integration/infrastructure/repositories/sessions/session-for-supervising-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sessions/session-for-supervising-repository_test.js @@ -1,9 +1,9 @@ -const { databaseBuilder, expect, catchErr } = require('../../../../test-helper'); -const _ = require('lodash'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); -const SessionForSupervising = require('../../../../../lib/domain/read-models/SessionForSupervising'); -const sessionForSupervisingRepository = require('../../../../../lib/infrastructure/repositories/sessions/session-for-supervising-repository'); -const Assessment = require('../../../../../lib/domain/models/Assessment'); +import { databaseBuilder, expect, catchErr } from '../../../../test-helper.js'; +import _ from 'lodash'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; +import { SessionForSupervising } from '../../../../../lib/domain/read-models/SessionForSupervising.js'; +import * as sessionForSupervisingRepository from '../../../../../lib/infrastructure/repositories/sessions/session-for-supervising-repository.js'; +import { Assessment } from '../../../../../lib/domain/models/Assessment.js'; describe('Integration | Repository | SessionForSupervising', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/sessions/session-for-supervisor-kit-repository_test.js b/api/tests/integration/infrastructure/repositories/sessions/session-for-supervisor-kit-repository_test.js index dfcd7570566..913e21c5830 100644 --- a/api/tests/integration/infrastructure/repositories/sessions/session-for-supervisor-kit-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sessions/session-for-supervisor-kit-repository_test.js @@ -1,6 +1,6 @@ -const { databaseBuilder, expect } = require('../../../../test-helper'); -const sessionForSupervisorKitRepository = require('../../../../../lib/infrastructure/repositories/sessions/session-for-supervisor-kit-repository'); -const SessionForSupervisorKit = require('../../../../../lib/domain/read-models/SessionForSupervisorKit'); +import { databaseBuilder, expect } from '../../../../test-helper.js'; +import * as sessionForSupervisorKitRepository from '../../../../../lib/infrastructure/repositories/sessions/session-for-supervisor-kit-repository.js'; +import { SessionForSupervisorKit } from '../../../../../lib/domain/read-models/SessionForSupervisorKit.js'; describe('Integration | Repository | Session-for-supervisor-kit', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/sessions/session-jury-comment-repository_test.js b/api/tests/integration/infrastructure/repositories/sessions/session-jury-comment-repository_test.js index c23165f05f2..278132ed6c3 100644 --- a/api/tests/integration/infrastructure/repositories/sessions/session-jury-comment-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sessions/session-jury-comment-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, domainBuilder, catchErr } = require('../../../../test-helper'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); -const sessionJuryCommentRepository = require('../../../../../lib/infrastructure/repositories/sessions/session-jury-comment-repository'); +import { expect, databaseBuilder, domainBuilder, catchErr } from '../../../../test-helper.js'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; +import * as sessionJuryCommentRepository from '../../../../../lib/infrastructure/repositories/sessions/session-jury-comment-repository.js'; describe('Integration | Infrastructure | Repository | session-jury-comment-repository', function () { context('#get', function () { @@ -150,7 +150,7 @@ describe('Integration | Infrastructure | Repository | session-jury-comment-repos }); // when - await sessionJuryCommentRepository.delete(123); + await sessionJuryCommentRepository.remove(123); // then const deletedSessionJuryComment = await sessionJuryCommentRepository.get(123); diff --git a/api/tests/integration/infrastructure/repositories/sessions/session-repository_test.js b/api/tests/integration/infrastructure/repositories/sessions/session-repository_test.js index f17580791b8..8f73f56e8e8 100644 --- a/api/tests/integration/infrastructure/repositories/sessions/session-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sessions/session-repository_test.js @@ -1,9 +1,8 @@ -const { databaseBuilder, expect, knex, domainBuilder, catchErr } = require('../../../../test-helper'); -const _ = require('lodash'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); -const Session = require('../../../../../lib/domain/models/Session'); -const { statuses } = require('../../../../../lib/domain/models/Session'); -const sessionRepository = require('../../../../../lib/infrastructure/repositories/sessions/session-repository'); +import { databaseBuilder, expect, knex, domainBuilder, catchErr } from '../../../../test-helper.js'; +import _ from 'lodash'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; +import { Session, statuses } from '../../../../../lib/domain/models/Session.js'; +import * as sessionRepository from '../../../../../lib/infrastructure/repositories/sessions/session-repository.js'; describe('Integration | Repository | Session', function () { describe('#save', function () { @@ -556,7 +555,7 @@ describe('Integration | Repository | Session', function () { await databaseBuilder.commit(); // when - await sessionRepository.delete(sessionId); + await sessionRepository.remove(sessionId); // then const foundSession = await knex('sessions').select('id').where({ id: sessionId }).first(); @@ -582,7 +581,7 @@ describe('Integration | Repository | Session', function () { await databaseBuilder.commit(); // when - await sessionRepository.delete(sessionId); + await sessionRepository.remove(sessionId); // then const foundSession = await knex('sessions').select('id').where({ id: sessionId }).first(); @@ -605,7 +604,7 @@ describe('Integration | Repository | Session', function () { await databaseBuilder.commit(); // when - await sessionRepository.delete(sessionId); + await sessionRepository.remove(sessionId); // then const foundSession = await knex('sessions').select('id').where({ id: sessionId }).first(); @@ -623,7 +622,7 @@ describe('Integration | Repository | Session', function () { await databaseBuilder.commit(); // when - await sessionRepository.delete(sessionId); + await sessionRepository.remove(sessionId); // then const foundSession = await knex('sessions').select('id').where({ id: sessionId }).first(); @@ -638,7 +637,7 @@ describe('Integration | Repository | Session', function () { const sessionId = 123456; // when - const error = await catchErr(sessionRepository.delete)(sessionId); + const error = await catchErr(sessionRepository.remove)(sessionId); // then expect(error).to.be.instanceOf(NotFoundError); diff --git a/api/tests/integration/infrastructure/repositories/sessions/session-summary-repository_test.js b/api/tests/integration/infrastructure/repositories/sessions/session-summary-repository_test.js index 497abb01f7b..40a7e80169d 100644 --- a/api/tests/integration/infrastructure/repositories/sessions/session-summary-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sessions/session-summary-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../../test-helper'); -const sessionSummaryRepository = require('../../../../../lib/infrastructure/repositories/sessions/session-summary-repository'); -const _ = require('lodash'); +import { expect, databaseBuilder, domainBuilder } from '../../../../test-helper.js'; +import * as sessionSummaryRepository from '../../../../../lib/infrastructure/repositories/sessions/session-summary-repository.js'; +import _ from 'lodash'; describe('Integration | Repository | Session Summary', function () { describe('#findPaginatedByCertificationCenterId', function () { diff --git a/api/tests/integration/infrastructure/repositories/skill-repository_test.js b/api/tests/integration/infrastructure/repositories/skill-repository_test.js index d463961f544..903012eb024 100644 --- a/api/tests/integration/infrastructure/repositories/skill-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/skill-repository_test.js @@ -1,7 +1,7 @@ -const { expect, mockLearningContent, domainBuilder, catchErr } = require('../../../test-helper'); -const Skill = require('../../../../lib/domain/models/Skill'); -const skillRepository = require('../../../../lib/infrastructure/repositories/skill-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, mockLearningContent, domainBuilder, catchErr } from '../../../test-helper.js'; +import { Skill } from '../../../../lib/domain/models/Skill.js'; +import * as skillRepository from '../../../../lib/infrastructure/repositories/skill-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | skill-repository', function () { describe('#list', function () { diff --git a/api/tests/integration/infrastructure/repositories/skill-set-repository_test.js b/api/tests/integration/infrastructure/repositories/skill-set-repository_test.js index 83c1b059818..f3a8122141f 100644 --- a/api/tests/integration/infrastructure/repositories/skill-set-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/skill-set-repository_test.js @@ -1,7 +1,8 @@ -const { knex, expect, databaseBuilder } = require('../../../test-helper'); -const skillSetRepository = require('../../../../lib/infrastructure/repositories/skill-set-repository'); -const omit = require('lodash/omit'); -const SkillSet = require('../../../../lib/domain/models/SkillSet'); +import { knex, expect, databaseBuilder } from '../../../test-helper.js'; +import * as skillSetRepository from '../../../../lib/infrastructure/repositories/skill-set-repository.js'; +import lodash from 'lodash'; +const { omit } = lodash; +import { SkillSet } from '../../../../lib/domain/models/SkillSet.js'; describe('Integration | Repository | Skill Set Repository', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/repositories/student-repository_test.js b/api/tests/integration/infrastructure/repositories/student-repository_test.js index 38b6be9c7b2..daabba74821 100644 --- a/api/tests/integration/infrastructure/repositories/student-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/student-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const studentRepository = require('../../../../lib/infrastructure/repositories/student-repository'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as studentRepository from '../../../../lib/infrastructure/repositories/student-repository.js'; describe('Integration | Infrastructure | Repository | student-repository', function () { describe('#findReconciledStudentsByNationalStudentId', function () { diff --git a/api/tests/integration/infrastructure/repositories/sup-organization-learner-repository_test.js b/api/tests/integration/infrastructure/repositories/sup-organization-learner-repository_test.js index 00a9638bd34..ebcee6ec21f 100644 --- a/api/tests/integration/infrastructure/repositories/sup-organization-learner-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sup-organization-learner-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, knex, domainBuilder } = require('../../../test-helper'); -const supOrganizationLearnerRepository = require('../../../../lib/infrastructure/repositories/sup-organization-learner-repository'); -const OrganizationLearner = require('../../../../lib/domain/models/OrganizationLearner'); +import { expect, databaseBuilder, knex, domainBuilder } from '../../../test-helper.js'; +import * as supOrganizationLearnerRepository from '../../../../lib/infrastructure/repositories/sup-organization-learner-repository.js'; +import { OrganizationLearner } from '../../../../lib/domain/models/OrganizationLearner.js'; describe('Integration | Infrastructure | Repository | sup-organization-learner-repository', function () { describe('#findOneByStudentNumber', function () { diff --git a/api/tests/integration/infrastructure/repositories/sup-organization-participant-repository_test.js b/api/tests/integration/infrastructure/repositories/sup-organization-participant-repository_test.js index 8391b1d81e6..1c2daffb141 100644 --- a/api/tests/integration/infrastructure/repositories/sup-organization-participant-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/sup-organization-participant-repository_test.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const { expect, databaseBuilder } = require('../../../test-helper'); -const supOrganizationParticipantRepository = require('../../../../lib/infrastructure/repositories/sup-organization-participant-repository'); -const SupOrganizationParticipant = require('../../../../lib/domain/read-models/SupOrganizationParticipant'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import _ from 'lodash'; +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as supOrganizationParticipantRepository from '../../../../lib/infrastructure/repositories/sup-organization-participant-repository.js'; +import { SupOrganizationParticipant } from '../../../../lib/domain/read-models/SupOrganizationParticipant.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; describe('Integration | Infrastructure | Repository | sup-organization-participant-repository', function () { describe('#findPaginatedFilteredSupParticipants', function () { diff --git a/api/tests/integration/infrastructure/repositories/supervisor-access-repository_test.js b/api/tests/integration/infrastructure/repositories/supervisor-access-repository_test.js index 5a8643b170c..18df682f4a2 100644 --- a/api/tests/integration/infrastructure/repositories/supervisor-access-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/supervisor-access-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const supervisorAccessRepository = require('../../../../lib/infrastructure/repositories/supervisor-access-repository'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import * as supervisorAccessRepository from '../../../../lib/infrastructure/repositories/supervisor-access-repository.js'; describe('Integration | Repository | supervisor-access-repository', function () { describe('#create', function () { diff --git a/api/tests/integration/infrastructure/repositories/tag-repository_test.js b/api/tests/integration/infrastructure/repositories/tag-repository_test.js index ce06ac7e004..b28508d2921 100644 --- a/api/tests/integration/infrastructure/repositories/tag-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/tag-repository_test.js @@ -1,9 +1,7 @@ -const { expect, knex, domainBuilder, databaseBuilder, catchErr } = require('../../../test-helper'); - -const { AlreadyExistingEntityError, NotFoundError } = require('../../../../lib/domain/errors'); - -const Tag = require('../../../../lib/domain/models/Tag'); -const tagRepository = require('../../../../lib/infrastructure/repositories/tag-repository'); +import { expect, knex, domainBuilder, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { AlreadyExistingEntityError, NotFoundError } from '../../../../lib/domain/errors.js'; +import { Tag } from '../../../../lib/domain/models/Tag.js'; +import * as tagRepository from '../../../../lib/infrastructure/repositories/tag-repository.js'; describe('Integration | Repository | TagRepository', function () { afterEach(async function () { diff --git a/api/tests/integration/infrastructure/repositories/target-profile-for-admin-repository_test.js b/api/tests/integration/infrastructure/repositories/target-profile-for-admin-repository_test.js index 97a55a952f5..08ba388b7d7 100644 --- a/api/tests/integration/infrastructure/repositories/target-profile-for-admin-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/target-profile-for-admin-repository_test.js @@ -1,7 +1,7 @@ -const { expect, databaseBuilder, catchErr, mockLearningContent, domainBuilder } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const targetProfileForAdminRepository = require('../../../../lib/infrastructure/repositories/target-profile-for-admin-repository'); -const TargetProfileForAdmin = require('../../../../lib/domain/models/TargetProfileForAdmin'); +import { expect, databaseBuilder, catchErr, mockLearningContent, domainBuilder } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as targetProfileForAdminRepository from '../../../../lib/infrastructure/repositories/target-profile-for-admin-repository.js'; +import { TargetProfileForAdmin } from '../../../../lib/domain/models/TargetProfileForAdmin.js'; describe('Integration | Repository | target-profile-for-admin', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/target-profile-for-update-repository_test.js b/api/tests/integration/infrastructure/repositories/target-profile-for-update-repository_test.js index 185feabd7fe..5c69d4c4172 100644 --- a/api/tests/integration/infrastructure/repositories/target-profile-for-update-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/target-profile-for-update-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const targetProfileForUpdateRepository = require('../../../../lib/infrastructure/repositories/target-profile-for-update-repository'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import * as targetProfileForUpdateRepository from '../../../../lib/infrastructure/repositories/target-profile-for-update-repository.js'; describe('Integration | Repository | Target-profile-for-update', function () { describe('#update', function () { diff --git a/api/tests/integration/infrastructure/repositories/target-profile-repository_test.js b/api/tests/integration/infrastructure/repositories/target-profile-repository_test.js index 36891d5fdd0..b1e76585947 100644 --- a/api/tests/integration/infrastructure/repositories/target-profile-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/target-profile-repository_test.js @@ -1,9 +1,9 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, catchErr, knex, domainBuilder } = require('../../../test-helper'); -const TargetProfile = require('../../../../lib/domain/models/TargetProfile'); -const targetProfileRepository = require('../../../../lib/infrastructure/repositories/target-profile-repository'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const { NotFoundError, ObjectValidationError, InvalidSkillSetError } = require('../../../../lib/domain/errors'); +import _ from 'lodash'; +import { expect, databaseBuilder, catchErr, knex, domainBuilder } from '../../../test-helper.js'; +import { TargetProfile } from '../../../../lib/domain/models/TargetProfile.js'; +import * as targetProfileRepository from '../../../../lib/infrastructure/repositories/target-profile-repository.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { NotFoundError, ObjectValidationError, InvalidSkillSetError } from '../../../../lib/domain/errors.js'; describe('Integration | Repository | Target-profile', function () { describe('#create', function () { diff --git a/api/tests/integration/infrastructure/repositories/target-profile-share-repository_test.js b/api/tests/integration/infrastructure/repositories/target-profile-share-repository_test.js index 573af82ec18..302a94e56b0 100644 --- a/api/tests/integration/infrastructure/repositories/target-profile-share-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/target-profile-share-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const _ = require('lodash'); -const targetProfileShareRepository = require('../../../../lib/infrastructure/repositories/target-profile-share-repository'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import _ from 'lodash'; +import * as targetProfileShareRepository from '../../../../lib/infrastructure/repositories/target-profile-share-repository.js'; describe('Integration | Repository | Target-profile-share', function () { describe('#addTargetProfilesToOrganization', function () { diff --git a/api/tests/integration/infrastructure/repositories/target-profile-summary-for-admin-repository_test.js b/api/tests/integration/infrastructure/repositories/target-profile-summary-for-admin-repository_test.js index f9b9d13b0c1..1cd50a54f83 100644 --- a/api/tests/integration/infrastructure/repositories/target-profile-summary-for-admin-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/target-profile-summary-for-admin-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, domainBuilder } = require('../../../test-helper'); -const targetProfileSummaryForAdminRepository = require('../../../../lib/infrastructure/repositories/target-profile-summary-for-admin-repository'); +import { expect, databaseBuilder, domainBuilder } from '../../../test-helper.js'; +import * as targetProfileSummaryForAdminRepository from '../../../../lib/infrastructure/repositories/target-profile-summary-for-admin-repository.js'; describe('Integration | Repository | Target-profile-summary-for-admin', function () { describe('#findPaginatedFiltered', function () { diff --git a/api/tests/integration/infrastructure/repositories/target-profile-training-repository_test.js b/api/tests/integration/infrastructure/repositories/target-profile-training-repository_test.js index a822099625d..ec75a1a642f 100644 --- a/api/tests/integration/infrastructure/repositories/target-profile-training-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/target-profile-training-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, sinon } = require('../../../test-helper'); -const targetProfileTrainingRepository = require('../../../../lib/infrastructure/repositories/target-profile-training-repository'); +import { expect, databaseBuilder, sinon } from '../../../test-helper.js'; +import * as targetProfileTrainingRepository from '../../../../lib/infrastructure/repositories/target-profile-training-repository.js'; describe('Integration | Repository | target-profile-training-repository', function () { describe('#create', function () { diff --git a/api/tests/integration/infrastructure/repositories/thematic-repository_test.js b/api/tests/integration/infrastructure/repositories/thematic-repository_test.js index 101234b9bac..21440b98d13 100644 --- a/api/tests/integration/infrastructure/repositories/thematic-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/thematic-repository_test.js @@ -1,6 +1,6 @@ -const { expect, mockLearningContent, domainBuilder } = require('../../../test-helper'); -const thematicRepository = require('../../../../lib/infrastructure/repositories/thematic-repository'); -const Thematic = require('../../../../lib/domain/models/Thematic'); +import { expect, mockLearningContent, domainBuilder } from '../../../test-helper.js'; +import * as thematicRepository from '../../../../lib/infrastructure/repositories/thematic-repository.js'; +import { Thematic } from '../../../../lib/domain/models/Thematic.js'; describe('Integration | Repository | thematic-repository', function () { describe('#list', function () { diff --git a/api/tests/integration/infrastructure/repositories/training-repository_test.js b/api/tests/integration/infrastructure/repositories/training-repository_test.js index f4d56b771ae..c302331262f 100644 --- a/api/tests/integration/infrastructure/repositories/training-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/training-repository_test.js @@ -1,14 +1,15 @@ -const { expect, databaseBuilder, domainBuilder, catchErr, knex, mockLearningContent } = require('../../../test-helper'); -const trainingRepository = require('../../../../lib/infrastructure/repositories/training-repository'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const TrainingSummary = require('../../../../lib/domain/read-models/TrainingSummary'); -const Training = require('../../../../lib/domain/models/Training'); -const UserRecommendedTraining = require('../../../../lib/domain/read-models/UserRecommendedTraining'); -const TrainingTriggerForAdmin = require('../../../../lib/domain/read-models/TrainingTriggerForAdmin'); -const TrainingForAdmin = require('../../../../lib/domain/read-models/TrainingForAdmin'); -const TrainingTrigger = require('../../../../lib/domain/models/TrainingTrigger'); -const TrainingTriggerTube = require('../../../../lib/domain/models/TrainingTriggerTube'); -const _ = require('lodash'); +import { expect, databaseBuilder, domainBuilder, catchErr, knex, mockLearningContent } from '../../../test-helper.js'; + +import * as trainingRepository from '../../../../lib/infrastructure/repositories/training-repository.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { TrainingSummary } from '../../../../lib/domain/read-models/TrainingSummary.js'; +import { Training } from '../../../../lib/domain/models/Training.js'; +import { UserRecommendedTraining } from '../../../../lib/domain/read-models/UserRecommendedTraining.js'; +import { TrainingTriggerForAdmin } from '../../../../lib/domain/read-models/TrainingTriggerForAdmin.js'; +import { TrainingForAdmin } from '../../../../lib/domain/read-models/TrainingForAdmin.js'; +import { TrainingTrigger } from '../../../../lib/domain/models/TrainingTrigger.js'; +import { TrainingTriggerTube } from '../../../../lib/domain/models/TrainingTriggerTube.js'; +import _ from 'lodash'; describe('Integration | Repository | training-repository', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/training-trigger-repository_test.js b/api/tests/integration/infrastructure/repositories/training-trigger-repository_test.js index c3ed9047ca6..0b6bccc9ff8 100644 --- a/api/tests/integration/infrastructure/repositories/training-trigger-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/training-trigger-repository_test.js @@ -1,4 +1,4 @@ -const { +import { expect, databaseBuilder, domainBuilder, @@ -7,13 +7,14 @@ const { learningContentBuilder, sinon, catchErr, -} = require('../../../test-helper'); -const trainingTriggerRepository = require('../../../../lib/infrastructure/repositories/training-trigger-repository'); -const { TrainingTrigger, TrainingTriggerTube } = require('../../../../lib/domain/models'); -const TrainingTriggerForAdmin = require('../../../../lib/domain/read-models/TrainingTriggerForAdmin'); -const _ = require('lodash'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const logger = require('../../../../lib/infrastructure/logger'); +} from '../../../test-helper.js'; + +import * as trainingTriggerRepository from '../../../../lib/infrastructure/repositories/training-trigger-repository.js'; +import { TrainingTrigger, TrainingTriggerTube } from '../../../../lib/domain/models/index.js'; +import { TrainingTriggerForAdmin } from '../../../../lib/domain/read-models/TrainingTriggerForAdmin.js'; +import _ from 'lodash'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; describe('Integration | Repository | training-trigger-repository', function () { let learningContent; @@ -106,7 +107,7 @@ describe('Integration | Repository | training-trigger-repository', function () { ], }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); }); diff --git a/api/tests/integration/infrastructure/repositories/tube-repository_test.js b/api/tests/integration/infrastructure/repositories/tube-repository_test.js index ec531eade31..f3dbfdb08d4 100644 --- a/api/tests/integration/infrastructure/repositories/tube-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/tube-repository_test.js @@ -1,5 +1,5 @@ -const { expect, mockLearningContent, domainBuilder } = require('../../../test-helper'); -const tubeRepository = require('../../../../lib/infrastructure/repositories/tube-repository'); +import { expect, mockLearningContent, domainBuilder } from '../../../test-helper.js'; +import * as tubeRepository from '../../../../lib/infrastructure/repositories/tube-repository.js'; describe('Integration | Repository | tube-repository', function () { describe('#get', function () { diff --git a/api/tests/integration/infrastructure/repositories/tutorial-evaluation-repository_test.js b/api/tests/integration/infrastructure/repositories/tutorial-evaluation-repository_test.js index 2d4b3f06cbe..cdcead0ccd5 100644 --- a/api/tests/integration/infrastructure/repositories/tutorial-evaluation-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/tutorial-evaluation-repository_test.js @@ -1,6 +1,6 @@ -const { expect, knex, databaseBuilder } = require('../../../test-helper'); -const tutorialEvaluationRepository = require('../../../../lib/infrastructure/repositories/tutorial-evaluation-repository'); -const TutorialEvaluation = require('../../../../lib/domain/models/TutorialEvaluation'); +import { expect, knex, databaseBuilder } from '../../../test-helper.js'; +import * as tutorialEvaluationRepository from '../../../../lib/infrastructure/repositories/tutorial-evaluation-repository.js'; +import { TutorialEvaluation } from '../../../../lib/domain/models/TutorialEvaluation.js'; describe('Integration | Infrastructure | Repository | tutorialEvaluationRepository', function () { let userId, tutorialId, status; diff --git a/api/tests/integration/infrastructure/repositories/tutorial-repository_test.js b/api/tests/integration/infrastructure/repositories/tutorial-repository_test.js index cc921be08e2..4c612aabaf4 100644 --- a/api/tests/integration/infrastructure/repositories/tutorial-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/tutorial-repository_test.js @@ -1,13 +1,15 @@ -const _ = require('lodash'); -const { expect, mockLearningContent, databaseBuilder, catchErr, domainBuilder } = require('../../../test-helper'); -const Tutorial = require('../../../../lib/domain/models/Tutorial'); -const TutorialEvaluation = require('../../../../lib/domain/models/TutorialEvaluation'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const tutorialRepository = require('../../../../lib/infrastructure/repositories/tutorial-repository'); -const TutorialForUser = require('../../../../lib/domain/read-models/TutorialForUser'); -const UserSavedTutorial = require('../../../../lib/domain/models/UserSavedTutorial'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const { ENGLISH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import _ from 'lodash'; +import { expect, mockLearningContent, databaseBuilder, catchErr, domainBuilder } from '../../../test-helper.js'; +import { Tutorial } from '../../../../lib/domain/models/Tutorial.js'; +import { TutorialEvaluation } from '../../../../lib/domain/models/TutorialEvaluation.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import * as tutorialRepository from '../../../../lib/infrastructure/repositories/tutorial-repository.js'; +import { TutorialForUser } from '../../../../lib/domain/read-models/TutorialForUser.js'; +import { UserSavedTutorial } from '../../../../lib/domain/models/UserSavedTutorial.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { ENGLISH_SPOKEN } = LOCALE; describe('Integration | Repository | tutorial-repository', function () { describe('#findByRecordIdsForCurrentUser', function () { diff --git a/api/tests/integration/infrastructure/repositories/user-campaign-results/stage-collection-repository_test.js b/api/tests/integration/infrastructure/repositories/user-campaign-results/stage-collection-repository_test.js index 2e38611017d..3a7d9262de3 100644 --- a/api/tests/integration/infrastructure/repositories/user-campaign-results/stage-collection-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-campaign-results/stage-collection-repository_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, learningContentBuilder, mockLearningContent } = require('../../../../test-helper'); -const stageCollectionRepository = require('../../../../../lib/infrastructure/repositories/user-campaign-results/stage-collection-repository.js'); +import { expect, databaseBuilder, learningContentBuilder, mockLearningContent } from '../../../../test-helper.js'; +import * as stageCollectionRepository from '../../../../../lib/infrastructure/repositories/user-campaign-results/stage-collection-repository.js'; const competenceId = 'recCompetence'; const learningContent = [ @@ -49,7 +49,7 @@ describe('Integration | Infrastructure | Repository | stage-collection-repositor let campaignId; beforeEach(async function () { - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); targetProfileId = databaseBuilder.factory.buildTargetProfile().id; campaignId = databaseBuilder.factory.buildCampaign({ type: 'ASSESSMENT', targetProfileId }).id; diff --git a/api/tests/integration/infrastructure/repositories/user-email-repository_test.js b/api/tests/integration/infrastructure/repositories/user-email-repository_test.js index 993a1eff545..488dd7bf054 100644 --- a/api/tests/integration/infrastructure/repositories/user-email-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-email-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const userEmailRepository = require('../../../../lib/infrastructure/repositories/user-email-repository'); -const EmailModificationDemand = require('../../../../lib/domain/models/EmailModificationDemand'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as userEmailRepository from '../../../../lib/infrastructure/repositories/user-email-repository.js'; +import { EmailModificationDemand } from '../../../../lib/domain/models/EmailModificationDemand.js'; describe('Integration | Repository | UserEmailRepository', function () { describe('#saveEmailModificationDemand', function () { diff --git a/api/tests/integration/infrastructure/repositories/user-login-repository_test.js b/api/tests/integration/infrastructure/repositories/user-login-repository_test.js index 06c40755ae3..209b1b02dca 100644 --- a/api/tests/integration/infrastructure/repositories/user-login-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-login-repository_test.js @@ -1,6 +1,6 @@ -const { databaseBuilder, expect, knex, sinon } = require('../../../test-helper'); -const userLoginRepository = require('../../../../lib/infrastructure/repositories/user-login-repository'); -const UserLogin = require('../../../../lib/domain/models/UserLogin'); +import { databaseBuilder, expect, knex, sinon } from '../../../test-helper.js'; +import * as userLoginRepository from '../../../../lib/infrastructure/repositories/user-login-repository.js'; +import { UserLogin } from '../../../../lib/domain/models/UserLogin.js'; describe('Integration | Repository | UserLoginRepository', function () { describe('#findByUserId', function () { diff --git a/api/tests/integration/infrastructure/repositories/user-orga-settings-repository_test.js b/api/tests/integration/infrastructure/repositories/user-orga-settings-repository_test.js index 41c8d017afa..c2580f8c605 100644 --- a/api/tests/integration/infrastructure/repositories/user-orga-settings-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-orga-settings-repository_test.js @@ -1,12 +1,11 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { catchErr, expect, knex, databaseBuilder } = require('../../../test-helper'); +import { catchErr, expect, knex, databaseBuilder } from '../../../test-helper.js'; +import { UserOrgaSettings } from '../../../../lib/domain/models/UserOrgaSettings.js'; +import { BookshelfUserOrgaSettings } from '../../../../lib/infrastructure/orm-models/UserOrgaSettings.js'; +import { UserOrgaSettingsCreationError } from '../../../../lib/domain/errors.js'; -const UserOrgaSettings = require('../../../../lib/domain/models/UserOrgaSettings'); -const BookshelfUserOrgaSettings = require('../../../../lib/infrastructure/orm-models/UserOrgaSettings'); -const { UserOrgaSettingsCreationError } = require('../../../../lib/domain/errors'); - -const userOrgaSettingsRepository = require('../../../../lib/infrastructure/repositories/user-orga-settings-repository'); +import * as userOrgaSettingsRepository from '../../../../lib/infrastructure/repositories/user-orga-settings-repository.js'; describe('Integration | Repository | UserOrgaSettings', function () { const USER_PICKED_PROPERTIES = [ diff --git a/api/tests/integration/infrastructure/repositories/user-organizations-for-admin-repository_test.js b/api/tests/integration/infrastructure/repositories/user-organizations-for-admin-repository_test.js index 3e69836b26d..4d01d3bec72 100644 --- a/api/tests/integration/infrastructure/repositories/user-organizations-for-admin-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-organizations-for-admin-repository_test.js @@ -1,6 +1,6 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const UserOrganizationForAdmin = require('../../../../lib/domain/read-models/UserOrganizationForAdmin'); -const userOrganizationsForAdminRepository = require('../../../../lib/infrastructure/repositories/user-organizations-for-admin-repository'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { UserOrganizationForAdmin } from '../../../../lib/domain/read-models/UserOrganizationForAdmin.js'; +import * as userOrganizationsForAdminRepository from '../../../../lib/infrastructure/repositories/user-organizations-for-admin-repository.js'; describe('Integration | Repository | user-organizations-for-admin', function () { context('#findByUserId', function () { diff --git a/api/tests/integration/infrastructure/repositories/user-recommended-training-repository_test.js b/api/tests/integration/infrastructure/repositories/user-recommended-training-repository_test.js index be294eeab33..4765604525c 100644 --- a/api/tests/integration/infrastructure/repositories/user-recommended-training-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-recommended-training-repository_test.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const userRecommendedTrainingRepository = require('../../../../lib/infrastructure/repositories/user-recommended-training-repository'); -const UserRecommendedTraining = require('../../../../lib/domain/read-models/UserRecommendedTraining'); +import _ from 'lodash'; +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import * as userRecommendedTrainingRepository from '../../../../lib/infrastructure/repositories/user-recommended-training-repository.js'; +import { UserRecommendedTraining } from '../../../../lib/domain/read-models/UserRecommendedTraining.js'; describe('Integration | Repository | user-recommended-training-repository', function () { describe('#save', function () { diff --git a/api/tests/integration/infrastructure/repositories/user-repository_test.js b/api/tests/integration/infrastructure/repositories/user-repository_test.js index c6586a720d9..36473f1ef89 100644 --- a/api/tests/integration/infrastructure/repositories/user-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-repository_test.js @@ -1,30 +1,26 @@ -const each = require('lodash/each'); -const map = require('lodash/map'); -const times = require('lodash/times'); -const pick = require('lodash/pick'); +import lodash from 'lodash'; +const { each, map, times, pick } = lodash; +import { expect, knex, databaseBuilder, catchErr, sinon } from '../../../test-helper.js'; -const { expect, knex, databaseBuilder, catchErr, sinon } = require('../../../test-helper'); - -const { +import { AlreadyExistingEntityError, AlreadyRegisteredEmailError, AlreadyRegisteredUsernameError, NotFoundError, UserNotFoundError, -} = require('../../../../lib/domain/errors'); - -const User = require('../../../../lib/domain/models/User'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const UserDetailsForAdmin = require('../../../../lib/domain/models/UserDetailsForAdmin'); -const Membership = require('../../../../lib/domain/models/Membership'); -const CertificationCenter = require('../../../../lib/domain/models/CertificationCenter'); -const CertificationCenterMembership = require('../../../../lib/domain/models/CertificationCenterMembership'); -const Organization = require('../../../../lib/domain/models/Organization'); -const OrganizationLearnerForAdmin = require('../../../../lib/domain/read-models/OrganizationLearnerForAdmin'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); - -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const userRepository = require('../../../../lib/infrastructure/repositories/user-repository'); +} from '../../../../lib/domain/errors.js'; + +import { User } from '../../../../lib/domain/models/User.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import { UserDetailsForAdmin } from '../../../../lib/domain/models/UserDetailsForAdmin.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { CertificationCenter } from '../../../../lib/domain/models/CertificationCenter.js'; +import { CertificationCenterMembership } from '../../../../lib/domain/models/CertificationCenterMembership.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { OrganizationLearnerForAdmin } from '../../../../lib/domain/read-models/OrganizationLearnerForAdmin.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import * as userRepository from '../../../../lib/infrastructure/repositories/user-repository.js'; const expectedUserDetailsForAdminAttributes = [ 'id', diff --git a/api/tests/integration/infrastructure/repositories/user-saved-tutorial-repository_test.js b/api/tests/integration/infrastructure/repositories/user-saved-tutorial-repository_test.js index 85dd43bbfa3..b2029f4e011 100644 --- a/api/tests/integration/infrastructure/repositories/user-saved-tutorial-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-saved-tutorial-repository_test.js @@ -1,6 +1,6 @@ -const { expect, knex, databaseBuilder } = require('../../../test-helper'); -const userSavedTutorialRepository = require('../../../../lib/infrastructure/repositories/user-saved-tutorial-repository'); -const UserSavedTutorial = require('../../../../lib/domain/models/UserSavedTutorial'); +import { expect, knex, databaseBuilder } from '../../../test-helper.js'; +import * as userSavedTutorialRepository from '../../../../lib/infrastructure/repositories/user-saved-tutorial-repository.js'; +import { UserSavedTutorial } from '../../../../lib/domain/models/UserSavedTutorial.js'; describe('Integration | Infrastructure | Repository | user-saved-tutorial-repository', function () { let userId; diff --git a/api/tests/integration/infrastructure/repositories/user-to-create-repository_test.js b/api/tests/integration/infrastructure/repositories/user-to-create-repository_test.js index 456831d6bca..04a10aa90ff 100644 --- a/api/tests/integration/infrastructure/repositories/user-to-create-repository_test.js +++ b/api/tests/integration/infrastructure/repositories/user-to-create-repository_test.js @@ -1,10 +1,8 @@ -const { expect, knex, databaseBuilder, catchErr } = require('../../../test-helper'); - -const { OrganizationLearnerAlreadyLinkedToUserError } = require('../../../../lib/domain/errors'); - -const User = require('../../../../lib/domain/models/User'); -const UserToCreateRepository = require('../../../../lib/infrastructure/repositories/user-to-create-repository'); -const UserToCreate = require('../../../../lib/domain/models/UserToCreate'); +import { expect, knex, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { OrganizationLearnerAlreadyLinkedToUserError } from '../../../../lib/domain/errors.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import * as UserToCreateRepository from '../../../../lib/infrastructure/repositories/user-to-create-repository.js'; +import { UserToCreate } from '../../../../lib/domain/models/UserToCreate.js'; describe('Integration | Infrastructure | Repository | UserToCreateRepository', function () { describe('#create', function () { diff --git a/api/tests/integration/infrastructure/serializer/campaigns-administration/csv-campaigns-ids-parser_test.js b/api/tests/integration/infrastructure/serializer/campaigns-administration/csv-campaigns-ids-parser_test.js index c077e679097..f1244a394fa 100644 --- a/api/tests/integration/infrastructure/serializer/campaigns-administration/csv-campaigns-ids-parser_test.js +++ b/api/tests/integration/infrastructure/serializer/campaigns-administration/csv-campaigns-ids-parser_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr, createTempFile, removeTempFile } = require('../../../../test-helper'); -const { CsvImportError } = require('../../../../../lib/domain/errors'); -const csvCampaignIdsParser = require('../../../../../lib/infrastructure/serializers/csv/campaigns-administration/csv-campaigns-ids-parser'); +import { expect, catchErr, createTempFile, removeTempFile } from '../../../../test-helper.js'; +import { CsvImportError } from '../../../../../lib/domain/errors.js'; +import * as csvCampaignIdsParser from '../../../../../lib/infrastructure/serializers/csv/campaigns-administration/csv-campaigns-ids-parser.js'; describe('Integration | Serializer | CSV | campaigns-administration | csv-campaigns-ids-parser', function () { describe('#extractCampaignsIds', function () { diff --git a/api/tests/integration/infrastructure/temporary-storage/RedisTemporaryStorage_test.js b/api/tests/integration/infrastructure/temporary-storage/RedisTemporaryStorage_test.js index d316adabe30..f86cfebf9c3 100644 --- a/api/tests/integration/infrastructure/temporary-storage/RedisTemporaryStorage_test.js +++ b/api/tests/integration/infrastructure/temporary-storage/RedisTemporaryStorage_test.js @@ -1,7 +1,9 @@ -const { v4: uuidv4 } = require('uuid'); -const RedisTemporaryStorage = require('../../../../lib/infrastructure/temporary-storage/RedisTemporaryStorage'); -const { expect } = require('../../../test-helper'); -const settings = require('../../../../lib/config'); +import { v4 as uuidv4 } from 'uuid'; + +import { RedisTemporaryStorage } from '../../../../lib/infrastructure/temporary-storage/RedisTemporaryStorage.js'; +import { expect } from '../../../test-helper.js'; +import { config as settings } from '../../../../lib/config.js'; + const REDIS_URL = settings.redis.url; describe('Integration | Infrastructure | TemporaryStorage | RedisTemporaryStorage', function () { diff --git a/api/tests/integration/infrastructure/utils/RedisClient_test.js b/api/tests/integration/infrastructure/utils/RedisClient_test.js index 21956ed815e..276c88930ac 100644 --- a/api/tests/integration/infrastructure/utils/RedisClient_test.js +++ b/api/tests/integration/infrastructure/utils/RedisClient_test.js @@ -1,7 +1,8 @@ -const { v4: uuidv4 } = require('uuid'); -const RedisClient = require('../../../../lib/infrastructure/utils/RedisClient'); -const config = require('../../../../lib/config'); -const { expect } = require('../../../test-helper'); +import { v4 as uuidv4 } from 'uuid'; + +import { RedisClient } from '../../../../lib/infrastructure/utils/RedisClient.js'; +import { config } from '../../../../lib/config.js'; +import { expect } from '../../../test-helper.js'; describe('Integration | Infrastructure | Utils | RedisClient', function () { it('stores and retrieve a value for a key', async function () { diff --git a/api/tests/integration/infrastructure/utils/bookshelf-to-domain-converter_test.js b/api/tests/integration/infrastructure/utils/bookshelf-to-domain-converter_test.js index 36b42c82cb3..f0b10f32e20 100644 --- a/api/tests/integration/infrastructure/utils/bookshelf-to-domain-converter_test.js +++ b/api/tests/integration/infrastructure/utils/bookshelf-to-domain-converter_test.js @@ -1,17 +1,16 @@ -const { expect, databaseBuilder } = require('../../../test-helper'); -const bookshelfToDomainConverter = require('../../../../lib/infrastructure/utils/bookshelf-to-domain-converter'); - -const User = require('../../../../lib/domain/models/User'); -const Membership = require('../../../../lib/domain/models/Membership'); -const TargetProfile = require('../../../../lib/domain/models/TargetProfile'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const Tag = require('../../../../lib/domain/models/Tag'); -const Organization = require('../../../../lib/domain/models/Organization'); - -const BookshelfUser = require('../../../../lib/infrastructure/orm-models/User'); -const BookshelfCampaign = require('../../../../lib/infrastructure/orm-models/Campaign'); -const BookshelfCampaignParticipation = require('../../../../lib/infrastructure/orm-models/CampaignParticipation'); -const BookshelfOrganization = require('../../../../lib/infrastructure/orm-models/Organization'); +import { expect, databaseBuilder } from '../../../test-helper.js'; +import * as bookshelfToDomainConverter from '../../../../lib/infrastructure/utils/bookshelf-to-domain-converter.js'; + +import { User } from '../../../../lib/domain/models/User.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { TargetProfile } from '../../../../lib/domain/models/TargetProfile.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { Tag } from '../../../../lib/domain/models/Tag.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { BookshelfUser } from '../../../../lib/infrastructure/orm-models/User.js'; +import { BookshelfCampaign } from '../../../../lib/infrastructure/orm-models/Campaign.js'; +import { BookshelfCampaignParticipation } from '../../../../lib/infrastructure/orm-models/CampaignParticipation.js'; +import { BookshelfOrganization } from '../../../../lib/infrastructure/orm-models/Organization.js'; describe('Integration | Infrastructure | Utils | Bookshelf to domain converter', function () { describe('buildDomainObject', function () { diff --git a/api/tests/integration/infrastructure/utils/csv/certification-results_test.js b/api/tests/integration/infrastructure/utils/csv/certification-results_test.js index c85602398f7..3a6a0b75c38 100644 --- a/api/tests/integration/infrastructure/utils/csv/certification-results_test.js +++ b/api/tests/integration/infrastructure/utils/csv/certification-results_test.js @@ -1,10 +1,11 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const { +import { expect, domainBuilder } from '../../../../test-helper.js'; + +import { getSessionCertificationResultsCsv, getDivisionCertificationResultsCsv, REJECTED_AUTOMATICALLY_COMMENT, getCleaCertifiedCandidateCsv, -} = require('../../../../../lib/infrastructure/utils/csv/certification-results'); +} from '../../../../../lib/infrastructure/utils/csv/certification-results.js'; describe('Integration | Infrastructure | Utils | csv | certification-results', function () { context('#getSessionCertificationResultsCsv', function () { diff --git a/api/tests/integration/infrastructure/utils/csv/sessions-import_test.js b/api/tests/integration/infrastructure/utils/csv/sessions-import_test.js index d08af5c60f5..8f250871642 100644 --- a/api/tests/integration/infrastructure/utils/csv/sessions-import_test.js +++ b/api/tests/integration/infrastructure/utils/csv/sessions-import_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const { getHeaders } = require('../../../../../lib/infrastructure/files/sessions-import'); +import { expect } from '../../../../test-helper.js'; +import { getHeaders } from '../../../../../lib/infrastructure/files/sessions-import.js'; const BOM_CHAR = '\ufeff'; describe('Integration | Infrastructure | Utils | csv | sessions-import', function () { context('#getHeaders', function () { diff --git a/api/tests/integration/infrastructure/utils/csv/write-csv-utils_test.js b/api/tests/integration/infrastructure/utils/csv/write-csv-utils_test.js index c7520dd48aa..769b9c2840a 100644 --- a/api/tests/integration/infrastructure/utils/csv/write-csv-utils_test.js +++ b/api/tests/integration/infrastructure/utils/csv/write-csv-utils_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr } = require('../../../../test-helper'); -const { getCsvContent } = require('../../../../../lib/infrastructure/utils/csv/write-csv-utils'); -const { CsvParsingError } = require('../../../../../lib/domain/errors'); +import { expect, catchErr } from '../../../../test-helper.js'; +import { getCsvContent } from '../../../../../lib/infrastructure/utils/csv/write-csv-utils.js'; +import { CsvParsingError } from '../../../../../lib/domain/errors.js'; describe('Integration | Infrastructure | Utils | csv | write-csv-utils', function () { it('should return a csv content according to fileHeaders data', async function () { diff --git a/api/tests/integration/infrastructure/utils/filter-utils_test.js b/api/tests/integration/infrastructure/utils/filter-utils_test.js index 5b65b121e38..ff634d2b6d7 100644 --- a/api/tests/integration/infrastructure/utils/filter-utils_test.js +++ b/api/tests/integration/infrastructure/utils/filter-utils_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const { filterByFullName } = require('../../../../lib/infrastructure/utils/filter-utils'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { filterByFullName } from '../../../../lib/infrastructure/utils/filter-utils.js'; describe('Integration | Utils | filter-utils', function () { describe('#filterByFullName', function () { diff --git a/api/tests/integration/infrastructure/utils/knex-utils_test.js b/api/tests/integration/infrastructure/utils/knex-utils_test.js index 2b425bfd5ea..37389ef44e5 100644 --- a/api/tests/integration/infrastructure/utils/knex-utils_test.js +++ b/api/tests/integration/infrastructure/utils/knex-utils_test.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const { expect, databaseBuilder } = require('../../../test-helper'); -const { fetchPage, DEFAULT_PAGINATION } = require('../../../../lib/infrastructure/utils/knex-utils'); -const { knex } = require('../../../../lib/infrastructure/bookshelf'); +import _ from 'lodash'; +import { expect, databaseBuilder } from '../../../test-helper.js'; +import { fetchPage, DEFAULT_PAGINATION } from '../../../../lib/infrastructure/utils/knex-utils.js'; +import { knex } from '../../../../lib/infrastructure/bookshelf.js'; describe('Integration | Infrastructure | Utils | Knex utils', function () { describe('fetchPage', function () { diff --git a/api/tests/integration/infrastructure/utils/ods/files/fill-candidates-import-sheet_test.js b/api/tests/integration/infrastructure/utils/ods/files/fill-candidates-import-sheet_test.js index 84e87f0b3ce..bf11ec1101f 100644 --- a/api/tests/integration/infrastructure/utils/ods/files/fill-candidates-import-sheet_test.js +++ b/api/tests/integration/infrastructure/utils/ods/files/fill-candidates-import-sheet_test.js @@ -1,16 +1,24 @@ -const { unlink, writeFile } = require('fs').promises; -const _ = require('lodash'); -const { expect, databaseBuilder } = require('../../../../../test-helper'); -const readOdsUtils = require('../../../../../../lib/infrastructure/utils/ods/read-ods-utils'); -const fillCandidatesImportSheet = require('../../../../../../lib/infrastructure/files/candidates-import/fill-candidates-import-sheet'); -const usecases = require('../../../../../../lib/domain/usecases/index.js'); -const { +import fs from 'fs'; + +const { promises } = fs; + +const { unlink, writeFile } = promises; + +import _ from 'lodash'; +import { expect, databaseBuilder } from '../../../../../test-helper.js'; +import * as readOdsUtils from '../../../../../../lib/infrastructure/utils/ods/read-ods-utils.js'; +import { fillCandidatesImportSheet } from '../../../../../../lib/infrastructure/files/candidates-import/fill-candidates-import-sheet.js'; +import { usecases } from '../../../../../../lib/domain/usecases/index.js'; +import { PIX_PLUS_DROIT, CLEA, PIX_PLUS_EDU_1ER_DEGRE, PIX_PLUS_EDU_2ND_DEGRE, -} = require('../../../../../../lib/domain/models/ComplementaryCertification'); -const { getI18n } = require('../../../../../tooling/i18n/i18n'); +} from '../../../../../../lib/domain/models/ComplementaryCertification.js'; +import { getI18n } from '../../../../../tooling/i18n/i18n.js'; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | Infrastructure | Utils | Ods | fillCandidatesImportSheet', function () { let i18n; diff --git a/api/tests/integration/infrastructure/utils/ods/read-ods-utils_test.js b/api/tests/integration/infrastructure/utils/ods/read-ods-utils_test.js index 60022fc2fce..a3477bc3d5d 100644 --- a/api/tests/integration/infrastructure/utils/ods/read-ods-utils_test.js +++ b/api/tests/integration/infrastructure/utils/ods/read-ods-utils_test.js @@ -1,21 +1,26 @@ -const { readFile } = require('fs').promises; -const _ = require('lodash'); -const { getI18n } = require('../../../../tooling/i18n/i18n'); -const i18n = getI18n(); +import fs from 'fs'; + +const { promises } = fs; -const { expect, catchErr } = require('../../../../test-helper'); -const { UnprocessableEntityError } = require('../../../../../lib/application/http-errors'); +const { readFile } = promises; -const { - getTransformationStructsForPixCertifCandidatesImport, -} = require('../../../../../lib/infrastructure/files/candidates-import/candidates-import-transformation-structures'); +import _ from 'lodash'; +import { getI18n } from '../../../../tooling/i18n/i18n.js'; +const i18n = getI18n(); -const { +import { expect, catchErr } from '../../../../test-helper.js'; +import { UnprocessableEntityError } from '../../../../../lib/application/http-errors.js'; +import { getTransformationStructsForPixCertifCandidatesImport } from '../../../../../lib/infrastructure/files/candidates-import/candidates-import-transformation-structures.js'; + +import { getContentXml, extractTableDataFromOdsFile, validateOdsHeaders, getSheetDataRowsFromOdsBuffer, -} = require('../../../../../lib/infrastructure/utils/ods/read-ods-utils'); +} from '../../../../../lib/infrastructure/utils/ods/read-ods-utils.js'; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | Infrastructure | Utils | Ods | read-ods-utils', function () { const GET_CONTENT_ODS_FILE_PATH = `${__dirname}/files/get-content-xml_test.ods`; diff --git a/api/tests/integration/infrastructure/utils/ods/write-ods-utils_test.js b/api/tests/integration/infrastructure/utils/ods/write-ods-utils_test.js index 2dc3106120e..c9d70f87569 100644 --- a/api/tests/integration/infrastructure/utils/ods/write-ods-utils_test.js +++ b/api/tests/integration/infrastructure/utils/ods/write-ods-utils_test.js @@ -1,9 +1,13 @@ -const { writeFile, unlink } = require('fs').promises; +import fs from 'fs'; -const { expect } = require('../../../../test-helper'); +const { promises } = fs; -const { getContentXml } = require('../../../../../lib/infrastructure/utils/ods/read-ods-utils'); -const { +const { writeFile, unlink } = promises; + +import { expect } from '../../../../test-helper.js'; +import { getContentXml } from '../../../../../lib/infrastructure/utils/ods/read-ods-utils.js'; + +import { makeUpdatedOdsByContentXml, updateXmlRows, updateXmlSparseValues, @@ -11,8 +15,12 @@ const { incrementRowsColumnSpan, addValidatorRestrictedList, addTooltipOnCell, -} = require('../../../../../lib/infrastructure/utils/ods/write-ods-utils'); -const AddedCellOption = require('../../../../../lib/infrastructure/utils/ods/added-cell-option'); +} from '../../../../../lib/infrastructure/utils/ods/write-ods-utils.js'; + +import { AddedCellOption } from '../../../../../lib/infrastructure/utils/ods/added-cell-option.js'; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | Infrastructure | Utils | Ods | write-ods-utils', function () { const GET_CONTENT_ODS_FILE_PATH = `${__dirname}/files/get-content-xml_test.ods`; diff --git a/api/tests/integration/infrastructure/utils/pdf/certification-attestation-pdf_test.js b/api/tests/integration/infrastructure/utils/pdf/certification-attestation-pdf_test.js index b681116a116..6b20343648c 100644 --- a/api/tests/integration/infrastructure/utils/pdf/certification-attestation-pdf_test.js +++ b/api/tests/integration/infrastructure/utils/pdf/certification-attestation-pdf_test.js @@ -1,13 +1,13 @@ -const { domainBuilder, expect, nock, catchErr } = require('../../../../test-helper'); -const dayjs = require('dayjs'); -const { isSameBinary } = require('../../../../tooling/binary-comparator'); -const { - getCertificationAttestationsPdfBuffer, -} = require('../../../../../lib/infrastructure/utils/pdf/certification-attestation-pdf'); -const { CertificationAttestationGenerationError } = require('../../../../../lib/domain/errors'); -const fs = require('fs'); - -const { addRandomSuffix } = require('pdf-lib/cjs/utils'); +import { domainBuilder, expect, nock, catchErr, sinon } from '../../../../test-helper.js'; +import dayjs from 'dayjs'; +import { isSameBinary } from '../../../../tooling/binary-comparator.js'; +import { getCertificationAttestationsPdfBuffer } from '../../../../../lib/infrastructure/utils/pdf/certification-attestation-pdf.js'; +import { CertificationAttestationGenerationError } from '../../../../../lib/domain/errors.js'; +import fs from 'fs'; +import pdfLibUtils from 'pdf-lib/cjs/utils/index.js'; +import { writeFile } from 'fs/promises'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | Infrastructure | Utils | Pdf | Certification Attestation Pdf', function () { beforeEach(async function () { @@ -28,10 +28,6 @@ describe('Integration | Infrastructure | Utils | Pdf | Certification Attestation .reply(200, () => fs.readFileSync(`${__dirname}/stickers/macaron_droit_expert.pdf`)); }); - afterEach(function () { - _restorePdfLib(); - }); - it('should generate full attestation (non-regression test)', async function () { // given const resultCompetenceTree = domainBuilder.buildResultCompetenceTree(); @@ -253,7 +249,6 @@ describe('Integration | Infrastructure | Utils | Pdf | Certification Attestation async function _writeFile(buffer, outputFilename, dryRun = true) { // Note: to update the reference pdf, set dryRun to false. if (!dryRun) { - const { writeFile } = require('fs/promises'); await writeFile(`${__dirname}/${outputFilename}`, buffer); } } @@ -273,9 +268,5 @@ function _makePdfLibPredictable() { return prefix + '-' + Math.floor(suffix); } - require('pdf-lib/cjs/utils').addRandomSuffix = autoIncrementSuffixByPrefix; -} - -function _restorePdfLib() { - require('pdf-lib/cjs/utils').addRandomSuffix = addRandomSuffix; + sinon.stub(pdfLibUtils, 'addRandomSuffix').callsFake(autoIncrementSuffixByPrefix); } diff --git a/api/tests/integration/infrastructure/utils/pdf/supervisor-kit-pdf_test.js b/api/tests/integration/infrastructure/utils/pdf/supervisor-kit-pdf_test.js index bbfac257ba1..f5d4537f2a1 100644 --- a/api/tests/integration/infrastructure/utils/pdf/supervisor-kit-pdf_test.js +++ b/api/tests/integration/infrastructure/utils/pdf/supervisor-kit-pdf_test.js @@ -1,18 +1,15 @@ -const { domainBuilder, expect } = require('../../../../test-helper'); -const { isSameBinary } = require('../../../../tooling/binary-comparator'); -const { getSupervisorKitPdfBuffer } = require('../../../../../lib/infrastructure/utils/pdf/supervisor-kit-pdf'); - -const { addRandomSuffix } = require('pdf-lib/cjs/utils'); +import { domainBuilder, expect, sinon } from '../../../../test-helper.js'; +import { isSameBinary } from '../../../../tooling/binary-comparator.js'; +import { getSupervisorKitPdfBuffer } from '../../../../../lib/infrastructure/utils/pdf/supervisor-kit-pdf.js'; +import pdfLibUtils from 'pdf-lib/cjs/utils/index.js'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | Infrastructure | Utils | Pdf | Certification supervisor kit Pdf', function () { beforeEach(function () { _makePdfLibPredictable(); }); - afterEach(function () { - _restorePdfLib(); - }); - it('should return full supervisor kit as a buffer', async function () { // given const sessionForSupervisorKit = domainBuilder.buildSessionForSupervisorKit({ @@ -87,9 +84,5 @@ function _makePdfLibPredictable() { return prefix + '-' + Math.floor(suffix); } - require('pdf-lib/cjs/utils').addRandomSuffix = autoIncrementSuffixByPrefix; -} - -function _restorePdfLib() { - require('pdf-lib/cjs/utils').addRandomSuffix = addRandomSuffix; + sinon.stub(pdfLibUtils, 'addRandomSuffix').callsFake(autoIncrementSuffixByPrefix); } diff --git a/api/tests/integration/infrastructure/utils/xml/siecle-file-streamer_test.js b/api/tests/integration/infrastructure/utils/xml/siecle-file-streamer_test.js index caa8b6eea62..e6ab0f5c1da 100644 --- a/api/tests/integration/infrastructure/utils/xml/siecle-file-streamer_test.js +++ b/api/tests/integration/infrastructure/utils/xml/siecle-file-streamer_test.js @@ -1,6 +1,8 @@ -const { expect, catchErr, sinon } = require('../../../../test-helper'); -const SiecleFileStreamer = require('../../../../../lib/infrastructure/utils/xml/siecle-file-streamer'); -const { FileValidationError, SiecleXmlImportError } = require('../../../../../lib/domain/errors'); +import { expect, catchErr, sinon } from '../../../../test-helper.js'; +import { SiecleFileStreamer } from '../../../../../lib/infrastructure/utils/xml/siecle-file-streamer.js'; +import { FileValidationError, SiecleXmlImportError } from '../../../../../lib/domain/errors.js'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('SiecleFileStreamer', function () { describe('perform', function () { diff --git a/api/tests/integration/scripts/add-tags-to-organizations_test.js b/api/tests/integration/scripts/add-tags-to-organizations_test.js index c47a7894848..e4047e84b8e 100644 --- a/api/tests/integration/scripts/add-tags-to-organizations_test.js +++ b/api/tests/integration/scripts/add-tags-to-organizations_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex, catchErr } = require('../../test-helper'); -const { retrieveTagsByName, addTagsToOrganizations } = require('../../../scripts/add-tags-to-organizations'); +import { expect, databaseBuilder, knex, catchErr } from '../../test-helper.js'; +import { retrieveTagsByName, addTagsToOrganizations } from '../../../scripts/add-tags-to-organizations.js'; describe('Integration | Scripts | add-tags-to-organizations.js', function () { let firstTag; diff --git a/api/tests/integration/scripts/certification/fill-issue-report-category-id_test.js b/api/tests/integration/scripts/certification/fill-issue-report-category-id_test.js index 18a656e706f..695820d7330 100644 --- a/api/tests/integration/scripts/certification/fill-issue-report-category-id_test.js +++ b/api/tests/integration/scripts/certification/fill-issue-report-category-id_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const { main } = require('../../../../scripts/certification/fill-issue-report-category-id'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { main } from '../../../../scripts/certification/fill-issue-report-category-id.js'; describe('Integration | Scripts | Certification | fill-issue-report-category-id', function () { describe('#updateCertificationIssueReport', function () { diff --git a/api/tests/integration/scripts/certification/fill-last-assessment-result-certification-course-table_test.js b/api/tests/integration/scripts/certification/fill-last-assessment-result-certification-course-table_test.js index bb89bda6571..f13c2a3b79d 100644 --- a/api/tests/integration/scripts/certification/fill-last-assessment-result-certification-course-table_test.js +++ b/api/tests/integration/scripts/certification/fill-last-assessment-result-certification-course-table_test.js @@ -1,7 +1,5 @@ -const { expect, databaseBuilder, knex, sinon } = require('../../../test-helper'); -const { - addLastAssessmentResultCertificationCourse, -} = require('../../../../scripts/certification/fill-last-assessment-result-certification-course-table'); +import { expect, databaseBuilder, knex, sinon } from '../../../test-helper.js'; +import { addLastAssessmentResultCertificationCourse } from '../../../../scripts/certification/fill-last-assessment-result-certification-course-table.js'; const ASSOC_TABLE_NAME = 'certification-courses-last-assessment-results'; diff --git a/api/tests/integration/scripts/certification/fill-pix-certification-status-column-in-certification-courses-table_test.js b/api/tests/integration/scripts/certification/fill-pix-certification-status-column-in-certification-courses-table_test.js index 194866a945c..847deacfb9f 100644 --- a/api/tests/integration/scripts/certification/fill-pix-certification-status-column-in-certification-courses-table_test.js +++ b/api/tests/integration/scripts/certification/fill-pix-certification-status-column-in-certification-courses-table_test.js @@ -1,8 +1,6 @@ -const { expect, databaseBuilder, knex, sinon } = require('../../../test-helper'); -const { - updatePixCertificationStatus, -} = require('../../../../scripts/certification/fill-pix-certification-status-column-in-certification-courses-table'); -const { status } = require('../../../../lib/domain/models/AssessmentResult'); +import { expect, databaseBuilder, knex, sinon } from '../../../test-helper.js'; +import { updatePixCertificationStatus } from '../../../../scripts/certification/fill-pix-certification-status-column-in-certification-courses-table.js'; +import { status } from '../../../../lib/domain/models/AssessmentResult.js'; const OLD_UPDATED_AT = new Date('2020-01-01'); const NEW_UPDATED_AT = new Date('2022-02-02'); diff --git a/api/tests/integration/scripts/certification/get-cpf-import-status-from-xml_test.js b/api/tests/integration/scripts/certification/get-cpf-import-status-from-xml_test.js index 9f025e9c63f..78df3cc4f17 100644 --- a/api/tests/integration/scripts/certification/get-cpf-import-status-from-xml_test.js +++ b/api/tests/integration/scripts/certification/get-cpf-import-status-from-xml_test.js @@ -1,6 +1,8 @@ -const { knex, expect, databaseBuilder } = require('../../../test-helper'); -const { main } = require('../../../../scripts/certification/get-cpf-import-status-from-xml'); -const { cpfImportStatus } = require('../../../../lib/domain/models/CertificationCourse'); +import { knex, expect, databaseBuilder } from '../../../test-helper.js'; +import { main } from '../../../../scripts/certification/get-cpf-import-status-from-xml.js'; +import { cpfImportStatus } from '../../../../lib/domain/models/CertificationCourse.js'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | Scripts | Certification | get-cpf-import-status-from-xml', function () { afterEach(async function () { diff --git a/api/tests/integration/scripts/clean-anonymized-users-authentication-methods_test.js b/api/tests/integration/scripts/clean-anonymized-users-authentication-methods_test.js index d7394ee7bc5..36563dba21c 100644 --- a/api/tests/integration/scripts/clean-anonymized-users-authentication-methods_test.js +++ b/api/tests/integration/scripts/clean-anonymized-users-authentication-methods_test.js @@ -1,7 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../test-helper'); -const { - cleanAnonymizedAuthenticationMethods, -} = require('../../../scripts/clean-anonymized-users-authentication-methods'); +import { expect, databaseBuilder, knex } from '../../test-helper.js'; +import { cleanAnonymizedAuthenticationMethods } from '../../../scripts/clean-anonymized-users-authentication-methods.js'; describe('Integration | Scripts | clean-anonymized-users-authentication-methods', function () { describe('#cleanAnonymizedAuthenticationMethods', function () { diff --git a/api/tests/integration/scripts/create-badge-criteria-for-specified-badge_test.js b/api/tests/integration/scripts/create-badge-criteria-for-specified-badge_test.js index eb3a1b9f180..4af6e2e0b35 100644 --- a/api/tests/integration/scripts/create-badge-criteria-for-specified-badge_test.js +++ b/api/tests/integration/scripts/create-badge-criteria-for-specified-badge_test.js @@ -1,11 +1,11 @@ -const { expect, catchErr, databaseBuilder, knex } = require('../../test-helper'); -const { +import { expect, catchErr, databaseBuilder, knex } from '../../test-helper.js'; +import { checkBadgeExistence, checkCriteriaFormat, checkSkillSetIds, copySkillSets, -} = require('../../../scripts/create-badge-criteria-for-specified-badge.js'); -const BadgeCriterion = require('../../../lib/domain/models/BadgeCriterion'); +} from '../../../scripts/create-badge-criteria-for-specified-badge.js'; +import { BadgeCriterion } from '../../../lib/domain/models/BadgeCriterion.js'; describe('Integration | Scripts | create-badge-criteria-for-specified-badge', function () { describe('#checkBadgeExistence', function () { diff --git a/api/tests/integration/scripts/create-certification-center-memberships-from-organization-admins_test.js b/api/tests/integration/scripts/create-certification-center-memberships-from-organization-admins_test.js index 315049c51bc..724beaa39d9 100644 --- a/api/tests/integration/scripts/create-certification-center-memberships-from-organization-admins_test.js +++ b/api/tests/integration/scripts/create-certification-center-memberships-from-organization-admins_test.js @@ -1,15 +1,14 @@ -const { expect, databaseBuilder, knex } = require('../../test-helper'); +import { expect, databaseBuilder, knex } from '../../test-helper.js'; +import { Membership } from '../../../lib/domain/models/Membership.js'; +import { BookshelfCertificationCenterMembership } from '../../../lib/infrastructure/orm-models/CertificationCenterMembership.js'; -const Membership = require('../../../lib/domain/models/Membership'); -const BookshelfCertificationCenterMembership = require('../../../lib/infrastructure/orm-models/CertificationCenterMembership'); - -const { +import { getCertificationCenterIdWithMembershipsUserIdByExternalId, getAdminMembershipsUserIdByOrganizationExternalId, fetchCertificationCenterMembershipsByExternalId, prepareDataForInsert, createCertificationCenterMemberships, -} = require('../../../scripts/create-certification-center-memberships-from-organization-admins'); +} from '../../../scripts/create-certification-center-memberships-from-organization-admins.js'; describe('Integration | Scripts | create-certification-center-memberships-from-organization-admins.js', function () { afterEach(async function () { diff --git a/api/tests/integration/scripts/create-or-update-sco-agri-organizations_test.js b/api/tests/integration/scripts/create-or-update-sco-agri-organizations_test.js index 0b3a168fbb0..ace2cfd3e0f 100644 --- a/api/tests/integration/scripts/create-or-update-sco-agri-organizations_test.js +++ b/api/tests/integration/scripts/create-or-update-sco-agri-organizations_test.js @@ -1,10 +1,10 @@ -const { expect, databaseBuilder, knex } = require('../../test-helper'); -const { +import { expect, databaseBuilder, knex } from '../../test-helper.js'; +import { addTag, checkData, createOrUpdateOrganizations, -} = require('../../../scripts/create-or-update-sco-agri-organizations'); -const logoUrl = require('../../../scripts/logo/default-sco-agri-organization-logo-base64'); +} from '../../../scripts/create-or-update-sco-agri-organizations.js'; +import { logoUrl } from '../../../scripts/logo/default-sco-agri-organization-logo-base64.js'; describe('Integration | Scripts | create-or-update-sco-agri-organizations', function () { describe('#checkData', function () { diff --git a/api/tests/integration/scripts/data-generation/generate-campaign-with-participant_test.js b/api/tests/integration/scripts/data-generation/generate-campaign-with-participant_test.js index 7d32f8a8be6..4f7b6a1decb 100644 --- a/api/tests/integration/scripts/data-generation/generate-campaign-with-participant_test.js +++ b/api/tests/integration/scripts/data-generation/generate-campaign-with-participant_test.js @@ -1,12 +1,10 @@ -const { expect, learningContentBuilder, mockLearningContent, databaseBuilder, knex } = require('../../../test-helper'); -const { - generateCampaignWithParticipants, -} = require('../../../../scripts/data-generation/generate-campaign-with-participants'); +import { expect, learningContentBuilder, mockLearningContent, databaseBuilder, knex } from '../../../test-helper.js'; +import { generateCampaignWithParticipants } from '../../../../scripts/data-generation/generate-campaign-with-participants.js'; describe('Integration | Scripts | generate-campaign-with-participants', function () { it('should create a profiles collection campaign with participants', async function () { // given - mockLearningContent(learningContentBuilder.buildLearningContent.fromAreas([])); + mockLearningContent(learningContentBuilder.fromAreas([])); const organizationId = databaseBuilder.factory.buildOrganization().id; const userId = databaseBuilder.factory.buildUser({ id: 1 }).id; databaseBuilder.factory.buildMembership({ organizationId, organizationRole: 'ADMIN', userId }); @@ -27,7 +25,7 @@ describe('Integration | Scripts | generate-campaign-with-participants', function it('should create a assessment campaign with participants', async function () { // given - mockLearningContent(learningContentBuilder.buildLearningContent.fromAreas([])); + mockLearningContent(learningContentBuilder.fromAreas([])); const organizationId = databaseBuilder.factory.buildOrganization().id; const userId = databaseBuilder.factory.buildUser({ id: 1 }).id; databaseBuilder.factory.buildMembership({ organizationId, organizationRole: 'ADMIN', userId }); diff --git a/api/tests/integration/scripts/data-generation/generate-certif-cli_test.js b/api/tests/integration/scripts/data-generation/generate-certif-cli_test.js index 0a720f8e32b..9c5e89a1f88 100644 --- a/api/tests/integration/scripts/data-generation/generate-certif-cli_test.js +++ b/api/tests/integration/scripts/data-generation/generate-certif-cli_test.js @@ -1,10 +1,10 @@ -const { expect, knex, mockLearningContent } = require('../../../test-helper'); -const _ = require('lodash'); -const { +import { expect, knex, mockLearningContent } from '../../../test-helper.js'; +import _ from 'lodash'; +import { main, - databaseBuilder: databaseBuilderCli, -} = require('../../../../scripts/data-generation/generate-certif-cli'); -const databaseBuffer = require('../../../../db/database-builder/database-buffer'); + databaseBuilder as databaseBuilderCli, +} from '../../../../scripts/data-generation/generate-certif-cli.js'; +import { databaseBuffer } from '../../../../db/database-builder/database-buffer.js'; // FIXME Too hard to edit \o/ describe('Integration | Scripts | generate-certif-cli.js', function () { const certificationCenterSup = { id: 3, type: 'SUP' }; diff --git a/api/tests/integration/scripts/fill-campaign-participation-id-in-badge-acquisitions_test.js b/api/tests/integration/scripts/fill-campaign-participation-id-in-badge-acquisitions_test.js index 1630722689e..8c16f1c9c64 100644 --- a/api/tests/integration/scripts/fill-campaign-participation-id-in-badge-acquisitions_test.js +++ b/api/tests/integration/scripts/fill-campaign-participation-id-in-badge-acquisitions_test.js @@ -1,11 +1,11 @@ -const { expect, databaseBuilder, knex, sinon } = require('../../test-helper'); +import { expect, databaseBuilder, knex, sinon } from '../../test-helper.js'; -const { +import { main, getAllBadgeAcquistionsWithoutCampaignParticipationId, getCampaignParticipationFromBadgeAcquisition, updateBadgeAcquisitionWithCampaignParticipationId, -} = require('../../../scripts/fill-campaign-participation-id-in-badge-acquisitions'); +} from '../../../scripts/fill-campaign-participation-id-in-badge-acquisitions.js'; describe('Integration | Scripts | fillCampaignParticipationIdInBadgeAcquisitions', function () { beforeEach(function () { diff --git a/api/tests/integration/scripts/fill-skill-id-in-user-saved-tutorials_test.js b/api/tests/integration/scripts/fill-skill-id-in-user-saved-tutorials_test.js index d8ba3456926..cc31cdd8e48 100644 --- a/api/tests/integration/scripts/fill-skill-id-in-user-saved-tutorials_test.js +++ b/api/tests/integration/scripts/fill-skill-id-in-user-saved-tutorials_test.js @@ -1,4 +1,4 @@ -const { +import { expect, databaseBuilder, learningContentBuilder, @@ -6,8 +6,9 @@ const { domainBuilder, knex, sinon, -} = require('../../test-helper'); -const { +} from '../../test-helper.js'; + +import { getAllUserSavedTutorialsWithoutSkillId, getAllTutorials, getAllSkills, @@ -15,10 +16,11 @@ const { associateSkillsToTutorial, getMostRelevantSkillId, main, -} = require('../../../scripts/fill-skill-id-in-user-saved-tutorials'); -const UserSavedTutorial = require('../../../lib/domain/models/UserSavedTutorial'); -const UserSavedTutorialWithTutorial = require('../../../lib/domain/models/UserSavedTutorialWithTutorial'); -const KnowledgeElement = require('../../../lib/domain/models/KnowledgeElement'); +} from '../../../scripts/fill-skill-id-in-user-saved-tutorials.js'; + +import { UserSavedTutorial } from '../../../lib/domain/models/UserSavedTutorial.js'; +import { UserSavedTutorialWithTutorial } from '../../../lib/domain/models/UserSavedTutorialWithTutorial.js'; +import { KnowledgeElement } from '../../../lib/domain/models/KnowledgeElement.js'; describe('Integration | Scripts | fill-skillId-in-user-saved-tutorials', function () { describe('#main', function () { @@ -27,7 +29,7 @@ describe('Integration | Scripts | fill-skillId-in-user-saved-tutorials', functio beforeEach(function () { sinon.stub(console, 'log'); - learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + learningContentObjects = learningContentBuilder.fromAreas([ { id: 'recArea1', title_i18n: { @@ -228,7 +230,7 @@ describe('Integration | Scripts | fill-skillId-in-user-saved-tutorials', functio describe('#getAllTutorials', function () { it('should retrieve all tutorials', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContentObjects = learningContentBuilder.fromAreas([ { id: 'recArea1', title_i18n: { @@ -333,7 +335,7 @@ describe('Integration | Scripts | fill-skillId-in-user-saved-tutorials', functio describe('#getAllSkills', function () { it('should retrieve all skills', async function () { // given - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas([ + const learningContentObjects = learningContentBuilder.fromAreas([ { id: 'recArea1', title_i18n: { diff --git a/api/tests/integration/scripts/helpers/csvHelpers_test.js b/api/tests/integration/scripts/helpers/csvHelpers_test.js index bc8a9c6048c..267fd6d160a 100644 --- a/api/tests/integration/scripts/helpers/csvHelpers_test.js +++ b/api/tests/integration/scripts/helpers/csvHelpers_test.js @@ -1,6 +1,8 @@ -const { expect, catchErr } = require('../../../test-helper'); -const { FileValidationError, NotFoundError } = require('../../../../lib/domain/errors'); -const { checkCsvHeader } = require('../../../../scripts/helpers/csvHelpers'); +import { expect, catchErr } from '../../../test-helper.js'; +import { FileValidationError, NotFoundError } from '../../../../lib/domain/errors.js'; +import { checkCsvHeader } from '../../../../scripts/helpers/csvHelpers.js'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Integration | Scripts | Helpers | csvHelpers.js', function () { const withValidHeaderFilePath = `${__dirname}/files/withValidHeader-test.csv`; diff --git a/api/tests/integration/scripts/mark-users-for-TermsOfService-revalidation_test.js b/api/tests/integration/scripts/mark-users-for-TermsOfService-revalidation_test.js index e8419e31d7a..db18ef3096c 100644 --- a/api/tests/integration/scripts/mark-users-for-TermsOfService-revalidation_test.js +++ b/api/tests/integration/scripts/mark-users-for-TermsOfService-revalidation_test.js @@ -1,8 +1,5 @@ -const { expect, databaseBuilder } = require('../../test-helper'); - -const { - markUsersRequiringTermsOfServiceValidationForRevalidation, -} = require('../../../scripts/mark-users-for-TermsOfService-revalidation'); +import { expect, databaseBuilder } from '../../test-helper.js'; +import { markUsersRequiringTermsOfServiceValidationForRevalidation } from '../../../scripts/mark-users-for-TermsOfService-revalidation.js'; describe('Integration | Scripts | mark-users-for-TermsOfService-revalidation_test', function () { describe('#markUsersRequiringTermsOfServiceValidationForRevalidation', function () { diff --git a/api/tests/integration/scripts/populate-organizations-email_test.js b/api/tests/integration/scripts/populate-organizations-email_test.js index bc2827368f1..675e8b8d8e2 100644 --- a/api/tests/integration/scripts/populate-organizations-email_test.js +++ b/api/tests/integration/scripts/populate-organizations-email_test.js @@ -1,6 +1,5 @@ -const { expect, databaseBuilder, knex, sinon } = require('../../test-helper'); - -const populateOrganizations = require('../../../scripts/populate-organizations-email'); +import { expect, databaseBuilder, knex, sinon } from '../../test-helper.js'; +import { populateOrganizations } from '../../../scripts/populate-organizations-email.js'; describe('Integration | Scripts | populate-organizations-email.js', function () { describe('#populateOrganizations', function () { diff --git a/api/tests/integration/scripts/prod/archive-campaigns_test.js b/api/tests/integration/scripts/prod/archive-campaigns_test.js index 83edddcc52a..34565ef03e0 100644 --- a/api/tests/integration/scripts/prod/archive-campaigns_test.js +++ b/api/tests/integration/scripts/prod/archive-campaigns_test.js @@ -1,6 +1,8 @@ -const { expect, databaseBuilder, knex, sinon } = require('../../../test-helper'); -const archiveCampaigns = require('../../../../scripts/prod/archive-campaigns'); -const { noop } = require('lodash'); +import { expect, databaseBuilder, knex, sinon } from '../../../test-helper.js'; +import { archiveCampaigns } from '../../../../scripts/prod/archive-campaigns.js'; +import lodash from 'lodash'; + +const { noop } = lodash; describe('Script | Prod | Archive Campaign', function () { let clock; diff --git a/api/tests/integration/scripts/prod/compute-badge-acquisitions_test.js b/api/tests/integration/scripts/prod/compute-badge-acquisitions_test.js index 78ca3c43ed9..2f7a9595375 100644 --- a/api/tests/integration/scripts/prod/compute-badge-acquisitions_test.js +++ b/api/tests/integration/scripts/prod/compute-badge-acquisitions_test.js @@ -1,22 +1,24 @@ -const { +import { expect, databaseBuilder, sinon, learningContentBuilder, mockLearningContent, knex, -} = require('../../../test-helper'); -const { +} from '../../../test-helper.js'; + +import { normalizeRange, computeAllBadgeAcquisitions, computeBadgeAcquisition, getCampaignParticipationsBetweenIds, -} = require('../../../../scripts/prod/compute-badge-acquisitions'); -const CampaignParticipation = require('../../../../lib/domain/models/CampaignParticipation'); -const logger = require('../../../../lib/infrastructure/logger'); -const badgeAcquisitionRepository = require('../../../../lib/infrastructure/repositories/badge-acquisition-repository'); -const badgeForCalculationRepository = require('../../../../lib/infrastructure/repositories/badge-for-calculation-repository'); -const knowledgeElementRepository = require('../../../../lib/infrastructure/repositories/knowledge-element-repository'); +} from '../../../../scripts/prod/compute-badge-acquisitions.js'; + +import { CampaignParticipation } from '../../../../lib/domain/models/CampaignParticipation.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; +import * as badgeAcquisitionRepository from '../../../../lib/infrastructure/repositories/badge-acquisition-repository.js'; +import * as badgeForCalculationRepository from '../../../../lib/infrastructure/repositories/badge-for-calculation-repository.js'; +import * as knowledgeElementRepository from '../../../../lib/infrastructure/repositories/knowledge-element-repository.js'; describe('Script | Prod | Compute Badge Acquisitions', function () { describe('#validateRange', function () { @@ -165,7 +167,7 @@ describe('Script | Prod | Compute Badge Acquisitions', function () { threshold: 90, }); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); return databaseBuilder.commit(); @@ -312,7 +314,7 @@ describe('Script | Prod | Compute Badge Acquisitions', function () { userId, }); - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); return databaseBuilder.commit(); diff --git a/api/tests/integration/scripts/prod/compute-participation-results_test.js b/api/tests/integration/scripts/prod/compute-participation-results_test.js index 664bbb4f659..0f598cec7dd 100644 --- a/api/tests/integration/scripts/prod/compute-participation-results_test.js +++ b/api/tests/integration/scripts/prod/compute-participation-results_test.js @@ -1,7 +1,7 @@ -const { expect, mockLearningContent, databaseBuilder, knex } = require('../../../test-helper'); -const computeParticipationResults = require('../../../../scripts/prod/compute-participation-results'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, mockLearningContent, databaseBuilder, knex } from '../../../test-helper.js'; +import { computeParticipantResultsShared as computeParticipationResults } from '../../../../scripts/prod/compute-participation-results.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/integration/scripts/prod/create-assessment-campaigns-for-sco_test.js b/api/tests/integration/scripts/prod/create-assessment-campaigns-for-sco_test.js index 21c82dcfe9b..cdddd3bdf30 100644 --- a/api/tests/integration/scripts/prod/create-assessment-campaigns-for-sco_test.js +++ b/api/tests/integration/scripts/prod/create-assessment-campaigns-for-sco_test.js @@ -1,10 +1,10 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); -const { +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import { prepareCampaigns, checkData, getByExternalIdFetchingIdOnly, -} = require('../../../../scripts/prod/create-assessment-campaigns-for-sco'); +} from '../../../../scripts/prod/create-assessment-campaigns-for-sco.js'; describe('Integration | Scripts | create-assessment-campaigns', function () { describe('#prepareCampaigns', function () { diff --git a/api/tests/integration/scripts/prod/create-organization-places-lot_test.js b/api/tests/integration/scripts/prod/create-organization-places-lot_test.js index 0a99bd984e2..a4da5a2ef92 100644 --- a/api/tests/integration/scripts/prod/create-organization-places-lot_test.js +++ b/api/tests/integration/scripts/prod/create-organization-places-lot_test.js @@ -1,7 +1,6 @@ -const { expect, catchErr } = require('../../../test-helper'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); - -const { prepareOrganizationPlacesLot } = require('../../../../scripts/prod/create-organization-places-lot'); +import { expect, catchErr } from '../../../test-helper.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import { prepareOrganizationPlacesLot } from '../../../../scripts/prod/create-organization-places-lot.js'; describe('Integration | Scripts | create-organization-places-lot', function () { describe('#prepareOrganizationPlacesLot', function () { diff --git a/api/tests/integration/scripts/prod/create-profiles-collection-campaigns_test.js b/api/tests/integration/scripts/prod/create-profiles-collection-campaigns_test.js index ad0076c26fe..70181d6d664 100644 --- a/api/tests/integration/scripts/prod/create-profiles-collection-campaigns_test.js +++ b/api/tests/integration/scripts/prod/create-profiles-collection-campaigns_test.js @@ -1,9 +1,7 @@ -const { expect, databaseBuilder, catchErr } = require('../../../test-helper'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); - -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); - -const { prepareCampaigns, checkData } = require('../../../../scripts/prod/create-profiles-collection-campaigns'); +import { expect, databaseBuilder, catchErr } from '../../../test-helper.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { prepareCampaigns, checkData } from '../../../../scripts/prod/create-profiles-collection-campaigns.js'; describe('Integration | Scripts | create-profile-collection-campaigns', function () { describe('#prepareCampaigns', function () { diff --git a/api/tests/integration/scripts/prod/generate-knowledge-element-snapshots-for-campaigns_test.js b/api/tests/integration/scripts/prod/generate-knowledge-element-snapshots-for-campaigns_test.js index f13c560500e..6582f418b38 100644 --- a/api/tests/integration/scripts/prod/generate-knowledge-element-snapshots-for-campaigns_test.js +++ b/api/tests/integration/scripts/prod/generate-knowledge-element-snapshots-for-campaigns_test.js @@ -1,10 +1,8 @@ -const { expect, databaseBuilder, sinon } = require('../../../test-helper'); -const knowledgeElementRepository = require('../../../../lib/infrastructure/repositories/knowledge-element-repository'); -const knowledgeElementSnapshotRepository = require('../../../../lib/infrastructure/repositories/knowledge-element-snapshot-repository'); -const { +import { expect, databaseBuilder, sinon } from '../../../test-helper.js'; +import { getEligibleCampaignParticipations, generateKnowledgeElementSnapshots, -} = require('../../../../scripts/prod/generate-knowledge-element-snapshots-for-campaigns'); +} from '../../../../scripts/prod/generate-knowledge-element-snapshots-for-campaigns.js'; describe('Integration | Scripts | generate-knowledge-element-snapshots-for-campaigns.js', function () { describe('#getEligibleCampaignParticipations', function () { @@ -118,14 +116,15 @@ describe('Integration | Scripts | generate-knowledge-element-snapshots-for-campa }); describe('#generateKnowledgeElementSnapshots', function () { + let knowledgeElementRepositoryStub; + let knowledgeElementSnapshotRepositoryStub; beforeEach(function () { - sinon.stub(knowledgeElementRepository, 'findUniqByUserId'); - sinon.stub(knowledgeElementSnapshotRepository, 'save'); - }); - - afterEach(function () { - knowledgeElementRepository.findUniqByUserId.restore(); - knowledgeElementSnapshotRepository.save.restore(); + knowledgeElementRepositoryStub = { + findUniqByUserId: sinon.stub(), + }; + knowledgeElementSnapshotRepositoryStub = { + save: sinon.stub(), + }; }); it('should save snapshots', async function () { @@ -133,15 +132,18 @@ describe('Integration | Scripts | generate-knowledge-element-snapshots-for-campa const concurrency = 1; const campaignParticipationData = [{ userId: 1, sharedAt: new Date('2020-01-01') }]; const expectedKnowledgeElements = ['someKnowledgeElements']; - knowledgeElementRepository.findUniqByUserId + knowledgeElementRepositoryStub.findUniqByUserId .withArgs({ userId: campaignParticipationData[0].userId, limitDate: campaignParticipationData[0].sharedAt }) .resolves(expectedKnowledgeElements); // when - await generateKnowledgeElementSnapshots(campaignParticipationData, concurrency); + await generateKnowledgeElementSnapshots(campaignParticipationData, concurrency, { + knowledgeElementRepository: knowledgeElementRepositoryStub, + knowledgeElementSnapshotRepository: knowledgeElementSnapshotRepositoryStub, + }); // then - expect(knowledgeElementSnapshotRepository.save).to.have.been.calledWithExactly({ + expect(knowledgeElementSnapshotRepositoryStub.save).to.have.been.calledWithExactly({ userId: campaignParticipationData[0].userId, snappedAt: campaignParticipationData[0].sharedAt, knowledgeElements: expectedKnowledgeElements, diff --git a/api/tests/integration/scripts/prod/hide-skills-in-csv-export_test.js b/api/tests/integration/scripts/prod/hide-skills-in-csv-export_test.js index c9c5564f9b7..eba5130e8b9 100644 --- a/api/tests/integration/scripts/prod/hide-skills-in-csv-export_test.js +++ b/api/tests/integration/scripts/prod/hide-skills-in-csv-export_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const { hideSkills } = require('../../../../scripts/prod/hide-skills-in-csv-export'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { hideSkills } from '../../../../scripts/prod/hide-skills-in-csv-export.js'; describe('hideSkills', function () { it('should update showSkills to false', async function () { diff --git a/api/tests/integration/scripts/prod/replace-threshold1-with-first-skill-stage_test.js b/api/tests/integration/scripts/prod/replace-threshold1-with-first-skill-stage_test.js index eaf29428ee5..d3b4a3b0b6e 100644 --- a/api/tests/integration/scripts/prod/replace-threshold1-with-first-skill-stage_test.js +++ b/api/tests/integration/scripts/prod/replace-threshold1-with-first-skill-stage_test.js @@ -1,7 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const { - main, -} = require('../../../../scripts/prod/target-profile-migrations/replace-threshold1-with-first-skill-stage'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { main } from '../../../../scripts/prod/target-profile-migrations/replace-threshold1-with-first-skill-stage.js'; describe('Script | Prod | Replace Threshold with First Skill Stage', function () { it('should convert ', async function () { diff --git a/api/tests/integration/scripts/prod/select-category-for-target-profiles_test.js b/api/tests/integration/scripts/prod/select-category-for-target-profiles_test.js index 58d80f11b6a..d6793eaf361 100644 --- a/api/tests/integration/scripts/prod/select-category-for-target-profiles_test.js +++ b/api/tests/integration/scripts/prod/select-category-for-target-profiles_test.js @@ -1,9 +1,9 @@ -const { expect, databaseBuilder, knex, catchErr } = require('../../../test-helper'); -const { +import { expect, databaseBuilder, knex, catchErr } from '../../../test-helper.js'; +import { setCategoriesToTargetProfiles, setCategoryToTargetProfiles, -} = require('../../../../scripts/prod/select-category-for-target-profiles'); -const { categories } = require('../../../../lib/domain/models/TargetProfile'); +} from '../../../../scripts/prod/select-category-for-target-profiles.js'; +import { categories } from '../../../../lib/domain/models/TargetProfile.js'; describe('Integration | Scripts | select-category-for-target-profiles.js', function () { let firstTargetProfileId; diff --git a/api/tests/integration/scripts/prod/swap-campaign-codes_test.js b/api/tests/integration/scripts/prod/swap-campaign-codes_test.js index c83ed9f1192..565cf1158f8 100644 --- a/api/tests/integration/scripts/prod/swap-campaign-codes_test.js +++ b/api/tests/integration/scripts/prod/swap-campaign-codes_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const { swapCampaignCodes } = require('../../../../scripts/prod/swap-campaign-codes.js'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { swapCampaignCodes } from '../../../../scripts/prod/swap-campaign-codes.js'; describe('Integration | Scripts | swap-campaign-codes', function () { it('should swap campaign codes', async function () { diff --git a/api/tests/integration/scripts/prod/update-documentation-url_test.js b/api/tests/integration/scripts/prod/update-documentation-url_test.js index 97875e79b4f..4e5cc152152 100644 --- a/api/tests/integration/scripts/prod/update-documentation-url_test.js +++ b/api/tests/integration/scripts/prod/update-documentation-url_test.js @@ -1,5 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../../test-helper'); -const { updateDocumentationUrl, URL } = require('../../../../scripts/prod/update-documentation-url'); +import { expect, databaseBuilder, knex } from '../../../test-helper.js'; +import { updateDocumentationUrl, URL } from '../../../../scripts/prod/update-documentation-url.js'; describe('updateDocumentationUrl', function () { context('when the organization is PRO', function () { diff --git a/api/tests/integration/scripts/send-invitations-to-sco-organizations_test.js b/api/tests/integration/scripts/send-invitations-to-sco-organizations_test.js index b9b33a41adf..72c1ba8edbe 100644 --- a/api/tests/integration/scripts/send-invitations-to-sco-organizations_test.js +++ b/api/tests/integration/scripts/send-invitations-to-sco-organizations_test.js @@ -1,14 +1,14 @@ -const _ = require('lodash'); +import _ from 'lodash'; -const { expect, databaseBuilder, knex } = require('../../test-helper'); +import { expect, databaseBuilder, knex } from '../../test-helper.js'; +import { BookshelfOrganizationInvitation } from '../../../lib/infrastructure/orm-models/OrganizationInvitation.js'; -const BookshelfOrganizationInvitation = require('../../../lib/infrastructure/orm-models/OrganizationInvitation'); -const { +import { getOrganizationByExternalId, buildInvitation, prepareDataForSending, sendJoinOrganizationInvitations, -} = require('../../../scripts/send-invitations-to-sco-organizations'); +} from '../../../scripts/send-invitations-to-sco-organizations.js'; describe('Integration | Scripts | send-invitations-to-sco-organizations.js', function () { describe('#getOrganizationByExternalId', function () { diff --git a/api/tests/integration/scripts/switch-campaign-to-flash_test.js b/api/tests/integration/scripts/switch-campaign-to-flash_test.js index 7b9a067a1bb..506e072d6a4 100644 --- a/api/tests/integration/scripts/switch-campaign-to-flash_test.js +++ b/api/tests/integration/scripts/switch-campaign-to-flash_test.js @@ -1,6 +1,5 @@ -const { expect, databaseBuilder, knex } = require('../../test-helper'); - -const { switchCampaignToFlash } = require('../../../scripts/switch-campaign-to-flash.js'); +import { expect, databaseBuilder, knex } from '../../test-helper.js'; +import { switchCampaignToFlash } from '../../../scripts/switch-campaign-to-flash.js'; describe('Integration | Scripts | switch-campaign-to-flash.js', function () { describe('#switchCampaignToFlash', function () { diff --git a/api/tests/integration/scripts/toggle-is-for-absolute-novice-campaign-attribute_test.js b/api/tests/integration/scripts/toggle-is-for-absolute-novice-campaign-attribute_test.js index f7e7b290613..17dae43c618 100644 --- a/api/tests/integration/scripts/toggle-is-for-absolute-novice-campaign-attribute_test.js +++ b/api/tests/integration/scripts/toggle-is-for-absolute-novice-campaign-attribute_test.js @@ -1,8 +1,6 @@ -const { expect, sinon, databaseBuilder, knex } = require('../../test-helper'); -const logger = require('../../../lib/infrastructure/logger'); -const { - toggleIsForAbsoluteNoviceCampaignAttribute, -} = require('../../../scripts/toggle-is-for-absolute-novice-campaign-attribute'); +import { expect, sinon, databaseBuilder, knex } from '../../test-helper.js'; +import { logger } from '../../../lib/infrastructure/logger.js'; +import { toggleIsForAbsoluteNoviceCampaignAttribute } from '../../../scripts/toggle-is-for-absolute-novice-campaign-attribute.js'; describe('Toggle isForAbsoluteNovice campaign attribute', function () { describe('#toggleIsForAbsoluteNoviceCampaignAttribute', function () { diff --git a/api/tests/test-helper.js b/api/tests/test-helper.js index 09d48c6745a..da3dd22dbce 100644 --- a/api/tests/test-helper.js +++ b/api/tests/test-helper.js @@ -1,34 +1,53 @@ -require('dotenv').config({ path: `${__dirname}/../.env` }); -const _ = require('lodash'); -const MockDate = require('mockdate'); -const chai = require('chai'); +// eslint-disable-next-line eslint-comments/disable-enable-pair +/* eslint-disable node/no-unpublished-import */ +import * as url from 'url'; + +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); +import * as domainBuilder from './tooling/domain-builder/factory/index.js'; +import { HttpTestServer } from './tooling/server/http-test-server.js'; +import * as dotenv from 'dotenv'; + +dotenv.config({ path: `${__dirname}/../.env` }); +import _ from 'lodash'; +import MockDate from 'mockdate'; +import chai from 'chai'; + const expect = chai.expect; -const sinon = require('sinon'); -chai.use(require('chai-as-promised')); -chai.use(require('chai-sorted')); -chai.use(require('sinon-chai')); -const customChaiHelpers = require('./tooling/chai-custom-helpers/index'); -_.each(customChaiHelpers, chai.use); -const { learningContentCache } = require('../lib/infrastructure/caches/learning-content-cache'); +import sinon from 'sinon'; +import chaiAsPromised from 'chai-as-promised'; +import chaiSorted from 'chai-sorted'; +import sinonChai from 'sinon-chai'; + +chai.use(chaiAsPromised); +chai.use(chaiSorted); +chai.use(sinonChai); +import * as customChaiHelpers from './tooling/chai-custom-helpers/index.js'; -const { apimRegisterApplicationsCredentials, jwtConfig } = require('../lib/config'); +_.each(customChaiHelpers, chai.use); +import { learningContentCache } from '../lib/infrastructure/caches/learning-content-cache.js'; -const { knex, disconnect } = require('../db/knex-database-connection'); +import { config } from '../lib/config.js'; +const { apimRegisterApplicationsCredentials, jwtConfig } = config; +import { knex, disconnect } from '../db/knex-database-connection.js'; +import { DatabaseBuilder } from '../db/database-builder/database-builder.js'; -const DatabaseBuilder = require('../db/database-builder/database-builder'); const databaseBuilder = new DatabaseBuilder({ knex }); -const nock = require('nock'); +import nock from 'nock'; + nock.disableNetConnect(); -const learningContentBuilder = require('./tooling/learning-content-builder'); +import { buildLearningContent as learningContentBuilder } from './tooling/learning-content-builder/index.js'; + +import * as tokenService from '../lib/domain/services/token-service.js'; +import { Membership } from '../lib/domain/models/Membership.js'; -const tokenService = require('../lib/domain/services/token-service'); -const Membership = require('../lib/domain/models/Membership'); const EMPTY_BLANK_AND_NULL = ['', '\t \n', null]; -const { ROLES } = require('../lib/domain/constants').PIX_ADMIN; -const { createTempFile, removeTempFile } = require('./tooling/temporary-file'); +import { PIX_ADMIN } from '../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; +import { createTempFile, removeTempFile } from './tooling/temporary-file.js'; /* eslint-disable mocha/no-top-level-hooks */ afterEach(function () { @@ -41,6 +60,7 @@ afterEach(function () { after(function () { return disconnect(); }); + /* eslint-enable mocha/no-top-level-hooks */ function generateValidRequestAuthorizationHeader(userId = 1234, source = 'pix') { @@ -241,17 +261,18 @@ global.chaiErr = function globalErr(fn, val) { throw new chai.AssertionError('Expected an error'); }; +const testErr = new Error('Fake Error'); // eslint-disable-next-line mocha/no-exports -module.exports = { +export { EMPTY_BLANK_AND_NULL, expect, - domainBuilder: require('./tooling/domain-builder/factory'), + domainBuilder, databaseBuilder, generateValidRequestAuthorizationHeader, generateValidRequestAuthorizationHeaderForApplication, generateIdTokenForExternalUser, hFake, - HttpTestServer: require('./tooling/server/http-test-server'), + HttpTestServer, insertOrganizationUserWithRoleAdmin, insertUserWithRoleSuperAdmin, insertUserWithRoleCertif, @@ -262,7 +283,7 @@ module.exports = { streamToPromise, catchErr, catchErrSync, - testErr: new Error('Fake Error'), + testErr, mockLearningContent, learningContentBuilder, createTempFile, diff --git a/api/tests/test-helper_test.js b/api/tests/test-helper_test.js index 985df3582fd..918ddff6364 100644 --- a/api/tests/test-helper_test.js +++ b/api/tests/test-helper_test.js @@ -1,4 +1,4 @@ -const { expect, catchErr } = require('./test-helper'); +import { expect, catchErr } from './test-helper.js'; describe('Test helpers', function () { describe('#catchErr', function () { diff --git a/api/tests/tooling/binary-comparator.js b/api/tests/tooling/binary-comparator.js index 7dfd97ff74d..a69b244f251 100644 --- a/api/tests/tooling/binary-comparator.js +++ b/api/tests/tooling/binary-comparator.js @@ -1,5 +1,7 @@ -const { readFile } = require('fs/promises'); -const { createHash } = require('crypto'); +import { readFile } from 'fs/promises'; +import crypto from 'crypto'; + +const { createHash } = crypto; function _hash(buffer) { const h = createHash('sha1'); @@ -17,6 +19,4 @@ async function isSameBinary(referencePath, buffer) { return expectedHash == actualHash; } -module.exports = { - isSameBinary, -}; +export { isSameBinary }; diff --git a/api/tests/tooling/chai-custom-helpers/deep-equal-array.js b/api/tests/tooling/chai-custom-helpers/deep-equal-array.js index c69781a8514..1b3289c3c46 100644 --- a/api/tests/tooling/chai-custom-helpers/deep-equal-array.js +++ b/api/tests/tooling/chai-custom-helpers/deep-equal-array.js @@ -1,4 +1,4 @@ -module.exports = function (chai, _utils) { +const deepEqualArray = function (chai, _utils) { chai.Assertion.addMethod('deepEqualArray', function (referenceArray) { const assertedArray = this._obj; @@ -26,3 +26,5 @@ function _assertArraysHaveSameLength(chai, array1, array2) { function _assertDeepEqualInstance(chai, instance1, instance2) { new chai.Assertion(instance1).to.deepEqualInstance(instance2); } + +export { deepEqualArray }; diff --git a/api/tests/tooling/chai-custom-helpers/deep-equal-instance-omitting.js b/api/tests/tooling/chai-custom-helpers/deep-equal-instance-omitting.js index a5a1a099803..c075b3d7192 100644 --- a/api/tests/tooling/chai-custom-helpers/deep-equal-instance-omitting.js +++ b/api/tests/tooling/chai-custom-helpers/deep-equal-instance-omitting.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); +import _ from 'lodash'; -module.exports = function (chai, _utils) { +const deepEqualInstanceOmitting = function (chai, _utils) { chai.Assertion.addMethod('deepEqualInstanceOmitting', function (referenceInstance, omittedAttributes) { const assertedInstance = this._obj; @@ -18,3 +18,5 @@ function _assertAreSameType(chai, value1, value2) { function _assertHaveSameContent(chai, value1, value2, omittedAttributes) { new chai.Assertion(_.omit(value1, omittedAttributes)).to.deep.equal(_.omit(value2, omittedAttributes)); } + +export { deepEqualInstanceOmitting }; diff --git a/api/tests/tooling/chai-custom-helpers/deep-equal-instance.js b/api/tests/tooling/chai-custom-helpers/deep-equal-instance.js index 31847807981..c5da809c470 100644 --- a/api/tests/tooling/chai-custom-helpers/deep-equal-instance.js +++ b/api/tests/tooling/chai-custom-helpers/deep-equal-instance.js @@ -1,4 +1,4 @@ -module.exports = function (chai, _utils) { +const deepEqualInstance = function (chai, _utils) { chai.Assertion.addMethod('deepEqualInstance', function (referenceInstance) { const assertedInstance = this._obj; @@ -16,3 +16,5 @@ function _assertAreSameType(chai, value1, value2) { function _assertHaveSameContent(chai, value1, value2) { new chai.Assertion(value1).to.deep.equal(value2); } + +export { deepEqualInstance }; diff --git a/api/tests/tooling/chai-custom-helpers/index.js b/api/tests/tooling/chai-custom-helpers/index.js index 9e0504599ad..4c2940dd846 100644 --- a/api/tests/tooling/chai-custom-helpers/index.js +++ b/api/tests/tooling/chai-custom-helpers/index.js @@ -1,5 +1,5 @@ -module.exports = { - deepEqualInstance: require('./deep-equal-instance'), - deepEqualInstanceOmitting: require('./deep-equal-instance-omitting'), - deepEqualArray: require('./deep-equal-array'), -}; +import { deepEqualInstance } from './deep-equal-instance.js'; +import { deepEqualInstanceOmitting } from './deep-equal-instance-omitting.js'; +import { deepEqualArray } from './deep-equal-array.js'; + +export { deepEqualInstance, deepEqualInstanceOmitting, deepEqualArray }; diff --git a/api/tests/tooling/domain-builder/domain-builder.js b/api/tests/tooling/domain-builder/domain-builder.js index 4e47513e183..8bad72c39b4 100644 --- a/api/tests/tooling/domain-builder/domain-builder.js +++ b/api/tests/tooling/domain-builder/domain-builder.js @@ -1 +1,3 @@ -module.exports = require('./factory'); +import * as domainBuilder from './factory/index.js'; + +export { domainBuilder }; diff --git a/api/tests/tooling/domain-builder/factory/build-account-recovery-demand.js b/api/tests/tooling/domain-builder/factory/build-account-recovery-demand.js index b44779a6187..12128c749e4 100644 --- a/api/tests/tooling/domain-builder/factory/build-account-recovery-demand.js +++ b/api/tests/tooling/domain-builder/factory/build-account-recovery-demand.js @@ -1,6 +1,6 @@ -const AccountRecoveryDemand = require('../../../../lib/domain/models/AccountRecoveryDemand'); +import { AccountRecoveryDemand } from '../../../../lib/domain/models/AccountRecoveryDemand.js'; -module.exports = function buildAccountRecoveryDemand({ +const buildAccountRecoveryDemand = function ({ userId = 7, organizationLearnerId, newEmail = 'new-email@example.net', @@ -17,3 +17,5 @@ module.exports = function buildAccountRecoveryDemand({ temporaryKey, }); }; + +export { buildAccountRecoveryDemand }; diff --git a/api/tests/tooling/domain-builder/factory/build-admin-member.js b/api/tests/tooling/domain-builder/factory/build-admin-member.js index fb9c6160e84..44eb618392e 100644 --- a/api/tests/tooling/domain-builder/factory/build-admin-member.js +++ b/api/tests/tooling/domain-builder/factory/build-admin-member.js @@ -1,5 +1,7 @@ -const AdminMember = require('../../../../lib/domain/models/AdminMember'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; +import { AdminMember } from '../../../../lib/domain/models/AdminMember.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; const buildAdminMember = function ({ id = 1, @@ -107,4 +109,4 @@ buildAdminMember.withRoleSuperAdmin = function ({ }); }; -module.exports = buildAdminMember; +export { buildAdminMember }; diff --git a/api/tests/tooling/domain-builder/factory/build-allowed-certification-center-access.js b/api/tests/tooling/domain-builder/factory/build-allowed-certification-center-access.js index e08b549896d..59bd694a8c8 100644 --- a/api/tests/tooling/domain-builder/factory/build-allowed-certification-center-access.js +++ b/api/tests/tooling/domain-builder/factory/build-allowed-certification-center-access.js @@ -1,4 +1,4 @@ -const AllowedCertificationCenterAccess = require('../../../../lib/domain/read-models/AllowedCertificationCenterAccess'); +import { AllowedCertificationCenterAccess } from '../../../../lib/domain/read-models/AllowedCertificationCenterAccess.js'; function buildAllowedCertificationCenterAccess({ id = 123, @@ -30,4 +30,4 @@ buildAllowedCertificationCenterAccess.notSco = function ({ }); }; -module.exports = buildAllowedCertificationCenterAccess; +export { buildAllowedCertificationCenterAccess }; diff --git a/api/tests/tooling/domain-builder/factory/build-answer.js b/api/tests/tooling/domain-builder/factory/build-answer.js index a786e72080c..7110f36919e 100644 --- a/api/tests/tooling/domain-builder/factory/build-answer.js +++ b/api/tests/tooling/domain-builder/factory/build-answer.js @@ -1,5 +1,5 @@ -const Answer = require('../../../../lib/domain/models/Answer'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); +import { Answer } from '../../../../lib/domain/models/Answer.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; function buildAnswer({ id = 123, @@ -135,4 +135,4 @@ buildAnswer.focusedOut = function ({ }); }; -module.exports = buildAnswer; +export { buildAnswer }; diff --git a/api/tests/tooling/domain-builder/factory/build-area.js b/api/tests/tooling/domain-builder/factory/build-area.js index 2d1dc87511b..40c6f7ff0e1 100644 --- a/api/tests/tooling/domain-builder/factory/build-area.js +++ b/api/tests/tooling/domain-builder/factory/build-area.js @@ -1,6 +1,6 @@ -const Area = require('../../../../lib/domain/models/Area'); +import { Area } from '../../../../lib/domain/models/Area.js'; -module.exports = function buildArea({ +const buildArea = function ({ id = 'recArea123', code = 5, title = 'Super domaine', @@ -24,3 +24,5 @@ module.exports = function buildArea({ }); return area; }; + +export { buildArea }; diff --git a/api/tests/tooling/domain-builder/factory/build-assessment-result.js b/api/tests/tooling/domain-builder/factory/build-assessment-result.js index aabb4c10edd..a6ffffefc22 100644 --- a/api/tests/tooling/domain-builder/factory/build-assessment-result.js +++ b/api/tests/tooling/domain-builder/factory/build-assessment-result.js @@ -1,6 +1,8 @@ -const { status: assessmentResultStatuses } = require('../../../../lib/domain/models/AssessmentResult'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { + status as assessmentResultStatuses, + AssessmentResult, +} from '../../../../lib/domain/models/AssessmentResult.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; const buildAssessmentResult = function ({ id = 123, @@ -182,4 +184,4 @@ buildAssessmentResult.standard = function ({ }); }; -module.exports = buildAssessmentResult; +export { buildAssessmentResult }; diff --git a/api/tests/tooling/domain-builder/factory/build-assessment.js b/api/tests/tooling/domain-builder/factory/build-assessment.js index ffa5e564cdd..164907fab16 100644 --- a/api/tests/tooling/domain-builder/factory/build-assessment.js +++ b/api/tests/tooling/domain-builder/factory/build-assessment.js @@ -1,11 +1,10 @@ -const _ = require('lodash'); -const Assessment = require('../../../../lib/domain/models/Assessment'); - -const buildAnswer = require('./build-answer'); -const buildCourse = require('./build-course'); -const buildKnowledgeElement = require('./build-knowledge-element'); -const buildTargetProfile = require('./build-target-profile'); -const buildCampaignParticipation = require('./build-campaign-participation'); +import _ from 'lodash'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { buildAnswer } from './build-answer.js'; +import { buildCourse } from './build-course.js'; +import { buildKnowledgeElement } from './build-knowledge-element.js'; +import { buildTargetProfile } from './build-target-profile.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; function buildAssessment({ id = 123, @@ -154,4 +153,4 @@ buildAssessment.ofTypeCompetenceEvaluation = function ({ buildAssessment.ofTypeCertification = buildAssessment; -module.exports = buildAssessment; +export { buildAssessment }; diff --git a/api/tests/tooling/domain-builder/factory/build-authentication-method.js b/api/tests/tooling/domain-builder/factory/build-authentication-method.js index f730d7d52b1..878eadf81b0 100644 --- a/api/tests/tooling/domain-builder/factory/build-authentication-method.js +++ b/api/tests/tooling/domain-builder/factory/build-authentication-method.js @@ -1,9 +1,10 @@ -const isUndefined = require('lodash/isUndefined'); +import lodash from 'lodash'; +const { isUndefined } = lodash; -const encrypt = require('../../../../lib/domain/services/encryption-service'); -const User = require('../../../../lib/domain/models/User'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); +import * as encrypt from '../../../../lib/domain/services/encryption-service.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; function _buildUser() { return new User({ @@ -148,4 +149,4 @@ buildAuthenticationMethod.withIdentityProvider = function ({ }); }; -module.exports = buildAuthenticationMethod; +export { buildAuthenticationMethod }; diff --git a/api/tests/tooling/domain-builder/factory/build-badge-acquisition.js b/api/tests/tooling/domain-builder/factory/build-badge-acquisition.js index fe664612e6d..3b08735ad96 100644 --- a/api/tests/tooling/domain-builder/factory/build-badge-acquisition.js +++ b/api/tests/tooling/domain-builder/factory/build-badge-acquisition.js @@ -1,5 +1,5 @@ -const buildBadge = require('./build-badge'); -const BadgeAcquisition = require('../../../../lib/domain/models/BadgeAcquisition'); +import { buildBadge } from './build-badge.js'; +import { BadgeAcquisition } from '../../../../lib/domain/models/BadgeAcquisition.js'; const buildBadgeAcquisition = function buildBadgeAcquisition({ id = 123, @@ -18,4 +18,4 @@ const buildBadgeAcquisition = function buildBadgeAcquisition({ }); }; -module.exports = buildBadgeAcquisition; +export { buildBadgeAcquisition }; diff --git a/api/tests/tooling/domain-builder/factory/build-badge-criterion-for-calculation.js b/api/tests/tooling/domain-builder/factory/build-badge-criterion-for-calculation.js index 1cd9d85daf6..6b6f79f60da 100644 --- a/api/tests/tooling/domain-builder/factory/build-badge-criterion-for-calculation.js +++ b/api/tests/tooling/domain-builder/factory/build-badge-criterion-for-calculation.js @@ -1,4 +1,4 @@ -const { BadgeCriterion } = require('../../../../lib/domain/models/BadgeForCalculation'); +import { BadgeCriterion } from '../../../../lib/domain/models/BadgeForCalculation.js'; const buildBadgeCriterionForCalculation = function buildBadgeCriterionForCalculation({ threshold = 80, @@ -10,4 +10,4 @@ const buildBadgeCriterionForCalculation = function buildBadgeCriterionForCalcula }); }; -module.exports = buildBadgeCriterionForCalculation; +export { buildBadgeCriterionForCalculation }; diff --git a/api/tests/tooling/domain-builder/factory/build-badge-criterion.js b/api/tests/tooling/domain-builder/factory/build-badge-criterion.js index ed67cf62501..c59a4b166f9 100644 --- a/api/tests/tooling/domain-builder/factory/build-badge-criterion.js +++ b/api/tests/tooling/domain-builder/factory/build-badge-criterion.js @@ -1,6 +1,6 @@ -const BadgeCriterion = require('../../../../lib/domain/models/BadgeCriterion'); +import { BadgeCriterion } from '../../../../lib/domain/models/BadgeCriterion.js'; -module.exports = function buildBadgeCriterion({ +const buildBadgeCriterion = function ({ id = 1, scope = BadgeCriterion.SCOPES.CAMPAIGN_PARTICIPATION, threshold = 40, @@ -13,3 +13,5 @@ module.exports = function buildBadgeCriterion({ skillSetIds, }); }; + +export { buildBadgeCriterion }; diff --git a/api/tests/tooling/domain-builder/factory/build-badge-details.js b/api/tests/tooling/domain-builder/factory/build-badge-details.js index 612739ef358..34e770c9952 100644 --- a/api/tests/tooling/domain-builder/factory/build-badge-details.js +++ b/api/tests/tooling/domain-builder/factory/build-badge-details.js @@ -1,10 +1,10 @@ -const { +import { BadgeDetails, BadgeCriterion, SkillSet, CappedTube, SCOPES, -} = require('../../../../lib/domain/models/BadgeDetails'); +} from '../../../../lib/domain/models/BadgeDetails.js'; const buildBadgeDetails = function buildBadgeDetails({ id = 123, @@ -81,4 +81,4 @@ buildBadgeDetails.buildBadgeCriterion_CappedTubes = function ({ }); }; -module.exports = buildBadgeDetails; +export { buildBadgeDetails }; diff --git a/api/tests/tooling/domain-builder/factory/build-badge-for-calculation.js b/api/tests/tooling/domain-builder/factory/build-badge-for-calculation.js index 9d0742ebf16..048c009644d 100644 --- a/api/tests/tooling/domain-builder/factory/build-badge-for-calculation.js +++ b/api/tests/tooling/domain-builder/factory/build-badge-for-calculation.js @@ -1,5 +1,5 @@ -const { BadgeForCalculation } = require('../../../../lib/domain/models/BadgeForCalculation'); -const buildBadgeCriterionForCalculation = require('./build-badge-criterion-for-calculation'); +import { BadgeForCalculation } from '../../../../lib/domain/models/BadgeForCalculation.js'; +import { buildBadgeCriterionForCalculation } from './build-badge-criterion-for-calculation.js'; const buildBadgeForCalculation = function buildBadgeForCalculation({ id = 1, @@ -23,4 +23,4 @@ buildBadgeForCalculation.mockNotObtainable = function buildObtainable({ id, badg return badgeForCalculation; }; -module.exports = buildBadgeForCalculation; +export { buildBadgeForCalculation }; diff --git a/api/tests/tooling/domain-builder/factory/build-badge.js b/api/tests/tooling/domain-builder/factory/build-badge.js index 26aeef16fb0..c47dfca7e31 100644 --- a/api/tests/tooling/domain-builder/factory/build-badge.js +++ b/api/tests/tooling/domain-builder/factory/build-badge.js @@ -1,8 +1,8 @@ -const Badge = require('../../../../lib/domain/models/Badge'); -const buildBadgeCriterion = require('./build-badge-criterion'); -const buildSkillSet = require('./build-skill-set'); +import { Badge } from '../../../../lib/domain/models/Badge.js'; +import { buildBadgeCriterion } from './build-badge-criterion.js'; +import { buildSkillSet } from './build-skill-set.js'; -module.exports = function buildBadge({ +const buildBadge = function ({ id = 1, altMessage = 'altMessage', imageUrl = '/img/banana', @@ -31,3 +31,5 @@ module.exports = function buildBadge({ complementaryCertificationBadge, }); }; + +export { buildBadge }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-collective-result.js b/api/tests/tooling/domain-builder/factory/build-campaign-collective-result.js index bad600747ce..4f340b90e4e 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-collective-result.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-collective-result.js @@ -1,7 +1,7 @@ -const buildCampaignLearningContent = require('./build-campaign-learning-content'); -const CampaignCollectiveResult = require('../../../../lib/domain/read-models/CampaignCollectiveResult'); +import { buildCampaignLearningContent } from './build-campaign-learning-content.js'; +import { CampaignCollectiveResult } from '../../../../lib/domain/read-models/CampaignCollectiveResult.js'; -module.exports = function buildCampaignCollectiveResult({ +const buildCampaignCollectiveResult = function ({ id = 123, campaignLearningContent = buildCampaignLearningContent(), participantsValidatedKECountByCompetenceId = [], @@ -18,3 +18,5 @@ module.exports = function buildCampaignCollectiveResult({ return campaignCollectiveResult; }; + +export { buildCampaignCollectiveResult }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-learning-content.js b/api/tests/tooling/domain-builder/factory/build-campaign-learning-content.js index 58a9331b018..04eb9443958 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-learning-content.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-learning-content.js @@ -1,5 +1,5 @@ -const CampaignLearningContent = require('../../../../lib/domain/models/CampaignLearningContent'); -const buildLearningContent = require('./build-learning-content'); +import { CampaignLearningContent } from '../../../../lib/domain/models/CampaignLearningContent.js'; +import { buildLearningContent } from './build-learning-content.js'; function buildCampaignLearningContent(learningContent = buildLearningContent()) { return new CampaignLearningContent(learningContent); @@ -15,4 +15,4 @@ buildCampaignLearningContent.withSimpleContent = () => { return buildCampaignLearningContent(simpleLearningContent); }; -module.exports = buildCampaignLearningContent; +export { buildCampaignLearningContent }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-management.js b/api/tests/tooling/domain-builder/factory/build-campaign-management.js index 026a5fc03fd..53a02333eef 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-management.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-management.js @@ -1,7 +1,7 @@ -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignManagement = require('../../../../lib/domain/read-models/CampaignManagement'); +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignManagement } from '../../../../lib/domain/read-models/CampaignManagement.js'; -module.exports = function buildCampaignManagement({ +const buildCampaignManagement = function ({ id = 1, name = 'Un nom de campagne', code = 'AZERTY123', @@ -30,3 +30,5 @@ module.exports = function buildCampaignManagement({ ownerLastName, }); }; + +export { buildCampaignManagement }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-participation-badge.js b/api/tests/tooling/domain-builder/factory/build-campaign-participation-badge.js index 12a8d35c8a1..cbc6719f9dc 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-participation-badge.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-participation-badge.js @@ -1,6 +1,6 @@ -const CampaignParticipationBadge = require('../../../../lib/domain/models/CampaignParticipationBadge'); +import { CampaignParticipationBadge } from '../../../../lib/domain/models/CampaignParticipationBadge.js'; -module.exports = function buildCampaignParticipationBadge({ +const buildCampaignParticipationBadge = function ({ id = 123, key, altMessage, @@ -27,3 +27,5 @@ module.exports = function buildCampaignParticipationBadge({ skillSetResults, }); }; + +export { buildCampaignParticipationBadge }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-participation-for-user-management.js b/api/tests/tooling/domain-builder/factory/build-campaign-participation-for-user-management.js index 0b48330e995..69a5847126b 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-participation-for-user-management.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-participation-for-user-management.js @@ -1,7 +1,7 @@ -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const CampaignParticipationForUserManagement = require('../../../../lib/domain/read-models/CampaignParticipationForUserManagement'); +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { CampaignParticipationForUserManagement } from '../../../../lib/domain/read-models/CampaignParticipationForUserManagement.js'; -module.exports = function buildCampaignParticipationForUserManagement({ +const buildCampaignParticipationForUserManagement = function ({ id = 1, participantExternalId = 'un identifiant externe', status = CampaignParticipationStatuses.TO_SHARE, @@ -32,3 +32,5 @@ module.exports = function buildCampaignParticipationForUserManagement({ organizationLearnerLastName, }); }; + +export { buildCampaignParticipationForUserManagement }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-participation-info.js b/api/tests/tooling/domain-builder/factory/build-campaign-participation-info.js index 7732facf0a3..49ead2962a3 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-participation-info.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-participation-info.js @@ -1,4 +1,4 @@ -const CampaignParticipationInfo = require('../../../../lib/domain/read-models/CampaignParticipationInfo'); +import { CampaignParticipationInfo } from '../../../../lib/domain/read-models/CampaignParticipationInfo.js'; function buildCampaignParticipationInfo({ participantFirstName = 'participantFirstName', @@ -28,4 +28,4 @@ function buildCampaignParticipationInfo({ }); } -module.exports = buildCampaignParticipationInfo; +export { buildCampaignParticipationInfo }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-participation-result.js b/api/tests/tooling/domain-builder/factory/build-campaign-participation-result.js index 02a3207c693..75f7d0ad2f9 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-participation-result.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-participation-result.js @@ -1,6 +1,6 @@ -const CampaignParticipationResult = require('../../../../lib/domain/models/CampaignParticipationResult'); +import { CampaignParticipationResult } from '../../../../lib/domain/models/CampaignParticipationResult.js'; -module.exports = function buildCampaignParticipationResult({ +const buildCampaignParticipationResult = function ({ id = 1, isCompleted = true, totalSkillsCount = 10, @@ -17,3 +17,5 @@ module.exports = function buildCampaignParticipationResult({ competenceResults, }); }; + +export { buildCampaignParticipationResult }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-participation.js b/api/tests/tooling/domain-builder/factory/build-campaign-participation.js index d7c6d7d47ec..78679b86e97 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-participation.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-participation.js @@ -1,9 +1,9 @@ -const CampaignParticipation = require('../../../../lib/domain/models/CampaignParticipation'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const buildCampaign = require('./build-campaign'); +import { CampaignParticipation } from '../../../../lib/domain/models/CampaignParticipation.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { buildCampaign } from './build-campaign.js'; const { SHARED } = CampaignParticipationStatuses; -module.exports = function buildCampaignParticipation({ +const buildCampaignParticipation = function ({ id = 1, campaign = buildCampaign(), sharedAt = new Date('2020-02-01'), @@ -33,3 +33,5 @@ module.exports = function buildCampaignParticipation({ deletedBy, }); }; + +export { buildCampaignParticipation }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-report.js b/api/tests/tooling/domain-builder/factory/build-campaign-report.js index 9c68eff090b..007f934cdd8 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-report.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-report.js @@ -1,7 +1,7 @@ -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignReport = require('../../../../lib/domain/read-models/CampaignReport'); +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignReport } from '../../../../lib/domain/read-models/CampaignReport.js'; -module.exports = function buildCampaignReport({ +const buildCampaignReport = function ({ id = 1, name = 'Un nom de campagne', code = 'AZERTY123', @@ -52,3 +52,5 @@ module.exports = function buildCampaignReport({ totalStage, }); }; + +export { buildCampaignReport }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-to-join.js b/api/tests/tooling/domain-builder/factory/build-campaign-to-join.js index 8b54b46d5a3..6432add8414 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-to-join.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-to-join.js @@ -1,8 +1,8 @@ -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignToJoin = require('../../../../lib/domain/read-models/CampaignToJoin'); -const { types } = require('../../../../lib/domain/models/Organization'); +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignToJoin } from '../../../../lib/domain/read-models/CampaignToJoin.js'; +import { types } from '../../../../lib/domain/models/Organization.js'; -module.exports = function buildCampaignToJoin({ +const buildCampaignToJoin = function ({ id = 1, code = 'AZERTY123', title = 'Un titre de campagne', @@ -51,3 +51,5 @@ module.exports = function buildCampaignToJoin({ assessmentMethod, }); }; + +export { buildCampaignToJoin }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign-to-start-participation.js b/api/tests/tooling/domain-builder/factory/build-campaign-to-start-participation.js index 4c4e99db3ae..8df8c7efd28 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign-to-start-participation.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign-to-start-participation.js @@ -1,7 +1,7 @@ -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignToStartParticipation = require('../../../../lib/domain/models/CampaignToStartParticipation'); +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignToStartParticipation } from '../../../../lib/domain/models/CampaignToStartParticipation.js'; -module.exports = function buildCampaignToStartParticipation({ +const buildCampaignToStartParticipation = function ({ id = 1, idPixLabel = 'Un id pix label', archivedAt = null, @@ -24,3 +24,5 @@ module.exports = function buildCampaignToStartParticipation({ organizationId, }); }; + +export { buildCampaignToStartParticipation }; diff --git a/api/tests/tooling/domain-builder/factory/build-campaign.js b/api/tests/tooling/domain-builder/factory/build-campaign.js index 4a004dc6111..aab88a5f9c1 100644 --- a/api/tests/tooling/domain-builder/factory/build-campaign.js +++ b/api/tests/tooling/domain-builder/factory/build-campaign.js @@ -1,8 +1,8 @@ -const Campaign = require('../../../../lib/domain/models/Campaign'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const buildOrganization = require('./build-organization'); -const buildTargetProfile = require('./build-target-profile'); -const buildUser = require('./build-user'); +import { Campaign } from '../../../../lib/domain/models/Campaign.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { buildOrganization } from './build-organization.js'; +import { buildTargetProfile } from './build-target-profile.js'; +import { buildUser } from './build-user.js'; function buildCampaign({ id = 1, @@ -140,4 +140,4 @@ buildCampaign.ofTypeProfilesCollection = function ({ }); }; -module.exports = buildCampaign; +export { buildCampaign }; diff --git a/api/tests/tooling/domain-builder/factory/build-certifiable-badge-acquisition.js b/api/tests/tooling/domain-builder/factory/build-certifiable-badge-acquisition.js index 19c40cca157..fb66886d176 100644 --- a/api/tests/tooling/domain-builder/factory/build-certifiable-badge-acquisition.js +++ b/api/tests/tooling/domain-builder/factory/build-certifiable-badge-acquisition.js @@ -1,4 +1,4 @@ -const CertifiableBadgeAcquisition = require('../../../../lib/domain/models/CertifiableBadgeAcquisition'); +import { CertifiableBadgeAcquisition } from '../../../../lib/domain/models/CertifiableBadgeAcquisition.js'; const buildCertifiableBadgeAcquisition = function ({ badgeId = 123, @@ -22,4 +22,4 @@ const buildCertifiableBadgeAcquisition = function ({ }); }; -module.exports = buildCertifiableBadgeAcquisition; +export { buildCertifiableBadgeAcquisition }; diff --git a/api/tests/tooling/domain-builder/factory/build-certifiable-profile-for-learning-content.js b/api/tests/tooling/domain-builder/factory/build-certifiable-profile-for-learning-content.js index 1b6e6ecc4e9..2a68fc0bd0c 100644 --- a/api/tests/tooling/domain-builder/factory/build-certifiable-profile-for-learning-content.js +++ b/api/tests/tooling/domain-builder/factory/build-certifiable-profile-for-learning-content.js @@ -1,4 +1,4 @@ -const CertifiableProfileForLearningContent = require('../../../../lib/domain/models/CertifiableProfileForLearningContent'); +import { CertifiableProfileForLearningContent } from '../../../../lib/domain/models/CertifiableProfileForLearningContent.js'; const buildCertifiableProfileForLearningContent = function ({ learningContent, @@ -12,4 +12,4 @@ const buildCertifiableProfileForLearningContent = function ({ }); }; -module.exports = buildCertifiableProfileForLearningContent; +export { buildCertifiableProfileForLearningContent }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-assessment-score.js b/api/tests/tooling/domain-builder/factory/build-certification-assessment-score.js index edf54578899..03cb1282d90 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-assessment-score.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-assessment-score.js @@ -1,6 +1,6 @@ -const CertificationAssessmentScore = require('../../../../lib/domain/models/CertificationAssessmentScore'); +import { CertificationAssessmentScore } from '../../../../lib/domain/models/CertificationAssessmentScore.js'; -module.exports = function buildCertificationAssessmentScore({ +const buildCertificationAssessmentScore = function ({ competenceMarks = [], percentageCorrectAnswers = 0, hasEnoughNonNeutralizedChallengesToBeTrusted = true, @@ -11,3 +11,5 @@ module.exports = function buildCertificationAssessmentScore({ hasEnoughNonNeutralizedChallengesToBeTrusted, }); }; + +export { buildCertificationAssessmentScore }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-assessment.js b/api/tests/tooling/domain-builder/factory/build-certification-assessment.js index 8a80ece6e8f..a28eac49567 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-assessment.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-assessment.js @@ -1,7 +1,7 @@ -const CertificationAssessment = require('../../../../lib/domain/models/CertificationAssessment'); -const buildCertificationChallengeWithType = require('./build-certification-challenge-with-type'); +import { CertificationAssessment } from '../../../../lib/domain/models/CertificationAssessment.js'; +import { buildCertificationChallengeWithType } from './build-certification-challenge-with-type.js'; -module.exports = function buildCertificationAssessment({ +const buildCertificationAssessment = function ({ id = 123, userId = 123, certificationCourseId = 123, @@ -24,3 +24,5 @@ module.exports = function buildCertificationAssessment({ certificationAnswersByDate, }); }; + +export { buildCertificationAssessment }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-attestation.js b/api/tests/tooling/domain-builder/factory/build-certification-attestation.js index dfc038b3cd4..275cfae9361 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-attestation.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-attestation.js @@ -1,6 +1,6 @@ -const CertificationAttestation = require('../../../../lib/domain/models/CertificationAttestation'); +import { CertificationAttestation } from '../../../../lib/domain/models/CertificationAttestation.js'; -module.exports = function buildCertificationAttestation({ +const buildCertificationAttestation = function ({ id = 1, firstName = 'Jean', lastName = 'Bon', @@ -35,3 +35,5 @@ module.exports = function buildCertificationAttestation({ resultCompetenceTree, }); }; + +export { buildCertificationAttestation }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-candidate-for-supervising.js b/api/tests/tooling/domain-builder/factory/build-certification-candidate-for-supervising.js index 37111c1e7e2..a33c0f57b05 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-candidate-for-supervising.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-candidate-for-supervising.js @@ -1,6 +1,6 @@ -const CertificationCandidateForSupervising = require('../../../../lib/domain/models/CertificationCandidateForSupervising'); +import { CertificationCandidateForSupervising } from '../../../../lib/domain/models/CertificationCandidateForSupervising.js'; -module.exports = function buildCertificationCandidateForSupervising({ +const buildCertificationCandidateForSupervising = function ({ id = 123, userId = 345, firstName = 'Monkey', @@ -29,3 +29,5 @@ module.exports = function buildCertificationCandidateForSupervising({ stillValidBadgeAcquisitions, }); }; + +export { buildCertificationCandidateForSupervising }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-candidate-subscription.js b/api/tests/tooling/domain-builder/factory/build-certification-candidate-subscription.js index 3f5d3f9a9d1..bef0aa0532f 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-candidate-subscription.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-candidate-subscription.js @@ -1,6 +1,6 @@ -const CertificationCandidateSubscription = require('../../../../lib/domain/read-models/CertificationCandidateSubscription'); +import { CertificationCandidateSubscription } from '../../../../lib/domain/read-models/CertificationCandidateSubscription.js'; -module.exports = function buildCertificationCandidateSubscription({ +const buildCertificationCandidateSubscription = function ({ id = 1234, sessionId = 1234, eligibleSubscriptions = [], @@ -13,3 +13,5 @@ module.exports = function buildCertificationCandidateSubscription({ nonEligibleSubscriptions, }); }; + +export { buildCertificationCandidateSubscription }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-candidate.js b/api/tests/tooling/domain-builder/factory/build-certification-candidate.js index fe4c19d87b8..2ad829c4540 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-candidate.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-candidate.js @@ -1,5 +1,5 @@ -const buildComplementaryCertification = require('./build-complementary-certification'); -const CertificationCandidate = require('../../../../lib/domain/models/CertificationCandidate'); +import { buildComplementaryCertification } from './build-complementary-certification.js'; +import { CertificationCandidate } from '../../../../lib/domain/models/CertificationCandidate.js'; const buildCertificationCandidate = function ({ id = 123, @@ -129,4 +129,4 @@ buildCertificationCandidate.notPersisted = function ({ }); }; -module.exports = buildCertificationCandidate; +export { buildCertificationCandidate }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-center-for-admin.js b/api/tests/tooling/domain-builder/factory/build-certification-center-for-admin.js index 6801032f015..7d3b412ddb1 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-center-for-admin.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-center-for-admin.js @@ -1,6 +1,6 @@ -const CertificationCenterForAdmin = require('../../../../lib/domain/models/CertificationCenterForAdmin'); +import { CertificationCenterForAdmin } from '../../../../lib/domain/models/CertificationCenterForAdmin.js'; -module.exports = function buildCertificationCenterForAdmin({ +const buildCertificationCenterForAdmin = function ({ id = 1, name = 'name', type = CertificationCenterForAdmin.types.SUP, @@ -25,3 +25,5 @@ module.exports = function buildCertificationCenterForAdmin({ habilitations, }); }; + +export { buildCertificationCenterForAdmin }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-center-invitation.js b/api/tests/tooling/domain-builder/factory/build-certification-center-invitation.js index 489f0a44a7b..9b926bacf01 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-center-invitation.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-center-invitation.js @@ -1,6 +1,6 @@ -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; -module.exports = function buildCertificationCenterInvitation({ +const buildCertificationCenterInvitation = function ({ id = 123, certificationCenterId = 456, email = 'userInvited@example.net', @@ -19,3 +19,5 @@ module.exports = function buildCertificationCenterInvitation({ updatedAt, }); }; + +export { buildCertificationCenterInvitation }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-center-membership.js b/api/tests/tooling/domain-builder/factory/build-certification-center-membership.js index dbd42b8df15..3d812e43947 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-center-membership.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-center-membership.js @@ -1,6 +1,6 @@ -const User = require('../../../../lib/domain/models/User'); -const CertificationCenterMembership = require('../../../../lib/domain/models/CertificationCenterMembership'); -const buildCertificationCenter = require('./build-certification-center'); +import { User } from '../../../../lib/domain/models/User.js'; +import { CertificationCenterMembership } from '../../../../lib/domain/models/CertificationCenterMembership.js'; +import { buildCertificationCenter } from './build-certification-center.js'; function _buildUser() { return new User({ @@ -11,7 +11,7 @@ function _buildUser() { }); } -module.exports = function buildCertificationCenterMembership({ +const buildCertificationCenterMembership = function ({ id = 1, certificationCenter = buildCertificationCenter(), user = _buildUser(), @@ -28,3 +28,5 @@ module.exports = function buildCertificationCenterMembership({ isReferer, }); }; + +export { buildCertificationCenterMembership }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-center.js b/api/tests/tooling/domain-builder/factory/build-certification-center.js index 67693c3dd6c..6ac9aca0bd2 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-center.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-center.js @@ -1,9 +1,9 @@ -const CertificationCenter = require('../../../../lib/domain/models/CertificationCenter'); +import { CertificationCenter, types } from '../../../../lib/domain/models/CertificationCenter.js'; -module.exports = function buildCertificationCenter({ +const buildCertificationCenter = function ({ id = 1, name = 'name', - type = CertificationCenter.types.SUP, + type = types.SUP, externalId = 'externalId', createdAt = new Date('2020-01-01'), updatedAt, @@ -19,3 +19,5 @@ module.exports = function buildCertificationCenter({ habilitations, }); }; + +export { buildCertificationCenter }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-challenge-with-type.js b/api/tests/tooling/domain-builder/factory/build-certification-challenge-with-type.js index 197e2f8a168..5a70b98361d 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-challenge-with-type.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-challenge-with-type.js @@ -1,7 +1,7 @@ -const CertificationChallengeWithType = require('../../../../lib/domain/models/CertificationChallengeWithType'); -const Challenge = require('../../../../lib/domain/models/Challenge'); +import { CertificationChallengeWithType } from '../../../../lib/domain/models/CertificationChallengeWithType.js'; +import { Challenge } from '../../../../lib/domain/models/Challenge.js'; -module.exports = function buildCertificationChallengeWithType({ +const buildCertificationChallengeWithType = function ({ id = 123, challengeId = 'recCHAL', competenceId = 'recCOMP', @@ -22,3 +22,5 @@ module.exports = function buildCertificationChallengeWithType({ certifiableBadgeKey, }); }; + +export { buildCertificationChallengeWithType }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-challenge.js b/api/tests/tooling/domain-builder/factory/build-certification-challenge.js index b0f29c830f2..2a6db96daf3 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-challenge.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-challenge.js @@ -1,5 +1,5 @@ -const buildSkill = require('./build-skill'); -const CertificationChallenge = require('../../../../lib/domain/models/CertificationChallenge'); +import { buildSkill } from './build-skill.js'; +import { CertificationChallenge } from '../../../../lib/domain/models/CertificationChallenge.js'; const buildCertificationChallenge = function ({ id = 123, @@ -60,4 +60,4 @@ buildCertificationChallenge.forPixPlusCertification = function ({ }); }; -module.exports = buildCertificationChallenge; +export { buildCertificationChallenge }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-course.js b/api/tests/tooling/domain-builder/factory/build-certification-course.js index e7aada0e2da..9f3aac6bc9e 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-course.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-course.js @@ -1,9 +1,7 @@ -const CertificationCourse = require('../../../../lib/domain/models/CertificationCourse'); -const buildAssessment = require('./build-assessment'); -const CertificationIssueReport = require('../../../../lib/domain/models/CertificationIssueReport'); -const { - CertificationIssueReportCategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); +import { CertificationCourse } from '../../../../lib/domain/models/CertificationCourse.js'; +import { buildAssessment } from './build-assessment.js'; +import { CertificationIssueReport } from '../../../../lib/domain/models/CertificationIssueReport.js'; +import { CertificationIssueReportCategory } from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; function buildCertificationCourse({ id = 123, @@ -38,7 +36,7 @@ function buildCertificationCourse({ new CertificationIssueReport({ id: 159, certificationCourseId: id, - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, description: examinerComment, }) ); @@ -126,4 +124,4 @@ buildCertificationCourse.unpersisted = function ({ }); }; -module.exports = buildCertificationCourse; +export { buildCertificationCourse }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-cpf-city.js b/api/tests/tooling/domain-builder/factory/build-certification-cpf-city.js index 723c9e4acee..1a7a3f173a1 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-cpf-city.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-cpf-city.js @@ -1,4 +1,4 @@ -const CertificationCpfCity = require('../../../../lib/domain/models/CertificationCpfCity'); +import { CertificationCpfCity } from '../../../../lib/domain/models/CertificationCpfCity.js'; function buildCertificationCpfCity({ id = 123, @@ -16,4 +16,4 @@ function buildCertificationCpfCity({ }); } -module.exports = buildCertificationCpfCity; +export { buildCertificationCpfCity }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-cpf-country.js b/api/tests/tooling/domain-builder/factory/build-certification-cpf-country.js index 65d19340819..fd7dd06f2a9 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-cpf-country.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-cpf-country.js @@ -1,4 +1,4 @@ -const CertificationCpfCountry = require('../../../../lib/domain/models/CertificationCpfCountry'); +import { CertificationCpfCountry } from '../../../../lib/domain/models/CertificationCpfCountry.js'; function buildCertificationCpfCountry({ id = 123, @@ -32,4 +32,4 @@ buildCertificationCpfCountry.FRANCE = function ({ }); }; -module.exports = buildCertificationCpfCountry; +export { buildCertificationCpfCountry }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-details.js b/api/tests/tooling/domain-builder/factory/build-certification-details.js index 21aa87922ae..11240ba0e40 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-details.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-details.js @@ -1,7 +1,7 @@ -const CertificationDetails = require('../../../../lib/domain/read-models/CertificationDetails'); -const { states } = require('../../../../lib/domain/models/CertificationAssessment'); +import { CertificationDetails } from '../../../../lib/domain/read-models/CertificationDetails.js'; +import { states } from '../../../../lib/domain/models/CertificationAssessment.js'; -module.exports = function buildCertificationDetails({ +const buildCertificationDetails = function ({ id = 123, userId = 456, createdAt = new Date('2020-01-01'), @@ -43,3 +43,5 @@ module.exports = function buildCertificationDetails({ listChallengesAndAnswers, }); }; + +export { buildCertificationDetails }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-eligibility.js b/api/tests/tooling/domain-builder/factory/build-certification-eligibility.js index 9eab041d185..685702a2e2c 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-eligibility.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-eligibility.js @@ -1,6 +1,6 @@ -const CertificationEligibility = require('../../../../lib/domain/read-models/CertificationEligibility'); +import { CertificationEligibility } from '../../../../lib/domain/read-models/CertificationEligibility.js'; -module.exports = function buildCertificationEligibility({ +const buildCertificationEligibility = function ({ id = 123, pixCertificationEligible = false, eligibleComplementaryCertifications = [], @@ -11,3 +11,5 @@ module.exports = function buildCertificationEligibility({ eligibleComplementaryCertifications, }); }; + +export { buildCertificationEligibility }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-issue-report.js b/api/tests/tooling/domain-builder/factory/build-certification-issue-report.js index a376b20d6fa..c2623d5c0ea 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-issue-report.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-issue-report.js @@ -1,14 +1,14 @@ -const CertificationIssueReport = require('../../../../lib/domain/models/CertificationIssueReport'); -const { - CertificationIssueReportCategories, +import { CertificationIssueReport } from '../../../../lib/domain/models/CertificationIssueReport.js'; +import { + CertificationIssueReportCategory, CertificationIssueReportSubcategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); +} from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; const buildCertificationIssueReport = function ({ id = 123, certificationCourseId, categoryId, - category = CertificationIssueReportCategories.CANDIDATE_INFORMATIONS_CHANGES, + category = CertificationIssueReportCategory.CANDIDATE_INFORMATIONS_CHANGES, subcategory = CertificationIssueReportSubcategories.NAME_OR_BIRTHDATE, description = 'Une super description', questionNumber = null, @@ -48,7 +48,7 @@ buildCertificationIssueReport.impactful = function ({ resolvedAt, resolution, categoryId, - category: CertificationIssueReportCategories.FRAUD, + category: CertificationIssueReportCategory.FRAUD, subcategory: null, hasBeenAutomaticallyResolved, }); @@ -72,10 +72,10 @@ buildCertificationIssueReport.notImpactful = function ({ resolvedAt, resolution, categoryId, - category: CertificationIssueReportCategories.SIGNATURE_ISSUE, + category: CertificationIssueReportCategory.SIGNATURE_ISSUE, subcategory: null, hasBeenAutomaticallyResolved, }); }; -module.exports = buildCertificationIssueReport; +export { buildCertificationIssueReport }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-officer.js b/api/tests/tooling/domain-builder/factory/build-certification-officer.js index e493516ffcc..8699a6a9408 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-officer.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-officer.js @@ -1,9 +1,11 @@ -const CertificationOfficer = require('../../../../lib/domain/models/CertificationOfficer'); +import { CertificationOfficer } from '../../../../lib/domain/models/CertificationOfficer.js'; -module.exports = function buildCertificationOfficer({ id = 123, firstName = 'Dean', lastName = 'Winchester' } = {}) { +const buildCertificationOfficer = function ({ id = 123, firstName = 'Dean', lastName = 'Winchester' } = {}) { return new CertificationOfficer({ id, firstName, lastName, }); }; + +export { buildCertificationOfficer }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-point-of-contact.js b/api/tests/tooling/domain-builder/factory/build-certification-point-of-contact.js index 830770cc341..2622d598736 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-point-of-contact.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-point-of-contact.js @@ -1,7 +1,7 @@ -const CertificationPointOfContact = require('../../../../lib/domain/read-models/CertificationPointOfContact'); -const buildAllowedCertificationCenterAccess = require('./build-allowed-certification-center-access'); +import { CertificationPointOfContact } from '../../../../lib/domain/read-models/CertificationPointOfContact.js'; +import { buildAllowedCertificationCenterAccess } from './build-allowed-certification-center-access.js'; -module.exports = function buildCertificationPointOfContact({ +const buildCertificationPointOfContact = function ({ id = 123, firstName = 'Chèvre', lastName = 'Brebis', @@ -20,3 +20,5 @@ module.exports = function buildCertificationPointOfContact({ allowedCertificationCenterAccesses, }); }; + +export { buildCertificationPointOfContact }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-report.js b/api/tests/tooling/domain-builder/factory/build-certification-report.js index 88f2ffa743d..26d4eeab8a7 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-report.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-report.js @@ -1,7 +1,7 @@ -const CertificationReport = require('../../../../lib/domain/models/CertificationReport'); -const buildCertificationIssueReport = require('./build-certification-issue-report'); +import { CertificationReport } from '../../../../lib/domain/models/CertificationReport.js'; +import { buildCertificationIssueReport } from './build-certification-issue-report.js'; -module.exports = function buildCertificationReport({ +const buildCertificationReport = function ({ id = 'CertificationReport:456', firstName = 'Tiffany', lastName = 'Schwarzenegger', @@ -26,3 +26,5 @@ module.exports = function buildCertificationReport({ abortReason, }); }; + +export { buildCertificationReport }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-rescoring-completed-event.js b/api/tests/tooling/domain-builder/factory/build-certification-rescoring-completed-event.js index e6fef41ed2d..bd60dbe465a 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-rescoring-completed-event.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-rescoring-completed-event.js @@ -1,4 +1,4 @@ -const CertificationRescoringCompleted = require('../../../../lib/domain/events/CertificationRescoringCompleted'); +import { CertificationRescoringCompleted } from '../../../../lib/domain/events/CertificationRescoringCompleted.js'; const buildCertificationRescoringCompletedEvent = function ({ certificationCourseId = 123, @@ -12,4 +12,4 @@ const buildCertificationRescoringCompletedEvent = function ({ }); }; -module.exports = buildCertificationRescoringCompletedEvent; +export { buildCertificationRescoringCompletedEvent }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-result.js b/api/tests/tooling/domain-builder/factory/build-certification-result.js index c20cf608ff0..ba4ce885f9a 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-result.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-result.js @@ -1,4 +1,4 @@ -const CertificationResult = require('../../../../lib/domain/models/CertificationResult'); +import { CertificationResult } from '../../../../lib/domain/models/CertificationResult.js'; const buildCertificationResult = function ({ id = 123, @@ -166,4 +166,4 @@ buildCertificationResult.error = function ({ }); }; -module.exports = buildCertificationResult; +export { buildCertificationResult }; diff --git a/api/tests/tooling/domain-builder/factory/build-certification-scoring-completed-event.js b/api/tests/tooling/domain-builder/factory/build-certification-scoring-completed-event.js index 178629c9ee0..7dc8007e9f3 100644 --- a/api/tests/tooling/domain-builder/factory/build-certification-scoring-completed-event.js +++ b/api/tests/tooling/domain-builder/factory/build-certification-scoring-completed-event.js @@ -1,4 +1,4 @@ -const CertificationScoringCompleted = require('../../../../lib/domain/events/CertificationScoringCompleted'); +import { CertificationScoringCompleted } from '../../../../lib/domain/events/CertificationScoringCompleted.js'; const buildCertificationScoringCompletedEvent = function ({ certificationCourseId = 123, @@ -12,4 +12,4 @@ const buildCertificationScoringCompletedEvent = function ({ }); }; -module.exports = buildCertificationScoringCompletedEvent; +export { buildCertificationScoringCompletedEvent }; diff --git a/api/tests/tooling/domain-builder/factory/build-certifications-results-for-ls.js b/api/tests/tooling/domain-builder/factory/build-certifications-results-for-ls.js index d83d55c12ce..b3610d20d9b 100644 --- a/api/tests/tooling/domain-builder/factory/build-certifications-results-for-ls.js +++ b/api/tests/tooling/domain-builder/factory/build-certifications-results-for-ls.js @@ -1,6 +1,6 @@ -const { databaseBuilder, learningContentBuilder, mockLearningContent } = require('../../../test-helper'); -const { status } = require('../../../../lib/domain/models/AssessmentResult'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { databaseBuilder, learningContentBuilder, mockLearningContent } from '../../../test-helper.js'; +import { status } from '../../../../lib/domain/models/AssessmentResult.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; const assessmentCreatedDate = new Date('2020-04-19'); const assessmentBeforeCreatedDate = new Date('2020-04-18'); @@ -357,11 +357,11 @@ function mockLearningContentCompetences() { }, ]; - const learningContentObjects = learningContentBuilder.buildLearningContent.fromAreas(learningContent); + const learningContentObjects = learningContentBuilder.fromAreas(learningContent); mockLearningContent(learningContentObjects); } -module.exports = { +export { buildValidatedPublishedCertificationData, buildValidatedUnpublishedCertificationData, buildCancelledCertificationData, diff --git a/api/tests/tooling/domain-builder/factory/build-certified-area.js b/api/tests/tooling/domain-builder/factory/build-certified-area.js index f5136b72459..3143ee44137 100644 --- a/api/tests/tooling/domain-builder/factory/build-certified-area.js +++ b/api/tests/tooling/domain-builder/factory/build-certified-area.js @@ -1,4 +1,4 @@ -const { CertifiedArea } = require('../../../../lib/domain/read-models/CertifiedProfile'); +import { CertifiedArea } from '../../../../lib/domain/read-models/CertifiedProfile.js'; const buildCertifiedArea = function buildCertifiedArea({ id = 'someAreaId', @@ -12,4 +12,4 @@ const buildCertifiedArea = function buildCertifiedArea({ }); }; -module.exports = buildCertifiedArea; +export { buildCertifiedArea }; diff --git a/api/tests/tooling/domain-builder/factory/build-certified-competence.js b/api/tests/tooling/domain-builder/factory/build-certified-competence.js index b786a595778..65ed0c9acf4 100644 --- a/api/tests/tooling/domain-builder/factory/build-certified-competence.js +++ b/api/tests/tooling/domain-builder/factory/build-certified-competence.js @@ -1,4 +1,4 @@ -const { CertifiedCompetence } = require('../../../../lib/domain/read-models/CertifiedProfile'); +import { CertifiedCompetence } from '../../../../lib/domain/read-models/CertifiedProfile.js'; const buildCertifiedCompetence = function buildCertifiedCompetence({ id = 'someCompetenceId', @@ -14,4 +14,4 @@ const buildCertifiedCompetence = function buildCertifiedCompetence({ }); }; -module.exports = buildCertifiedCompetence; +export { buildCertifiedCompetence }; diff --git a/api/tests/tooling/domain-builder/factory/build-certified-profile.js b/api/tests/tooling/domain-builder/factory/build-certified-profile.js index 99ef496386f..3fbef3f9c0a 100644 --- a/api/tests/tooling/domain-builder/factory/build-certified-profile.js +++ b/api/tests/tooling/domain-builder/factory/build-certified-profile.js @@ -1,4 +1,4 @@ -const { CertifiedProfile } = require('../../../../lib/domain/read-models/CertifiedProfile'); +import { CertifiedProfile } from '../../../../lib/domain/read-models/CertifiedProfile.js'; const buildCertifiedProfile = function buildCertifiedProfile({ id = 123, @@ -18,4 +18,4 @@ const buildCertifiedProfile = function buildCertifiedProfile({ }); }; -module.exports = buildCertifiedProfile; +export { buildCertifiedProfile }; diff --git a/api/tests/tooling/domain-builder/factory/build-certified-skill.js b/api/tests/tooling/domain-builder/factory/build-certified-skill.js index cb50cae8f3d..0f009006417 100644 --- a/api/tests/tooling/domain-builder/factory/build-certified-skill.js +++ b/api/tests/tooling/domain-builder/factory/build-certified-skill.js @@ -1,4 +1,4 @@ -const { CertifiedSkill } = require('../../../../lib/domain/read-models/CertifiedProfile'); +import { CertifiedSkill } from '../../../../lib/domain/read-models/CertifiedProfile.js'; const buildCertifiedSkill = function buildCertifiedSkill({ id = 'someSkillId', @@ -16,4 +16,4 @@ const buildCertifiedSkill = function buildCertifiedSkill({ }); }; -module.exports = buildCertifiedSkill; +export { buildCertifiedSkill }; diff --git a/api/tests/tooling/domain-builder/factory/build-certified-tube.js b/api/tests/tooling/domain-builder/factory/build-certified-tube.js index b2f979bfa42..a20c6f71d31 100644 --- a/api/tests/tooling/domain-builder/factory/build-certified-tube.js +++ b/api/tests/tooling/domain-builder/factory/build-certified-tube.js @@ -1,4 +1,4 @@ -const { CertifiedTube } = require('../../../../lib/domain/read-models/CertifiedProfile'); +import { CertifiedTube } from '../../../../lib/domain/read-models/CertifiedProfile.js'; const buildCertifiedTube = function buildCertifiedTube({ id = 'someTubeId', @@ -12,4 +12,4 @@ const buildCertifiedTube = function buildCertifiedTube({ }); }; -module.exports = buildCertifiedTube; +export { buildCertifiedTube }; diff --git a/api/tests/tooling/domain-builder/factory/build-challenge-learning-content-data-object.js b/api/tests/tooling/domain-builder/factory/build-challenge-learning-content-data-object.js index c73ee0f16f8..129778ff5e1 100644 --- a/api/tests/tooling/domain-builder/factory/build-challenge-learning-content-data-object.js +++ b/api/tests/tooling/domain-builder/factory/build-challenge-learning-content-data-object.js @@ -1,4 +1,4 @@ -module.exports = function buildChallengeLearningContentDataObject({ +const buildChallengeLearningContentDataObject = function ({ id = 'recwWzTquPlvIl4So', instruction = "Les moteurs de recherche affichent certains liens en raison d'un accord commercial.\n\nDans quels encadrés se trouvent ces liens ?", proposals = '- 1\n- 2\n- 3\n- 4\n- 5', @@ -50,3 +50,5 @@ module.exports = function buildChallengeLearningContentDataObject({ shuffled, }; }; + +export { buildChallengeLearningContentDataObject }; diff --git a/api/tests/tooling/domain-builder/factory/build-challenge.js b/api/tests/tooling/domain-builder/factory/build-challenge.js index 5cab1cc201b..d5424c3db10 100644 --- a/api/tests/tooling/domain-builder/factory/build-challenge.js +++ b/api/tests/tooling/domain-builder/factory/build-challenge.js @@ -1,8 +1,8 @@ -const Challenge = require('../../../../lib/domain/models/Challenge'); -const Validator = require('../../../../lib/domain/models/Validator'); -const buildSkill = require('./build-skill'); +import { Challenge } from '../../../../lib/domain/models/Challenge.js'; +import { Validator } from '../../../../lib/domain/models/Validator.js'; +import { buildSkill } from './build-skill.js'; -module.exports = function buildChallenge({ +const buildChallenge = function ({ id = 'recCHAL1', // attributes attachments = ['URL pièce jointe'], @@ -65,3 +65,5 @@ module.exports = function buildChallenge({ shuffled, }); }; + +export { buildChallenge }; diff --git a/api/tests/tooling/domain-builder/factory/build-clea-certified-candidate.js b/api/tests/tooling/domain-builder/factory/build-clea-certified-candidate.js index bb64a867634..0dfa9d50ac7 100644 --- a/api/tests/tooling/domain-builder/factory/build-clea-certified-candidate.js +++ b/api/tests/tooling/domain-builder/factory/build-clea-certified-candidate.js @@ -1,6 +1,6 @@ -const CleaCertifiedCandidate = require('../../../../lib/domain/read-models/CleaCertifiedCandidate'); +import { CleaCertifiedCandidate } from '../../../../lib/domain/read-models/CleaCertifiedCandidate.js'; -module.exports = function buildCleaCertifiedCandidate({ +const buildCleaCertifiedCandidate = function ({ firstName = 'Gandhi', lastName = 'Matmatah', resultRecipientEmail = 'matmatahGdu75@dhi.fr', @@ -25,3 +25,5 @@ module.exports = function buildCleaCertifiedCandidate({ createdAt, }); }; + +export { buildCleaCertifiedCandidate }; diff --git a/api/tests/tooling/domain-builder/factory/build-competence-evaluation.js b/api/tests/tooling/domain-builder/factory/build-competence-evaluation.js index ef87592b572..aabced6d24a 100644 --- a/api/tests/tooling/domain-builder/factory/build-competence-evaluation.js +++ b/api/tests/tooling/domain-builder/factory/build-competence-evaluation.js @@ -1,8 +1,8 @@ -const CompetenceEvaluation = require('../../../../lib/domain/models/CompetenceEvaluation'); -const buildAssessment = require('./build-assessment'); -const buildUser = require('./build-user'); +import { CompetenceEvaluation } from '../../../../lib/domain/models/CompetenceEvaluation.js'; +import { buildAssessment } from './build-assessment.js'; +import { buildUser } from './build-user.js'; -module.exports = function buildCompetenceEvaluation({ +const buildCompetenceEvaluation = function ({ id = 1, assessmentId, assessment, @@ -34,3 +34,5 @@ module.exports = function buildCompetenceEvaluation({ status, }); }; + +export { buildCompetenceEvaluation }; diff --git a/api/tests/tooling/domain-builder/factory/build-competence-mark.js b/api/tests/tooling/domain-builder/factory/build-competence-mark.js index 4b799ed8682..e69695450f7 100644 --- a/api/tests/tooling/domain-builder/factory/build-competence-mark.js +++ b/api/tests/tooling/domain-builder/factory/build-competence-mark.js @@ -1,6 +1,6 @@ -const CompetenceMark = require('../../../../lib/domain/models/CompetenceMark'); +import { CompetenceMark } from '../../../../lib/domain/models/CompetenceMark.js'; -module.exports = function buildCompetenceMark({ +const buildCompetenceMark = function ({ id, level = 2, score = 13, @@ -19,3 +19,5 @@ module.exports = function buildCompetenceMark({ assessmentResultId, }); }; + +export { buildCompetenceMark }; diff --git a/api/tests/tooling/domain-builder/factory/build-competence-result.js b/api/tests/tooling/domain-builder/factory/build-competence-result.js index c5062342c3e..3544f8a2a99 100644 --- a/api/tests/tooling/domain-builder/factory/build-competence-result.js +++ b/api/tests/tooling/domain-builder/factory/build-competence-result.js @@ -1,6 +1,6 @@ -const CompetenceResult = require('../../../../lib/domain/models/CompetenceResult'); +import { CompetenceResult } from '../../../../lib/domain/models/CompetenceResult.js'; -module.exports = function buildCompetenceResult({ +const buildCompetenceResult = function ({ id = 1, name = 'name', index = '1.1', @@ -21,3 +21,5 @@ module.exports = function buildCompetenceResult({ validatedSkillsCount, }); }; + +export { buildCompetenceResult }; diff --git a/api/tests/tooling/domain-builder/factory/build-competence-tree.js b/api/tests/tooling/domain-builder/factory/build-competence-tree.js index aff3795b1e0..dbc9844a298 100644 --- a/api/tests/tooling/domain-builder/factory/build-competence-tree.js +++ b/api/tests/tooling/domain-builder/factory/build-competence-tree.js @@ -1,9 +1,8 @@ -const CompetenceTree = require('../../../../lib/domain/models/CompetenceTree'); +import { CompetenceTree } from '../../../../lib/domain/models/CompetenceTree.js'; +import { buildArea } from './build-area.js'; +import { buildCompetence } from './build-competence.js'; -const buildArea = require('./build-area'); -const buildCompetence = require('./build-competence'); - -module.exports = function buildCompetenceTree({ +const buildCompetenceTree = function ({ id = 1, areas = [ buildArea({ @@ -42,3 +41,5 @@ module.exports = function buildCompetenceTree({ areas, }); }; + +export { buildCompetenceTree }; diff --git a/api/tests/tooling/domain-builder/factory/build-competence.js b/api/tests/tooling/domain-builder/factory/build-competence.js index 5066c96fde5..12b6119d83c 100644 --- a/api/tests/tooling/domain-builder/factory/build-competence.js +++ b/api/tests/tooling/domain-builder/factory/build-competence.js @@ -1,4 +1,4 @@ -const Competence = require('../../../../lib/domain/models/Competence'); +import { Competence } from '../../../../lib/domain/models/Competence.js'; const buildCompetence = function ({ id = 'recCOMP1', @@ -24,4 +24,4 @@ const buildCompetence = function ({ }); }; -module.exports = buildCompetence; +export { buildCompetence }; diff --git a/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result-for-certification-with-external.js b/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result-for-certification-with-external.js index 95427d6a25b..0e6991f3b19 100644 --- a/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result-for-certification-with-external.js +++ b/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result-for-certification-with-external.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationCourseResultsForJuryCertificationWithExternal = require('../../../../lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal'); +import { ComplementaryCertificationCourseResultsForJuryCertificationWithExternal } from '../../../../lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal.js'; -module.exports = function buildPixEduComplementaryCertificationCourseResultsForJuryCertificationWithExternal({ +const buildPixEduComplementaryCertificationCourseResultsForJuryCertificationWithExternal = function ({ complementaryCertificationCourseId = 456, pixPartnerKey = 'PIX_PARTNER_KEY', pixLabel = 'Pix+ Édu 1er degré Avancé', @@ -25,3 +25,5 @@ module.exports = function buildPixEduComplementaryCertificationCourseResultsForJ allowedExternalLevels, }); }; + +export { buildPixEduComplementaryCertificationCourseResultsForJuryCertificationWithExternal }; diff --git a/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result-for-certification.js b/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result-for-certification.js index 367a9ceab1a..604a6c3ff2a 100644 --- a/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result-for-certification.js +++ b/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result-for-certification.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationCourseResultForJuryCertification = require('../../../../lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification'); +import { ComplementaryCertificationCourseResultsForJuryCertification as ComplementaryCertificationCourseResultForJuryCertification } from '../../../../lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification.js'; -module.exports = function buildComplementaryCertificationCourseResultForJuryCertification({ +const buildComplementaryCertificationCourseResultForJuryCertification = function ({ id = 1234, partnerKey = 'PARTNER_KEY', acquired = true, @@ -13,3 +13,5 @@ module.exports = function buildComplementaryCertificationCourseResultForJuryCert label, }); }; + +export { buildComplementaryCertificationCourseResultForJuryCertification }; diff --git a/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result.js b/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result.js index 95ce113defc..2ba9ff52f3f 100644 --- a/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result.js +++ b/api/tests/tooling/domain-builder/factory/build-complementary-certification-course-result.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationCourseResult = require('./../../../../lib/domain/models/ComplementaryCertificationCourseResult'); +import { ComplementaryCertificationCourseResult } from './../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; -module.exports = function buildComplementaryCertificationCourseResult({ +const buildComplementaryCertificationCourseResult = function ({ complementaryCertificationCourseId = 2, partnerKey = 'PARTNER_KEY', acquired = false, @@ -15,3 +15,5 @@ module.exports = function buildComplementaryCertificationCourseResult({ label, }); }; + +export { buildComplementaryCertificationCourseResult }; diff --git a/api/tests/tooling/domain-builder/factory/build-complementary-certification-for-supervising.js b/api/tests/tooling/domain-builder/factory/build-complementary-certification-for-supervising.js index 4d1d3c5c0ca..31689f7fb93 100644 --- a/api/tests/tooling/domain-builder/factory/build-complementary-certification-for-supervising.js +++ b/api/tests/tooling/domain-builder/factory/build-complementary-certification-for-supervising.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationForSupervising = require('../../../../lib/domain/models/ComplementaryCertificationForSupervising'); +import { ComplementaryCertificationForSupervising } from '../../../../lib/domain/models/ComplementaryCertificationForSupervising.js'; -module.exports = function buildComplementaryCertificationForSupervising({ +const buildComplementaryCertificationForSupervising = function ({ label = 'Complementary certification name', key = 'COMPLEMENTARY_CERTIFICATION_KEY', certificationExtraTime = 0, @@ -11,3 +11,5 @@ module.exports = function buildComplementaryCertificationForSupervising({ certificationExtraTime, }); }; + +export { buildComplementaryCertificationForSupervising }; diff --git a/api/tests/tooling/domain-builder/factory/build-complementary-certification-habilitation.js b/api/tests/tooling/domain-builder/factory/build-complementary-certification-habilitation.js index d32802e0b40..a11f4e8f114 100644 --- a/api/tests/tooling/domain-builder/factory/build-complementary-certification-habilitation.js +++ b/api/tests/tooling/domain-builder/factory/build-complementary-certification-habilitation.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationHabilitation = require('../../../../lib/domain/models/ComplementaryCertificationHabilitation'); +import { ComplementaryCertificationHabilitation } from '../../../../lib/domain/models/ComplementaryCertificationHabilitation.js'; -module.exports = function buildComplementaryCertificationHabilitation({ +const buildComplementaryCertificationHabilitation = function ({ id = 123, complementaryCertificationId = 456, certificationCenterId = 789, @@ -11,3 +11,5 @@ module.exports = function buildComplementaryCertificationHabilitation({ certificationCenterId, }); }; + +export { buildComplementaryCertificationHabilitation }; diff --git a/api/tests/tooling/domain-builder/factory/build-complementary-certification-scoring-criteria.js b/api/tests/tooling/domain-builder/factory/build-complementary-certification-scoring-criteria.js index 05a247ee0a5..5e9d8014a2d 100644 --- a/api/tests/tooling/domain-builder/factory/build-complementary-certification-scoring-criteria.js +++ b/api/tests/tooling/domain-builder/factory/build-complementary-certification-scoring-criteria.js @@ -1,4 +1,4 @@ -const ComplementaryCertificationScoringCriteria = require('../../../../lib/domain/models/ComplementaryCertificationScoringCriteria'); +import { ComplementaryCertificationScoringCriteria } from '../../../../lib/domain/models/ComplementaryCertificationScoringCriteria.js'; function buildComplementaryCertificationScoringCriteria({ complementaryCertificationCourseId = 123, @@ -16,4 +16,4 @@ function buildComplementaryCertificationScoringCriteria({ }); } -module.exports = buildComplementaryCertificationScoringCriteria; +export { buildComplementaryCertificationScoringCriteria }; diff --git a/api/tests/tooling/domain-builder/factory/build-complementary-certification-scoring-without-complementary-referential.js b/api/tests/tooling/domain-builder/factory/build-complementary-certification-scoring-without-complementary-referential.js index d79c09430c4..6306747b5a1 100644 --- a/api/tests/tooling/domain-builder/factory/build-complementary-certification-scoring-without-complementary-referential.js +++ b/api/tests/tooling/domain-builder/factory/build-complementary-certification-scoring-without-complementary-referential.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationScoringWithoutComplementaryReferential = require('../../../../lib/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential'); +import { ComplementaryCertificationScoringWithoutComplementaryReferential } from '../../../../lib/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential.js'; -module.exports = function buildComplementaryCertificationScoringWithoutComplementaryReferential({ +const buildComplementaryCertificationScoringWithoutComplementaryReferential = function ({ complementaryCertificationCourseId = 99, certificationCourseId = 42, reproducibilityRate = 50, @@ -19,3 +19,5 @@ module.exports = function buildComplementaryCertificationScoringWithoutComplemen minimumReproducibilityRate, }); }; + +export { buildComplementaryCertificationScoringWithoutComplementaryReferential }; diff --git a/api/tests/tooling/domain-builder/factory/build-complementary-certification.js b/api/tests/tooling/domain-builder/factory/build-complementary-certification.js index b5759a5a199..86314a35858 100644 --- a/api/tests/tooling/domain-builder/factory/build-complementary-certification.js +++ b/api/tests/tooling/domain-builder/factory/build-complementary-certification.js @@ -1,6 +1,6 @@ -const ComplementaryCertification = require('../../../../lib/domain/models/ComplementaryCertification'); +import { ComplementaryCertification } from '../../../../lib/domain/models/ComplementaryCertification.js'; -module.exports = function buildComplementaryCertification({ +const buildComplementaryCertification = function ({ id = 1, label = 'Complementary certification name', key = 'COMPLEMENTARY_CERTIFICATION_KEY', @@ -11,3 +11,5 @@ module.exports = function buildComplementaryCertification({ key, }); }; + +export { buildComplementaryCertification }; diff --git a/api/tests/tooling/domain-builder/factory/build-country.js b/api/tests/tooling/domain-builder/factory/build-country.js index 8a1b8d77c90..18931c23963 100644 --- a/api/tests/tooling/domain-builder/factory/build-country.js +++ b/api/tests/tooling/domain-builder/factory/build-country.js @@ -1,10 +1,12 @@ -const { Country } = require('../../../../lib/domain/read-models/Country'); -const { normalizeAndSortChars } = require('../../../../lib/infrastructure/utils/string-utils'); +import { Country } from '../../../../lib/domain/read-models/Country.js'; +import { normalizeAndSortChars } from '../../../../lib/infrastructure/utils/string-utils.js'; -module.exports = function buildCountry({ code = '99345', name = 'TOGO', matcher = normalizeAndSortChars(name) } = {}) { +const buildCountry = function ({ code = '99345', name = 'TOGO', matcher = normalizeAndSortChars(name) } = {}) { return new Country({ code, name, matcher, }); }; + +export { buildCountry }; diff --git a/api/tests/tooling/domain-builder/factory/build-course.js b/api/tests/tooling/domain-builder/factory/build-course.js index 0885b1c0d6e..9bbf62db6e7 100644 --- a/api/tests/tooling/domain-builder/factory/build-course.js +++ b/api/tests/tooling/domain-builder/factory/build-course.js @@ -1,6 +1,6 @@ -const Course = require('../../../../lib/domain/models/Course'); +import { Course } from '../../../../lib/domain/models/Course.js'; -module.exports = function buildCourse({ +const buildCourse = function ({ id = 'recCOUR123', description = 'description', imageUrl = 'imageURL', @@ -25,3 +25,5 @@ module.exports = function buildCourse({ tubes, }); }; + +export { buildCourse }; diff --git a/api/tests/tooling/domain-builder/factory/build-cpf-certification-result.js b/api/tests/tooling/domain-builder/factory/build-cpf-certification-result.js index 6396eb53c25..41188b675b6 100644 --- a/api/tests/tooling/domain-builder/factory/build-cpf-certification-result.js +++ b/api/tests/tooling/domain-builder/factory/build-cpf-certification-result.js @@ -1,6 +1,6 @@ -const CpfCertificationResult = require('../../../../lib/domain/read-models/CpfCertificationResult'); +import { CpfCertificationResult } from '../../../../lib/domain/read-models/CpfCertificationResult.js'; -module.exports = function buildCpfCertificationResult({ +const buildCpfCertificationResult = function ({ id = 1234, firstName = 'John', lastName = 'Doe', @@ -32,3 +32,5 @@ module.exports = function buildCpfCertificationResult({ competenceMarks, }); }; + +export { buildCpfCertificationResult }; diff --git a/api/tests/tooling/domain-builder/factory/build-data-protection-officer.js b/api/tests/tooling/domain-builder/factory/build-data-protection-officer.js index 1845676dfab..9a5b6cd8f09 100644 --- a/api/tests/tooling/domain-builder/factory/build-data-protection-officer.js +++ b/api/tests/tooling/domain-builder/factory/build-data-protection-officer.js @@ -1,4 +1,4 @@ -const DataProtectionOfficer = require('../../../../lib/domain/models/DataProtectionOfficer'); +import { DataProtectionOfficer } from '../../../../lib/domain/models/DataProtectionOfficer.js'; function _buildDataProtectionOfficer({ id = 10001, @@ -62,7 +62,4 @@ function buildDataProtectionOfficerWithOrganizationId({ }); } -module.exports = { - withCertificationCenterId: buildDataProtectionOfficerWithCertificationCenterId, - withOrganizationId: buildDataProtectionOfficerWithOrganizationId, -}; +export { buildDataProtectionOfficerWithCertificationCenterId, buildDataProtectionOfficerWithOrganizationId }; diff --git a/api/tests/tooling/domain-builder/factory/build-finalized-session.js b/api/tests/tooling/domain-builder/factory/build-finalized-session.js index b9341c719f2..dc3ba4e1a06 100644 --- a/api/tests/tooling/domain-builder/factory/build-finalized-session.js +++ b/api/tests/tooling/domain-builder/factory/build-finalized-session.js @@ -1,6 +1,6 @@ -const FinalizedSession = require('../../../../lib/domain/models/FinalizedSession'); +import { FinalizedSession } from '../../../../lib/domain/models/FinalizedSession.js'; -module.exports = function buildFinalizedSession({ +const buildFinalizedSession = function ({ sessionId = 123, certificationCenterName = 'Centre de certif pix', sessionDate = '2020-12-01', @@ -21,3 +21,5 @@ module.exports = function buildFinalizedSession({ assignedCertificationOfficerName, }); }; + +export { buildFinalizedSession }; diff --git a/api/tests/tooling/domain-builder/factory/build-framework.js b/api/tests/tooling/domain-builder/factory/build-framework.js index 51c96262d5a..b865bc2c14a 100644 --- a/api/tests/tooling/domain-builder/factory/build-framework.js +++ b/api/tests/tooling/domain-builder/factory/build-framework.js @@ -1,7 +1,7 @@ -const buildArea = require('./build-area'); -const Framework = require('../../../../lib/domain/models/Framework'); +import { buildArea } from './build-area.js'; +import { Framework } from '../../../../lib/domain/models/Framework.js'; -module.exports = function buildFramework({ id = 'recFramework123', name = 'Mon super référentiel', areas } = {}) { +const buildFramework = function ({ id = 'recFramework123', name = 'Mon super référentiel', areas } = {}) { areas = areas || [buildArea({ frameworkId: id })]; const framework = new Framework({ id, @@ -14,3 +14,5 @@ module.exports = function buildFramework({ id = 'recFramework123', name = 'Mon s }); return framework; }; + +export { buildFramework }; diff --git a/api/tests/tooling/domain-builder/factory/build-hint.js b/api/tests/tooling/domain-builder/factory/build-hint.js index b39ef4316ee..832771f6e62 100644 --- a/api/tests/tooling/domain-builder/factory/build-hint.js +++ b/api/tests/tooling/domain-builder/factory/build-hint.js @@ -1,8 +1,10 @@ -const Hint = require('../../../../lib/domain/models/Hint'); +import { Hint } from '../../../../lib/domain/models/Hint.js'; -module.exports = function buildHint({ skillName = '@web2', value = 'Pense à regarder les indices' } = {}) { +const buildHint = function ({ skillName = '@web2', value = 'Pense à regarder les indices' } = {}) { return new Hint({ skillName, value, }); }; + +export { buildHint }; diff --git a/api/tests/tooling/domain-builder/factory/build-jury-certification-summary.js b/api/tests/tooling/domain-builder/factory/build-jury-certification-summary.js index 8a3c0e3e21d..f4ff166f8c9 100644 --- a/api/tests/tooling/domain-builder/factory/build-jury-certification-summary.js +++ b/api/tests/tooling/domain-builder/factory/build-jury-certification-summary.js @@ -1,5 +1,5 @@ -const JuryCertificationSummary = require('../../../../lib/domain/read-models/JuryCertificationSummary'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); +import { JuryCertificationSummary } from '../../../../lib/domain/read-models/JuryCertificationSummary.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; const buildJuryCertificationSummary = function ({ id = 123, @@ -35,4 +35,4 @@ const buildJuryCertificationSummary = function ({ }); }; -module.exports = buildJuryCertificationSummary; +export { buildJuryCertificationSummary }; diff --git a/api/tests/tooling/domain-builder/factory/build-jury-certification.js b/api/tests/tooling/domain-builder/factory/build-jury-certification.js index ce1906c3926..335a0766c31 100644 --- a/api/tests/tooling/domain-builder/factory/build-jury-certification.js +++ b/api/tests/tooling/domain-builder/factory/build-jury-certification.js @@ -1,6 +1,6 @@ -const JuryCertification = require('../../../../lib/domain/models/JuryCertification'); -const buildCertificationIssueReport = require('./build-certification-issue-report'); -const buildCompetenceMark = require('./build-competence-mark'); +import { JuryCertification } from '../../../../lib/domain/models/JuryCertification.js'; +import { buildCertificationIssueReport } from './build-certification-issue-report.js'; +import { buildCompetenceMark } from './build-competence-mark.js'; const buildJuryCertification = function ({ certificationCourseId = 123, @@ -60,4 +60,4 @@ const buildJuryCertification = function ({ }); }; -module.exports = buildJuryCertification; +export { buildJuryCertification }; diff --git a/api/tests/tooling/domain-builder/factory/build-jury-session.js b/api/tests/tooling/domain-builder/factory/build-jury-session.js index 0fc877b5b6d..dc20c194c24 100644 --- a/api/tests/tooling/domain-builder/factory/build-jury-session.js +++ b/api/tests/tooling/domain-builder/factory/build-jury-session.js @@ -1,6 +1,6 @@ -const JurySession = require('../../../../lib/domain/models/JurySession'); -const domainBuilder = require('../domain-builder'); -const _ = require('lodash'); +import { JurySession } from '../../../../lib/domain/models/JurySession.js'; +import { domainBuilder } from '../domain-builder.js'; +import _ from 'lodash'; const buildJurySession = function ({ id = 123, @@ -60,4 +60,4 @@ const buildJurySession = function ({ }); }; -module.exports = buildJurySession; +export { buildJurySession }; diff --git a/api/tests/tooling/domain-builder/factory/build-knowledge-element.js b/api/tests/tooling/domain-builder/factory/build-knowledge-element.js index 9e0e508550a..fb626ba6c0f 100644 --- a/api/tests/tooling/domain-builder/factory/build-knowledge-element.js +++ b/api/tests/tooling/domain-builder/factory/build-knowledge-element.js @@ -1,4 +1,4 @@ -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; const buildKnowledgeElement = function ({ id = 123, @@ -98,4 +98,4 @@ buildKnowledgeElement.inferredValidated = function ({ }); }; -module.exports = buildKnowledgeElement; +export { buildKnowledgeElement }; diff --git a/api/tests/tooling/domain-builder/factory/build-learning-content.js b/api/tests/tooling/domain-builder/factory/build-learning-content.js index a4c7b319e01..ff40b7ccbb9 100644 --- a/api/tests/tooling/domain-builder/factory/build-learning-content.js +++ b/api/tests/tooling/domain-builder/factory/build-learning-content.js @@ -1,10 +1,10 @@ -const LearningContent = require('../../../../lib/domain/models/LearningContent'); -const buildSkill = require('./build-skill'); -const buildTube = require('./build-tube'); -const buildThematic = require('./build-thematic'); -const buildCompetence = require('./build-competence'); -const buildArea = require('./build-area'); -const buildFramework = require('./build-framework'); +import { LearningContent } from '../../../../lib/domain/models/LearningContent.js'; +import { buildSkill } from './build-skill.js'; +import { buildTube } from './build-tube.js'; +import { buildThematic } from './build-thematic.js'; +import { buildCompetence } from './build-competence.js'; +import { buildArea } from './build-area.js'; +import { buildFramework } from './build-framework.js'; function buildLearningContent(frameworks) { frameworks = frameworks || [buildFramework({ id: 'frameworkId', name: 'someFramework' })]; @@ -24,4 +24,4 @@ buildLearningContent.withSimpleContent = () => { return buildLearningContent([framework]); }; -module.exports = buildLearningContent; +export { buildLearningContent }; diff --git a/api/tests/tooling/domain-builder/factory/build-membership.js b/api/tests/tooling/domain-builder/factory/build-membership.js index ab804afa12f..5ac4730d221 100644 --- a/api/tests/tooling/domain-builder/factory/build-membership.js +++ b/api/tests/tooling/domain-builder/factory/build-membership.js @@ -1,6 +1,6 @@ -const Membership = require('../../../../lib/domain/models/Membership'); -const Organization = require('../../../../lib/domain/models/Organization'); -const User = require('../../../../lib/domain/models/User'); +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { User } from '../../../../lib/domain/models/User.js'; /* * /!\ We can not use standard entity builders because of bidirectional relationships (a.k.a. cyclic dependencies) @@ -25,7 +25,7 @@ function _buildOrganization() { }); } -module.exports = function buildMembership({ +const buildMembership = function ({ id = 123, organization = _buildOrganization(), organizationRole = Membership.roles.MEMBER, @@ -37,3 +37,5 @@ module.exports = function buildMembership({ return membership; }; + +export { buildMembership }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization-for-admin.js b/api/tests/tooling/domain-builder/factory/build-organization-for-admin.js index a552ce52570..f567b715aee 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization-for-admin.js +++ b/api/tests/tooling/domain-builder/factory/build-organization-for-admin.js @@ -1,4 +1,4 @@ -const OrganizationForAdmin = require('../../../../lib/domain/models/organizations-administration/Organization'); +import { OrganizationForAdmin } from '../../../../lib/domain/models/organizations-administration/Organization.js'; function buildOrganizationForAdmin({ id = 123, @@ -54,4 +54,4 @@ function buildOrganizationForAdmin({ }); } -module.exports = buildOrganizationForAdmin; +export { buildOrganizationForAdmin }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization-invitation.js b/api/tests/tooling/domain-builder/factory/build-organization-invitation.js index 2097153d784..ecc39a16db4 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization-invitation.js +++ b/api/tests/tooling/domain-builder/factory/build-organization-invitation.js @@ -1,6 +1,6 @@ -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; -module.exports = function buildOrganizationInvitation({ +const buildOrganizationInvitation = function ({ id = 123, organizationId = 456, organizationName = 'orgaName', @@ -23,3 +23,5 @@ module.exports = function buildOrganizationInvitation({ updatedAt, }); }; + +export { buildOrganizationInvitation }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization-learner-for-admin.js b/api/tests/tooling/domain-builder/factory/build-organization-learner-for-admin.js index 19af3822fd6..e8fe0ddf6aa 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization-learner-for-admin.js +++ b/api/tests/tooling/domain-builder/factory/build-organization-learner-for-admin.js @@ -1,6 +1,6 @@ -const OrganizationLearnerForAdmin = require('../../../../lib/domain/read-models/OrganizationLearnerForAdmin'); +import { OrganizationLearnerForAdmin } from '../../../../lib/domain/read-models/OrganizationLearnerForAdmin.js'; -module.exports = function buildOrganizationLearnerForAdmin({ +const buildOrganizationLearnerForAdmin = function ({ id = 123, firstName = 'Super', lastName = 'Yvette', @@ -29,3 +29,5 @@ module.exports = function buildOrganizationLearnerForAdmin({ organizationIsManagingStudents, }); }; + +export { buildOrganizationLearnerForAdmin }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization-learner-participation.js b/api/tests/tooling/domain-builder/factory/build-organization-learner-participation.js index fe53169f8a0..83af9cd6788 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization-learner-participation.js +++ b/api/tests/tooling/domain-builder/factory/build-organization-learner-participation.js @@ -1,8 +1,8 @@ -const OrganizationLearnerParticipation = require('../../../../lib/domain/read-models/OrganizationLearnerParticipation'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { OrganizationLearnerParticipation } from '../../../../lib/domain/read-models/OrganizationLearnerParticipation.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; -module.exports = function buildOrganizationLearnerParticipation({ +const buildOrganizationLearnerParticipation = function ({ id = '123', campaignType = CampaignTypes.ASSESSMENT, campaignName = 'Ma campagne', @@ -19,3 +19,5 @@ module.exports = function buildOrganizationLearnerParticipation({ status, }); }; + +export { buildOrganizationLearnerParticipation }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization-learner.js b/api/tests/tooling/domain-builder/factory/build-organization-learner.js index ec194e2cd0d..95102f57b5c 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization-learner.js +++ b/api/tests/tooling/domain-builder/factory/build-organization-learner.js @@ -1,5 +1,5 @@ -const OrganizationLearner = require('../../../../lib/domain/models/OrganizationLearner'); -const buildOrganization = require('./build-organization'); +import { OrganizationLearner } from '../../../../lib/domain/models/OrganizationLearner.js'; +import { buildOrganization } from './build-organization.js'; function buildOrganizationLearner({ id = 123, @@ -47,4 +47,4 @@ function buildOrganizationLearner({ }); } -module.exports = buildOrganizationLearner; +export { buildOrganizationLearner }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization-places-lot-management.js b/api/tests/tooling/domain-builder/factory/build-organization-places-lot-management.js index 7d41f49292a..6cf0a7824e8 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization-places-lot-management.js +++ b/api/tests/tooling/domain-builder/factory/build-organization-places-lot-management.js @@ -1,4 +1,4 @@ -const OrganizationPlacesLotManagement = require('../../../../lib/domain/read-models/OrganizationPlacesLotManagement'); +import { OrganizationPlacesLotManagement } from '../../../../lib/domain/read-models/OrganizationPlacesLotManagement.js'; function buildOrganizationPlacesLotManagement({ id, @@ -26,4 +26,4 @@ function buildOrganizationPlacesLotManagement({ }); } -module.exports = buildOrganizationPlacesLotManagement; +export { buildOrganizationPlacesLotManagement }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization-places-lot.js b/api/tests/tooling/domain-builder/factory/build-organization-places-lot.js index 84b38fa33d5..f5d52f6e7a9 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization-places-lot.js +++ b/api/tests/tooling/domain-builder/factory/build-organization-places-lot.js @@ -1,4 +1,4 @@ -const OrganizationPlacesLot = require('../../../../lib/domain/models/OrganizationPlacesLot'); +import { OrganizationPlacesLot } from '../../../../lib/domain/models/OrganizationPlacesLot.js'; function buildOrganizationPlacesLot({ id = 1, @@ -22,4 +22,4 @@ function buildOrganizationPlacesLot({ }); } -module.exports = buildOrganizationPlacesLot; +export { buildOrganizationPlacesLot }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization-tag.js b/api/tests/tooling/domain-builder/factory/build-organization-tag.js index a6a296bf4a9..3bb2360e94d 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization-tag.js +++ b/api/tests/tooling/domain-builder/factory/build-organization-tag.js @@ -1,5 +1,7 @@ -const OrganizationTag = require('../../../../lib/domain/models/OrganizationTag'); +import { OrganizationTag } from '../../../../lib/domain/models/OrganizationTag.js'; -module.exports = function buildOrganizationTag({ id = 123, organizationId = 456, tagId = 789 } = {}) { +const buildOrganizationTag = function ({ id = 123, organizationId = 456, tagId = 789 } = {}) { return new OrganizationTag({ id, organizationId, tagId }); }; + +export { buildOrganizationTag }; diff --git a/api/tests/tooling/domain-builder/factory/build-organization.js b/api/tests/tooling/domain-builder/factory/build-organization.js index 360a6b05fe2..052dd737d4c 100644 --- a/api/tests/tooling/domain-builder/factory/build-organization.js +++ b/api/tests/tooling/domain-builder/factory/build-organization.js @@ -1,4 +1,4 @@ -const Organization = require('../../../../lib/domain/models/Organization'); +import { Organization } from '../../../../lib/domain/models/Organization.js'; function buildOrganization({ id = 123, @@ -44,4 +44,4 @@ function buildOrganization({ }); } -module.exports = buildOrganization; +export { buildOrganization }; diff --git a/api/tests/tooling/domain-builder/factory/build-organizations-to-attach-to-target-profile.js b/api/tests/tooling/domain-builder/factory/build-organizations-to-attach-to-target-profile.js index 99a73be2c3f..75dcc84bedf 100644 --- a/api/tests/tooling/domain-builder/factory/build-organizations-to-attach-to-target-profile.js +++ b/api/tests/tooling/domain-builder/factory/build-organizations-to-attach-to-target-profile.js @@ -1,7 +1,9 @@ -const OrganizationsToAttachToTargetProfile = require('../../../../lib/domain/models/OrganizationsToAttachToTargetProfile'); +import { OrganizationsToAttachToTargetProfile } from '../../../../lib/domain/models/OrganizationsToAttachToTargetProfile.js'; -module.exports = function buildOrganizationsToAttachToTargetProfile({ id = 123 } = {}) { +const buildOrganizationsToAttachToTargetProfile = function ({ id = 123 } = {}) { return new OrganizationsToAttachToTargetProfile({ id, }); }; + +export { buildOrganizationsToAttachToTargetProfile }; diff --git a/api/tests/tooling/domain-builder/factory/build-participation-for-campaign-management.js b/api/tests/tooling/domain-builder/factory/build-participation-for-campaign-management.js index 3df8a036bf7..4a6f221eddc 100644 --- a/api/tests/tooling/domain-builder/factory/build-participation-for-campaign-management.js +++ b/api/tests/tooling/domain-builder/factory/build-participation-for-campaign-management.js @@ -1,7 +1,7 @@ -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const ParticipationForCampaignManagement = require('../../../../lib/domain/models/ParticipationForCampaignManagement'); +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { ParticipationForCampaignManagement } from '../../../../lib/domain/models/ParticipationForCampaignManagement.js'; -module.exports = function buildParticipationForCampaignManagement({ +const buildParticipationForCampaignManagement = function ({ id = 1, lastName = 'Un nom', firstName = 'Un prénom', @@ -34,3 +34,5 @@ module.exports = function buildParticipationForCampaignManagement({ deletedByLastName, }); }; + +export { buildParticipationForCampaignManagement }; diff --git a/api/tests/tooling/domain-builder/factory/build-pix-plus-certification-scoring.js b/api/tests/tooling/domain-builder/factory/build-pix-plus-certification-scoring.js index 99241523757..60f5612afa7 100644 --- a/api/tests/tooling/domain-builder/factory/build-pix-plus-certification-scoring.js +++ b/api/tests/tooling/domain-builder/factory/build-pix-plus-certification-scoring.js @@ -1,7 +1,7 @@ -const ComplementaryCertificationScoringWithComplementaryReferential = require('../../../../lib/domain/models/ComplementaryCertificationScoringWithComplementaryReferential'); -const buildReproducibilityRate = require('./build-reproducibility-rate'); +import { ComplementaryCertificationScoringWithComplementaryReferential } from '../../../../lib/domain/models/ComplementaryCertificationScoringWithComplementaryReferential.js'; +import { buildReproducibilityRate } from './build-reproducibility-rate.js'; -module.exports = function buildComplementaryCertificationScoringWithComplementaryReferential({ +const buildComplementaryCertificationScoringWithComplementaryReferential = function ({ complementaryCertificationCourseId = 999, complementaryCertificationBadgeKey = 'PIX_PLUS_TEST', reproducibilityRate = buildReproducibilityRate({ value: 100 }), @@ -16,3 +16,5 @@ module.exports = function buildComplementaryCertificationScoringWithComplementar minimumReproducibilityRate, }); }; + +export { buildComplementaryCertificationScoringWithComplementaryReferential }; diff --git a/api/tests/tooling/domain-builder/factory/build-placement-profile.js b/api/tests/tooling/domain-builder/factory/build-placement-profile.js index 2581b2376bd..a2befae7d82 100644 --- a/api/tests/tooling/domain-builder/factory/build-placement-profile.js +++ b/api/tests/tooling/domain-builder/factory/build-placement-profile.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); -const PlacementProfile = require('../../../../lib/domain/models/PlacementProfile'); -const buildUserCompetence = require('./build-user-competence'); +import _ from 'lodash'; +import { PlacementProfile } from '../../../../lib/domain/models/PlacementProfile.js'; +import { buildUserCompetence } from './build-user-competence.js'; const buildPlacementProfile = function buildPlacementProfile({ profileDate = new Date('2020-01-01'), @@ -32,4 +32,4 @@ buildPlacementProfile.buildForCompetences = function buildForCompetences({ profi }); }; -module.exports = buildPlacementProfile; +export { buildPlacementProfile }; diff --git a/api/tests/tooling/domain-builder/factory/build-pole-emploi-sending.js b/api/tests/tooling/domain-builder/factory/build-pole-emploi-sending.js index 724f9de60ae..b651c3f5be6 100644 --- a/api/tests/tooling/domain-builder/factory/build-pole-emploi-sending.js +++ b/api/tests/tooling/domain-builder/factory/build-pole-emploi-sending.js @@ -1,6 +1,7 @@ -const buildCampaignParticipation = require('./build-campaign-participation'); -const isUndefined = require('lodash/isUndefined'); -const PoleEmploiSending = require('../../../../lib/domain/models/PoleEmploiSending'); +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import lodash from 'lodash'; +const { isUndefined } = lodash; +import { PoleEmploiSending } from '../../../../lib/domain/models/PoleEmploiSending.js'; const buildPoleEmploiSending = function ({ type = PoleEmploiSending.TYPES.CAMPAIGN_PARTICIPATION_SHARING, @@ -24,4 +25,4 @@ const buildPoleEmploiSending = function ({ }); }; -module.exports = buildPoleEmploiSending; +export { buildPoleEmploiSending }; diff --git a/api/tests/tooling/domain-builder/factory/build-prescriber.js b/api/tests/tooling/domain-builder/factory/build-prescriber.js index 65c5550176a..d785e81b8e1 100644 --- a/api/tests/tooling/domain-builder/factory/build-prescriber.js +++ b/api/tests/tooling/domain-builder/factory/build-prescriber.js @@ -1,8 +1,8 @@ -const Membership = require('../../../../lib/domain/models/Membership'); -const Organization = require('../../../../lib/domain/models/Organization'); -const User = require('../../../../lib/domain/models/User'); -const UserOrgaSettings = require('../../../../lib/domain/models/UserOrgaSettings'); -const Prescriber = require('../../../../lib/domain/read-models/Prescriber'); +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { UserOrgaSettings } from '../../../../lib/domain/models/UserOrgaSettings.js'; +import { Prescriber } from '../../../../lib/domain/read-models/Prescriber.js'; /* * /!\ We can not use standard entity builders because of bidirectional relationships (a.k.a. cyclic dependencies) @@ -44,7 +44,7 @@ function _buildUserOrgaSettings() { }); } -module.exports = function buildPrescriber({ +const buildPrescriber = function ({ id = 753, firstName = 'Jean', lastName = 'Forme', @@ -67,3 +67,5 @@ module.exports = function buildPrescriber({ enableMultipleSendingAssessment, }); }; + +export { buildPrescriber }; diff --git a/api/tests/tooling/domain-builder/factory/build-private-certificate-with-competence-tree.js b/api/tests/tooling/domain-builder/factory/build-private-certificate-with-competence-tree.js index 72ca2c59235..8c16b2930b0 100644 --- a/api/tests/tooling/domain-builder/factory/build-private-certificate-with-competence-tree.js +++ b/api/tests/tooling/domain-builder/factory/build-private-certificate-with-competence-tree.js @@ -1,8 +1,8 @@ -const PrivateCertificate = require('../../../../lib/domain/models/PrivateCertificate'); -const buildAssessmentResult = require('./build-assessment-result'); -const buildResultCompetenceTree = require('./build-result-competence-tree'); +import { PrivateCertificate } from '../../../../lib/domain/models/PrivateCertificate.js'; +import { buildAssessmentResult } from './build-assessment-result.js'; +import { buildResultCompetenceTree } from './build-result-competence-tree.js'; -module.exports = function buildPrivateCertificate({ +const buildPrivateCertificate = function ({ id = 1, assessmentResults = [buildAssessmentResult()], assessmentState = 'completed', @@ -60,3 +60,5 @@ module.exports = function buildPrivateCertificate({ return certificate; }; + +export { buildPrivateCertificate }; diff --git a/api/tests/tooling/domain-builder/factory/build-private-certificate.js b/api/tests/tooling/domain-builder/factory/build-private-certificate.js index 6b872dff909..dc78a33f750 100644 --- a/api/tests/tooling/domain-builder/factory/build-private-certificate.js +++ b/api/tests/tooling/domain-builder/factory/build-private-certificate.js @@ -1,4 +1,4 @@ -const PrivateCertificate = require('../../../../lib/domain/models/PrivateCertificate'); +import { PrivateCertificate } from '../../../../lib/domain/models/PrivateCertificate.js'; const buildPrivateCertificate = function ({ id = 1, @@ -235,4 +235,4 @@ buildPrivateCertificate.started = function ({ }); }; -module.exports = buildPrivateCertificate; +export { buildPrivateCertificate }; diff --git a/api/tests/tooling/domain-builder/factory/build-progression.js b/api/tests/tooling/domain-builder/factory/build-progression.js index 4c282b950f9..34584cd9604 100644 --- a/api/tests/tooling/domain-builder/factory/build-progression.js +++ b/api/tests/tooling/domain-builder/factory/build-progression.js @@ -1,8 +1,8 @@ -const buildSkillCollection = require('./build-skill-collection'); -const buildKnowledgeElement = require('./build-knowledge-element'); -const Progression = require('../../../../lib/domain/models/Progression'); +import { BuildSkillCollection as buildSkillCollection } from './build-skill-collection.js'; +import { buildKnowledgeElement } from './build-knowledge-element.js'; +import { Progression } from '../../../../lib/domain/models/Progression.js'; -module.exports = function buildProgression({ +const buildProgression = function ({ id = Progression.generateIdFromAssessmentId(1234), skillIds = buildSkillCollection().map((skill) => skill.id), knowledgeElements = [buildKnowledgeElement()], @@ -10,3 +10,5 @@ module.exports = function buildProgression({ } = {}) { return new Progression({ id, skillIds, knowledgeElements, isProfileCompleted }); }; + +export { buildProgression }; diff --git a/api/tests/tooling/domain-builder/factory/build-reproducibility-rate.js b/api/tests/tooling/domain-builder/factory/build-reproducibility-rate.js index 0357147fd0c..3a5a8dc9dda 100644 --- a/api/tests/tooling/domain-builder/factory/build-reproducibility-rate.js +++ b/api/tests/tooling/domain-builder/factory/build-reproducibility-rate.js @@ -1,5 +1,7 @@ -const { ReproducibilityRate } = require('../../../../lib/domain/models/ReproducibilityRate'); +import { ReproducibilityRate } from '../../../../lib/domain/models/ReproducibilityRate.js'; -module.exports = function buildReproducibilityRate({ value = 10 } = {}) { +const buildReproducibilityRate = function ({ value = 10 } = {}) { return new ReproducibilityRate(value); }; + +export { buildReproducibilityRate }; diff --git a/api/tests/tooling/domain-builder/factory/build-result-competence-tree.js b/api/tests/tooling/domain-builder/factory/build-result-competence-tree.js index fe27ed99019..d39570ed18a 100644 --- a/api/tests/tooling/domain-builder/factory/build-result-competence-tree.js +++ b/api/tests/tooling/domain-builder/factory/build-result-competence-tree.js @@ -1,8 +1,8 @@ -const ResultCompetenceTree = require('../../../../lib/domain/models/ResultCompetenceTree'); -const buildCompetenceTree = require('./build-competence-tree'); -const buildCompetenceMark = require('./build-competence-mark'); +import { ResultCompetenceTree } from '../../../../lib/domain/models/ResultCompetenceTree.js'; +import { buildCompetenceTree } from './build-competence-tree.js'; +import { buildCompetenceMark } from './build-competence-mark.js'; -module.exports = function buildResultCompetenceTree({ +const buildResultCompetenceTree = function ({ id = '1-1', competenceTree = buildCompetenceTree(), competenceMarks = [buildCompetenceMark()], @@ -14,3 +14,5 @@ module.exports = function buildResultCompetenceTree({ resultCompetenceTree.id = id; return resultCompetenceTree; }; + +export { buildResultCompetenceTree }; diff --git a/api/tests/tooling/domain-builder/factory/build-sco-certification-candidate.js b/api/tests/tooling/domain-builder/factory/build-sco-certification-candidate.js index ac88718bdae..30b3fda3001 100644 --- a/api/tests/tooling/domain-builder/factory/build-sco-certification-candidate.js +++ b/api/tests/tooling/domain-builder/factory/build-sco-certification-candidate.js @@ -1,6 +1,6 @@ -const SCOCertificationCandidate = require('../../../../lib/domain/models/SCOCertificationCandidate'); +import { SCOCertificationCandidate } from '../../../../lib/domain/models/SCOCertificationCandidate.js'; -module.exports = function buildSCOCertificationCandidate({ +const buildSCOCertificationCandidate = function ({ id = 123, firstName = 'Myriam', lastName = 'Meilleure', @@ -21,3 +21,5 @@ module.exports = function buildSCOCertificationCandidate({ organizationLearnerId, }); }; + +export { buildSCOCertificationCandidate }; diff --git a/api/tests/tooling/domain-builder/factory/build-session-for-supervising.js b/api/tests/tooling/domain-builder/factory/build-session-for-supervising.js index 86882f5c350..36a28484a00 100644 --- a/api/tests/tooling/domain-builder/factory/build-session-for-supervising.js +++ b/api/tests/tooling/domain-builder/factory/build-session-for-supervising.js @@ -1,6 +1,6 @@ -const SessionForSupervising = require('../../../../lib/domain/read-models/SessionForSupervising'); +import { SessionForSupervising } from '../../../../lib/domain/read-models/SessionForSupervising.js'; -module.exports = function buildSessionForSupervising({ +const buildSessionForSupervising = function ({ id = 123, certificationCenterName = 'Centre de certif pix', certificationCenterId = 565, @@ -23,3 +23,5 @@ module.exports = function buildSessionForSupervising({ certificationCandidates, }); }; + +export { buildSessionForSupervising }; diff --git a/api/tests/tooling/domain-builder/factory/build-session-for-supervisor-kit.js b/api/tests/tooling/domain-builder/factory/build-session-for-supervisor-kit.js index 3dcbecc69e7..41d9155d707 100644 --- a/api/tests/tooling/domain-builder/factory/build-session-for-supervisor-kit.js +++ b/api/tests/tooling/domain-builder/factory/build-session-for-supervisor-kit.js @@ -1,6 +1,6 @@ -const SessionForSupervisorKit = require('../../../../lib/domain/read-models/SessionForSupervisorKit'); +import { SessionForSupervisorKit } from '../../../../lib/domain/read-models/SessionForSupervisorKit.js'; -module.exports = function buildSessionForSupervisorKit({ +const buildSessionForSupervisorKit = function ({ id = 123, examiner = 'Sherlock Holmes', address = '22b Baker Street', @@ -21,3 +21,5 @@ module.exports = function buildSessionForSupervisorKit({ supervisorPassword, }); }; + +export { buildSessionForSupervisorKit }; diff --git a/api/tests/tooling/domain-builder/factory/build-session-jury-comment.js b/api/tests/tooling/domain-builder/factory/build-session-jury-comment.js index 28d4f059c6c..07d02426b23 100644 --- a/api/tests/tooling/domain-builder/factory/build-session-jury-comment.js +++ b/api/tests/tooling/domain-builder/factory/build-session-jury-comment.js @@ -1,4 +1,4 @@ -const SessionJuryComment = require('../../../../lib/domain/models/SessionJuryComment'); +import { SessionJuryComment } from '../../../../lib/domain/models/SessionJuryComment.js'; const buildSessionJuryComment = function ({ id = 123, @@ -14,4 +14,4 @@ const buildSessionJuryComment = function ({ }); }; -module.exports = buildSessionJuryComment; +export { buildSessionJuryComment }; diff --git a/api/tests/tooling/domain-builder/factory/build-session-summary.js b/api/tests/tooling/domain-builder/factory/build-session-summary.js index be48e494caf..50b846d7064 100644 --- a/api/tests/tooling/domain-builder/factory/build-session-summary.js +++ b/api/tests/tooling/domain-builder/factory/build-session-summary.js @@ -1,4 +1,4 @@ -const SessionSummary = require('../../../../lib/domain/read-models/SessionSummary'); +import { SessionSummary } from '../../../../lib/domain/read-models/SessionSummary.js'; const buildSessionSummary = function ({ id = 123, @@ -93,4 +93,4 @@ buildSessionSummary.processed = function ({ }); }; -module.exports = buildSessionSummary; +export { buildSessionSummary }; diff --git a/api/tests/tooling/domain-builder/factory/build-session.js b/api/tests/tooling/domain-builder/factory/build-session.js index 36de8e681c8..72be11792d8 100644 --- a/api/tests/tooling/domain-builder/factory/build-session.js +++ b/api/tests/tooling/domain-builder/factory/build-session.js @@ -1,4 +1,4 @@ -const Session = require('../../../../lib/domain/models/Session'); +import { Session } from '../../../../lib/domain/models/Session.js'; const buildSession = function ({ id = 123, @@ -184,4 +184,4 @@ buildSession.processed = function ({ }); }; -module.exports = buildSession; +export { buildSession }; diff --git a/api/tests/tooling/domain-builder/factory/build-shareable-certificate.js b/api/tests/tooling/domain-builder/factory/build-shareable-certificate.js index 84b345f360c..440e5ceeefc 100644 --- a/api/tests/tooling/domain-builder/factory/build-shareable-certificate.js +++ b/api/tests/tooling/domain-builder/factory/build-shareable-certificate.js @@ -1,6 +1,6 @@ -const ShareableCertificate = require('../../../../lib/domain/models/ShareableCertificate'); +import { ShareableCertificate } from '../../../../lib/domain/models/ShareableCertificate.js'; -module.exports = function buildShareableCertificate({ +const buildShareableCertificate = function ({ id = 1, firstName = 'Jean', lastName = 'Bon', @@ -33,3 +33,5 @@ module.exports = function buildShareableCertificate({ certifiedBadgeImages, }); }; + +export { buildShareableCertificate }; diff --git a/api/tests/tooling/domain-builder/factory/build-skill-collection.js b/api/tests/tooling/domain-builder/factory/build-skill-collection.js index 484a6e5f16d..6ff9bf26da1 100644 --- a/api/tests/tooling/domain-builder/factory/build-skill-collection.js +++ b/api/tests/tooling/domain-builder/factory/build-skill-collection.js @@ -1,10 +1,6 @@ -const buildSkill = require('./build-skill'); +import { buildSkill } from './build-skill.js'; -module.exports = function BuildSkillCollection({ - name = buildSkill.buildRandomTubeName(), - minLevel = 3, - maxLevel = 5, -} = {}) { +const BuildSkillCollection = function ({ name = buildSkill.buildRandomTubeName(), minLevel = 3, maxLevel = 5 } = {}) { const collection = []; for (let i = minLevel; i <= maxLevel; ++i) { @@ -13,3 +9,5 @@ module.exports = function BuildSkillCollection({ return collection; }; + +export { BuildSkillCollection }; diff --git a/api/tests/tooling/domain-builder/factory/build-skill-learning-content-data-object.js b/api/tests/tooling/domain-builder/factory/build-skill-learning-content-data-object.js index 37e46df3af6..325593a40c9 100644 --- a/api/tests/tooling/domain-builder/factory/build-skill-learning-content-data-object.js +++ b/api/tests/tooling/domain-builder/factory/build-skill-learning-content-data-object.js @@ -9,7 +9,7 @@ const DEFAULT_ID = 'recSK0X22abcdefgh', DEFAULT_VERSION = 1, DEFAULT_LEVEL = 1; -module.exports = function ({ +const buildSkillLearningContentDataObject = function ({ id = DEFAULT_ID, name = DEFAULT_NAME, hint = DEFAULT_HINT, @@ -34,3 +34,5 @@ module.exports = function ({ level, }; }; + +export { buildSkillLearningContentDataObject }; diff --git a/api/tests/tooling/domain-builder/factory/build-skill-set.js b/api/tests/tooling/domain-builder/factory/build-skill-set.js index b32b9caf30b..63bafa1fdea 100644 --- a/api/tests/tooling/domain-builder/factory/build-skill-set.js +++ b/api/tests/tooling/domain-builder/factory/build-skill-set.js @@ -1,6 +1,6 @@ -const SkillSet = require('../../../../lib/domain/models/SkillSet'); +import { SkillSet } from '../../../../lib/domain/models/SkillSet.js'; -module.exports = function buildSkillSet({ id = 1, badgeId = 64, name = 'name', skillIds = ['recABC', 'recDEF'] } = {}) { +const buildSkillSet = function ({ id = 1, badgeId = 64, name = 'name', skillIds = ['recABC', 'recDEF'] } = {}) { return new SkillSet({ id, badgeId, @@ -8,3 +8,5 @@ module.exports = function buildSkillSet({ id = 1, badgeId = 64, name = 'name', s skillIds, }); }; + +export { buildSkillSet }; diff --git a/api/tests/tooling/domain-builder/factory/build-skill.js b/api/tests/tooling/domain-builder/factory/build-skill.js index 100c757d6f8..5d6c70fa8cf 100644 --- a/api/tests/tooling/domain-builder/factory/build-skill.js +++ b/api/tests/tooling/domain-builder/factory/build-skill.js @@ -1,4 +1,4 @@ -const Skill = require('../../../../lib/domain/models/Skill'); +import { Skill } from '../../../../lib/domain/models/Skill.js'; const buildSkill = function buildSkill({ id = 'recSK123', @@ -25,7 +25,7 @@ const buildSkill = function buildSkill({ }; buildSkill.buildRandomTubeName = buildRandomTubeName; -module.exports = buildSkill; +export { buildSkill }; /** * A tube name starts by a @ and contains between 3 and 15 other letters diff --git a/api/tests/tooling/domain-builder/factory/build-solution.js b/api/tests/tooling/domain-builder/factory/build-solution.js index e7b9a22c2b1..bb7246829f3 100644 --- a/api/tests/tooling/domain-builder/factory/build-solution.js +++ b/api/tests/tooling/domain-builder/factory/build-solution.js @@ -1,6 +1,6 @@ -const Solution = require('../../../../lib/domain/models/Solution'); +import { Solution } from '../../../../lib/domain/models/Solution.js'; -module.exports = function buildSolution({ +const buildSolution = function ({ id = 'recCHAL123', type = 'QCM', value = '1', @@ -19,3 +19,5 @@ module.exports = function buildSolution({ scoring, }); }; + +export { buildSolution }; diff --git a/api/tests/tooling/domain-builder/factory/build-stage.js b/api/tests/tooling/domain-builder/factory/build-stage.js index 2c854405b4b..41d94663569 100644 --- a/api/tests/tooling/domain-builder/factory/build-stage.js +++ b/api/tests/tooling/domain-builder/factory/build-stage.js @@ -1,6 +1,6 @@ -const Stage = require('../../../../lib/domain/models/Stage'); +import { Stage } from '../../../../lib/domain/models/Stage.js'; -module.exports = function buildStage({ +const buildStage = function ({ id = 123, title = 'Courage', message = 'Insister', @@ -21,3 +21,5 @@ module.exports = function buildStage({ targetProfileId, }); }; + +export { buildStage }; diff --git a/api/tests/tooling/domain-builder/factory/build-sup-organization-learner.js b/api/tests/tooling/domain-builder/factory/build-sup-organization-learner.js index 5cc29771cf7..2660fc64f4e 100644 --- a/api/tests/tooling/domain-builder/factory/build-sup-organization-learner.js +++ b/api/tests/tooling/domain-builder/factory/build-sup-organization-learner.js @@ -1,5 +1,5 @@ -const SupOrganizationLearner = require('../../../../lib/domain/models/SupOrganizationLearner'); -const buildOrganization = require('./build-organization'); +import { SupOrganizationLearner } from '../../../../lib/domain/models/SupOrganizationLearner.js'; +import { buildOrganization } from './build-organization.js'; function buildSupOrganizationLearner({ organization = buildOrganization({ isManagingStudents: true }), @@ -35,4 +35,4 @@ function buildSupOrganizationLearner({ }); } -module.exports = buildSupOrganizationLearner; +export { buildSupOrganizationLearner }; diff --git a/api/tests/tooling/domain-builder/factory/build-tag.js b/api/tests/tooling/domain-builder/factory/build-tag.js index 825a89c867d..a6db7652615 100644 --- a/api/tests/tooling/domain-builder/factory/build-tag.js +++ b/api/tests/tooling/domain-builder/factory/build-tag.js @@ -1,4 +1,4 @@ -const Tag = require('../../../../lib/domain/models/Tag'); +import { Tag } from '../../../../lib/domain/models/Tag.js'; function buildTag({ id = 123, name = 'Type' } = {}) { return new Tag({ @@ -7,4 +7,4 @@ function buildTag({ id = 123, name = 'Type' } = {}) { }); } -module.exports = buildTag; +export { buildTag }; diff --git a/api/tests/tooling/domain-builder/factory/build-target-profile-for-admin.js b/api/tests/tooling/domain-builder/factory/build-target-profile-for-admin.js index 474071b4e9d..2132a50074a 100644 --- a/api/tests/tooling/domain-builder/factory/build-target-profile-for-admin.js +++ b/api/tests/tooling/domain-builder/factory/build-target-profile-for-admin.js @@ -1,11 +1,11 @@ -const buildArea = require('./build-area'); -const buildCompetence = require('./build-competence'); -const buildThematic = require('./build-thematic'); -const buildTube = require('./build-tube'); -const buildStageCollection = require('./target-profile-management/build-stage-collection'); -const TargetProfileForAdmin = require('../../../../lib/domain/models/TargetProfileForAdmin'); +import { buildArea } from './build-area.js'; +import { buildCompetence } from './build-competence.js'; +import { buildThematic } from './build-thematic.js'; +import { buildTube } from './build-tube.js'; +import { buildStageCollection } from './target-profile-management/build-stage-collection.js'; +import { TargetProfileForAdmin } from '../../../../lib/domain/models/TargetProfileForAdmin.js'; -module.exports = function buildTargetProfileForAdmin({ +const buildTargetProfileForAdmin = function ({ id = 123, name = 'Profil cible super cool', outdated = false, @@ -46,3 +46,5 @@ module.exports = function buildTargetProfileForAdmin({ tubes: tubesWithLevelThematicMobileAndTablet, }); }; + +export { buildTargetProfileForAdmin }; diff --git a/api/tests/tooling/domain-builder/factory/build-target-profile-for-creation.js b/api/tests/tooling/domain-builder/factory/build-target-profile-for-creation.js index 381c84230a5..dbefb951d9a 100644 --- a/api/tests/tooling/domain-builder/factory/build-target-profile-for-creation.js +++ b/api/tests/tooling/domain-builder/factory/build-target-profile-for-creation.js @@ -1,6 +1,6 @@ -const TargetProfileForCreation = require('../../../../lib/domain/models/TargetProfileForCreation'); +import { TargetProfileForCreation } from '../../../../lib/domain/models/TargetProfileForCreation.js'; -module.exports = function buildTargetProfileForCreation({ +const buildTargetProfileForCreation = function ({ name = 'Profil cible super cool', category = 'some_category', description = 'description', @@ -21,3 +21,5 @@ module.exports = function buildTargetProfileForCreation({ tubes, }); }; + +export { buildTargetProfileForCreation }; diff --git a/api/tests/tooling/domain-builder/factory/build-target-profile-summary-for-admin.js b/api/tests/tooling/domain-builder/factory/build-target-profile-summary-for-admin.js index a91534b1139..74e4b457e4c 100644 --- a/api/tests/tooling/domain-builder/factory/build-target-profile-summary-for-admin.js +++ b/api/tests/tooling/domain-builder/factory/build-target-profile-summary-for-admin.js @@ -1,6 +1,6 @@ -const TargetProfileSummaryForAdmin = require('../../../../lib/domain/models/TargetProfileSummaryForAdmin'); +import { TargetProfileSummaryForAdmin } from '../../../../lib/domain/models/TargetProfileSummaryForAdmin.js'; -module.exports = function buildTargetProfileSummaryForAdmin({ +const buildTargetProfileSummaryForAdmin = function ({ id = 123, name = 'Profil cible super cool', outdated = false, @@ -13,3 +13,5 @@ module.exports = function buildTargetProfileSummaryForAdmin({ createdAt, }); }; + +export { buildTargetProfileSummaryForAdmin }; diff --git a/api/tests/tooling/domain-builder/factory/build-target-profile.js b/api/tests/tooling/domain-builder/factory/build-target-profile.js index 53a93263bd9..7487ddca395 100644 --- a/api/tests/tooling/domain-builder/factory/build-target-profile.js +++ b/api/tests/tooling/domain-builder/factory/build-target-profile.js @@ -1,6 +1,6 @@ -const TargetProfile = require('../../../../lib/domain/models/TargetProfile'); +import { TargetProfile } from '../../../../lib/domain/models/TargetProfile.js'; -module.exports = function buildTargetProfile({ +const buildTargetProfile = function ({ id = 123, name = 'Profil cible super cool', imageUrl = 'ImageURL', @@ -23,3 +23,5 @@ module.exports = function buildTargetProfile({ badges, }); }; + +export { buildTargetProfile }; diff --git a/api/tests/tooling/domain-builder/factory/build-thematic.js b/api/tests/tooling/domain-builder/factory/build-thematic.js index e44258aa05c..9656fc2437e 100644 --- a/api/tests/tooling/domain-builder/factory/build-thematic.js +++ b/api/tests/tooling/domain-builder/factory/build-thematic.js @@ -1,4 +1,4 @@ -const Thematic = require('../../../../lib/domain/models/Thematic'); +import { Thematic } from '../../../../lib/domain/models/Thematic.js'; const buildThematic = function buildThematic({ id = 'recThem1', @@ -16,4 +16,4 @@ const buildThematic = function buildThematic({ }); }; -module.exports = buildThematic; +export { buildThematic }; diff --git a/api/tests/tooling/domain-builder/factory/build-training-for-admin.js b/api/tests/tooling/domain-builder/factory/build-training-for-admin.js index 2300148caec..82ebe7828f2 100644 --- a/api/tests/tooling/domain-builder/factory/build-training-for-admin.js +++ b/api/tests/tooling/domain-builder/factory/build-training-for-admin.js @@ -1,6 +1,6 @@ -const TrainingForAdmin = require('../../../../lib/domain/read-models/TrainingForAdmin'); +import { TrainingForAdmin } from '../../../../lib/domain/read-models/TrainingForAdmin.js'; -module.exports = function buildTrainingForAdmin({ +const buildTrainingForAdmin = function ({ id = 'training1', title = 'Training 1', link = 'https://example.net', @@ -27,3 +27,5 @@ module.exports = function buildTrainingForAdmin({ trainingTriggers, }); }; + +export { buildTrainingForAdmin }; diff --git a/api/tests/tooling/domain-builder/factory/build-training-summary.js b/api/tests/tooling/domain-builder/factory/build-training-summary.js index 83fed5aa445..3b07d2e5f54 100644 --- a/api/tests/tooling/domain-builder/factory/build-training-summary.js +++ b/api/tests/tooling/domain-builder/factory/build-training-summary.js @@ -1,9 +1,11 @@ -const TrainingSummary = require('../../../../lib/domain/read-models/TrainingSummary'); +import { TrainingSummary } from '../../../../lib/domain/read-models/TrainingSummary.js'; -module.exports = function buildTrainingSummary({ id = 1, title = 'Training Summary 1', isRecommendable = false } = {}) { +const buildTrainingSummary = function ({ id = 1, title = 'Training Summary 1', isRecommendable = false } = {}) { return new TrainingSummary({ id, title, isRecommendable, }); }; + +export { buildTrainingSummary }; diff --git a/api/tests/tooling/domain-builder/factory/build-training-trigger-for-admin.js b/api/tests/tooling/domain-builder/factory/build-training-trigger-for-admin.js index 1452d3e9839..884178099a4 100644 --- a/api/tests/tooling/domain-builder/factory/build-training-trigger-for-admin.js +++ b/api/tests/tooling/domain-builder/factory/build-training-trigger-for-admin.js @@ -1,8 +1,8 @@ -const buildTube = require('./build-tube'); -const TrainingTriggerForAdmin = require('../../../../lib/domain/read-models/TrainingTriggerForAdmin'); -const TrainingTriggerTube = require('../../../../lib/domain/models/TrainingTriggerTube'); +import { buildTube } from './build-tube.js'; +import { TrainingTriggerForAdmin } from '../../../../lib/domain/read-models/TrainingTriggerForAdmin.js'; +import { TrainingTriggerTube } from '../../../../lib/domain/models/TrainingTriggerTube.js'; -module.exports = function buildTrainingTriggerForAdmin({ +const buildTrainingTriggerForAdmin = function ({ id = 1000, trainingId = 156, triggerTubes = [ @@ -29,3 +29,5 @@ module.exports = function buildTrainingTriggerForAdmin({ thematics, }); }; + +export { buildTrainingTriggerForAdmin }; diff --git a/api/tests/tooling/domain-builder/factory/build-training-trigger-tube.js b/api/tests/tooling/domain-builder/factory/build-training-trigger-tube.js index 5bae9a006d1..0d602735040 100644 --- a/api/tests/tooling/domain-builder/factory/build-training-trigger-tube.js +++ b/api/tests/tooling/domain-builder/factory/build-training-trigger-tube.js @@ -1,10 +1,12 @@ -const buildTube = require('./build-tube'); -const TrainingTriggerTube = require('../../../../lib/domain/models/TrainingTriggerTube'); +import { buildTube } from './build-tube.js'; +import { TrainingTriggerTube } from '../../../../lib/domain/models/TrainingTriggerTube.js'; -module.exports = function buildTrainingTriggerTube({ id = 1000, tube = buildTube(), level = 8 } = {}) { +const buildTrainingTriggerTube = function ({ id = 1000, tube = buildTube(), level = 8 } = {}) { return new TrainingTriggerTube({ id, tube, level, }); }; + +export { buildTrainingTriggerTube }; diff --git a/api/tests/tooling/domain-builder/factory/build-training-trigger.js b/api/tests/tooling/domain-builder/factory/build-training-trigger.js index af65ce7a55f..cbee0adcc3c 100644 --- a/api/tests/tooling/domain-builder/factory/build-training-trigger.js +++ b/api/tests/tooling/domain-builder/factory/build-training-trigger.js @@ -1,8 +1,8 @@ -const buildTube = require('./build-tube'); -const TrainingTrigger = require('../../../../lib/domain/models/TrainingTrigger'); -const TrainingTriggerTube = require('../../../../lib/domain/models/TrainingTriggerTube'); +import { buildTube } from './build-tube.js'; +import { TrainingTrigger } from '../../../../lib/domain/models/TrainingTrigger.js'; +import { TrainingTriggerTube } from '../../../../lib/domain/models/TrainingTriggerTube.js'; -module.exports = function buildTrainingTrigger({ +const buildTrainingTrigger = function ({ id = 1000, trainingId = 156, triggerTubes = [ @@ -29,3 +29,5 @@ module.exports = function buildTrainingTrigger({ thematics, }); }; + +export { buildTrainingTrigger }; diff --git a/api/tests/tooling/domain-builder/factory/build-training.js b/api/tests/tooling/domain-builder/factory/build-training.js index 726a40f7f26..f72453f9dea 100644 --- a/api/tests/tooling/domain-builder/factory/build-training.js +++ b/api/tests/tooling/domain-builder/factory/build-training.js @@ -1,6 +1,6 @@ -const Training = require('../../../../lib/domain/models/Training'); +import { Training } from '../../../../lib/domain/models/Training.js'; -module.exports = function buildTraining({ +const buildTraining = function ({ id = 'training1', title = 'Training 1', link = 'https://example.net', @@ -27,3 +27,5 @@ module.exports = function buildTraining({ trainingTriggers, }); }; + +export { buildTraining }; diff --git a/api/tests/tooling/domain-builder/factory/build-tube.js b/api/tests/tooling/domain-builder/factory/build-tube.js index 3fb019f87c9..3bb5660084e 100644 --- a/api/tests/tooling/domain-builder/factory/build-tube.js +++ b/api/tests/tooling/domain-builder/factory/build-tube.js @@ -1,7 +1,7 @@ -const Tube = require('../../../../lib/domain/models/Tube'); -const buildSkillCollection = require('./build-skill-collection'); +import { Tube } from '../../../../lib/domain/models/Tube.js'; +import { BuildSkillCollection as buildSkillCollection } from './build-skill-collection.js'; -module.exports = function buildTube({ +const buildTube = function ({ id = 'recTube123', name = '@tubeName', title = 'titre', @@ -30,3 +30,5 @@ module.exports = function buildTube({ skillIds, }); }; + +export { buildTube }; diff --git a/api/tests/tooling/domain-builder/factory/build-tutorial-for-user.js b/api/tests/tooling/domain-builder/factory/build-tutorial-for-user.js index 850303d5cd4..f0080fc5453 100644 --- a/api/tests/tooling/domain-builder/factory/build-tutorial-for-user.js +++ b/api/tests/tooling/domain-builder/factory/build-tutorial-for-user.js @@ -1,8 +1,8 @@ -const buildTutorial = require('./build-tutorial'); -const buildUserSavedTutorial = require('./build-user-saved-tutorial'); -const TutorialForUser = require('../../../../lib/domain/read-models/TutorialForUser'); +import { buildTutorial } from './build-tutorial.js'; +import { buildUserSavedTutorial } from './build-user-saved-tutorial.js'; +import { TutorialForUser } from '../../../../lib/domain/read-models/TutorialForUser.js'; -module.exports = function buildTutorialForUser({ +const buildTutorialForUser = function ({ tutorial = buildTutorial(), userSavedTutorial = buildUserSavedTutorial(), tutorialEvaluation, @@ -10,3 +10,5 @@ module.exports = function buildTutorialForUser({ } = {}) { return new TutorialForUser({ ...tutorial, tutorialEvaluation, userSavedTutorial, skillId }); }; + +export { buildTutorialForUser }; diff --git a/api/tests/tooling/domain-builder/factory/build-tutorial.js b/api/tests/tooling/domain-builder/factory/build-tutorial.js index f74c423af22..5a00ac616a5 100644 --- a/api/tests/tooling/domain-builder/factory/build-tutorial.js +++ b/api/tests/tooling/domain-builder/factory/build-tutorial.js @@ -1,6 +1,6 @@ -const Tutorial = require('../../../../lib/domain/models/Tutorial'); +import { Tutorial } from '../../../../lib/domain/models/Tutorial.js'; -module.exports = function buildTutorial({ +const buildTutorial = function ({ id = 'recTuto1', duration = '00:01:30', format = 'video', @@ -17,3 +17,5 @@ module.exports = function buildTutorial({ title, }); }; + +export { buildTutorial }; diff --git a/api/tests/tooling/domain-builder/factory/build-user-competence.js b/api/tests/tooling/domain-builder/factory/build-user-competence.js index cbd2ee839c5..53bae83cfe6 100644 --- a/api/tests/tooling/domain-builder/factory/build-user-competence.js +++ b/api/tests/tooling/domain-builder/factory/build-user-competence.js @@ -1,6 +1,6 @@ -const UserCompetence = require('../../../../lib/domain/models/UserCompetence'); +import { UserCompetence } from '../../../../lib/domain/models/UserCompetence.js'; -module.exports = function buildUserCompetence({ +const buildUserCompetence = function ({ id = 'recUserComp', index = '1.1', name = 'name', @@ -19,3 +19,5 @@ module.exports = function buildUserCompetence({ skills, }); }; + +export { buildUserCompetence }; diff --git a/api/tests/tooling/domain-builder/factory/build-user-details-for-admin.js b/api/tests/tooling/domain-builder/factory/build-user-details-for-admin.js index c33db56fc61..7797f545d4f 100644 --- a/api/tests/tooling/domain-builder/factory/build-user-details-for-admin.js +++ b/api/tests/tooling/domain-builder/factory/build-user-details-for-admin.js @@ -1,6 +1,6 @@ -const UserDetailsForAdmin = require('../../../../lib/domain/models/UserDetailsForAdmin'); +import { UserDetailsForAdmin } from '../../../../lib/domain/models/UserDetailsForAdmin.js'; -module.exports = function buildUserDetailsForAdmin({ +const buildUserDetailsForAdmin = function ({ id = 123, firstName = 'Louis', lastName = 'Philippe', @@ -51,3 +51,5 @@ module.exports = function buildUserDetailsForAdmin({ hasBeenAnonymisedBy, }); }; + +export { buildUserDetailsForAdmin }; diff --git a/api/tests/tooling/domain-builder/factory/build-user-orga-settings.js b/api/tests/tooling/domain-builder/factory/build-user-orga-settings.js index 7314aeb87bf..8934e558799 100644 --- a/api/tests/tooling/domain-builder/factory/build-user-orga-settings.js +++ b/api/tests/tooling/domain-builder/factory/build-user-orga-settings.js @@ -1,6 +1,6 @@ -const UserOrgaSettings = require('../../../../lib/domain/models/UserOrgaSettings'); -const Organization = require('../../../../lib/domain/models/Organization'); -const User = require('../../../../lib/domain/models/User'); +import { UserOrgaSettings } from '../../../../lib/domain/models/UserOrgaSettings.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { User } from '../../../../lib/domain/models/User.js'; /* * /!\ We can not use standard entity builders because of bidirectional relationships (a.k.a. cyclic dependencies) @@ -26,7 +26,7 @@ function _buildOrganization() { }); } -module.exports = function buildUserOrgaSettings({ +const buildUserOrgaSettings = function ({ id = 789, currentOrganization = _buildOrganization(), user = _buildUser(), @@ -37,3 +37,5 @@ module.exports = function buildUserOrgaSettings({ return userOrgaSettings; }; + +export { buildUserOrgaSettings }; diff --git a/api/tests/tooling/domain-builder/factory/build-user-saved-tutorial-with-tutorial.js b/api/tests/tooling/domain-builder/factory/build-user-saved-tutorial-with-tutorial.js index fccb6b55106..c23aea6991d 100644 --- a/api/tests/tooling/domain-builder/factory/build-user-saved-tutorial-with-tutorial.js +++ b/api/tests/tooling/domain-builder/factory/build-user-saved-tutorial-with-tutorial.js @@ -1,9 +1,9 @@ -const UserSavedTutorialWithTutorial = require('../../../../lib/domain/models/UserSavedTutorialWithTutorial'); -const buildSkill = require('./build-skill'); -const buildTutorial = require('./build-tutorial'); -const buildUser = require('./build-user'); +import { UserSavedTutorialWithTutorial } from '../../../../lib/domain/models/UserSavedTutorialWithTutorial.js'; +import { buildSkill } from './build-skill.js'; +import { buildTutorial } from './build-tutorial.js'; +import { buildUser } from './build-user.js'; -module.exports = function buildUserSavedTutorialWithTutorial({ +const buildUserSavedTutorialWithTutorial = function ({ id = 123, userId = buildUser().id, skillId = buildSkill().id, @@ -16,3 +16,5 @@ module.exports = function buildUserSavedTutorialWithTutorial({ tutorial, }); }; + +export { buildUserSavedTutorialWithTutorial }; diff --git a/api/tests/tooling/domain-builder/factory/build-user-saved-tutorial.js b/api/tests/tooling/domain-builder/factory/build-user-saved-tutorial.js index 441aaaf57c6..c17648e4ba3 100644 --- a/api/tests/tooling/domain-builder/factory/build-user-saved-tutorial.js +++ b/api/tests/tooling/domain-builder/factory/build-user-saved-tutorial.js @@ -1,6 +1,6 @@ -const UserSavedTutorial = require('../../../../lib/domain/models/UserSavedTutorial'); +import { UserSavedTutorial } from '../../../../lib/domain/models/UserSavedTutorial.js'; -module.exports = function buildUserSavedTutorial({ +const buildUserSavedTutorial = function ({ id = 111, userId = '4044', tutorialId = '111', @@ -15,3 +15,5 @@ module.exports = function buildUserSavedTutorial({ createdAt, }); }; + +export { buildUserSavedTutorial }; diff --git a/api/tests/tooling/domain-builder/factory/build-user-scorecard.js b/api/tests/tooling/domain-builder/factory/build-user-scorecard.js index 1a3211e51f7..7020908570f 100644 --- a/api/tests/tooling/domain-builder/factory/build-user-scorecard.js +++ b/api/tests/tooling/domain-builder/factory/build-user-scorecard.js @@ -1,7 +1,7 @@ -const buildArea = require('./build-area'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); +import { buildArea } from './build-area.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; -module.exports = function buildUserScorecard({ +const buildUserScorecard = function ({ id = 'recCOMP123_789', // attributes name = 'Mener une troupe à la bataille', @@ -38,3 +38,5 @@ module.exports = function buildUserScorecard({ tutorials, }); }; + +export { buildUserScorecard }; diff --git a/api/tests/tooling/domain-builder/factory/build-user.js b/api/tests/tooling/domain-builder/factory/build-user.js index 91ea47df0b9..197c1c1dcde 100644 --- a/api/tests/tooling/domain-builder/factory/build-user.js +++ b/api/tests/tooling/domain-builder/factory/build-user.js @@ -1,10 +1,9 @@ -const User = require('../../../../lib/domain/models/User'); +import { User } from '../../../../lib/domain/models/User.js'; +import { buildMembership } from './build-membership.js'; +import { buildCertificationCenterMembership } from './build-certification-center-membership.js'; +import { buildAuthenticationMethod } from './build-authentication-method.js'; -const buildMembership = require('./build-membership'); -const buildCertificationCenterMembership = require('./build-certification-center-membership'); -const buildAuthenticationMethod = require('./build-authentication-method'); - -module.exports = function buildUser({ +const buildUser = function ({ id = 123, firstName = 'Lorie', lastName = 'MeilleureAmie', @@ -51,3 +50,5 @@ module.exports = function buildUser({ hasBeenAnonymisedBy, }); }; + +export { buildUser }; diff --git a/api/tests/tooling/domain-builder/factory/build-validation.js b/api/tests/tooling/domain-builder/factory/build-validation.js index 7391549d0be..cacea157502 100644 --- a/api/tests/tooling/domain-builder/factory/build-validation.js +++ b/api/tests/tooling/domain-builder/factory/build-validation.js @@ -1,9 +1,11 @@ -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const Validation = require('../../../../lib/domain/models/Validation'); +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { Validation } from '../../../../lib/domain/models/Validation.js'; -module.exports = function ({ result = AnswerStatus.OK, resultDetails = 'Bravo' } = {}) { +const buildValidation = function ({ result = AnswerStatus.OK, resultDetails = 'Bravo' } = {}) { return new Validation({ result, resultDetails, }); }; + +export { buildValidation }; diff --git a/api/tests/tooling/domain-builder/factory/build-validator.js b/api/tests/tooling/domain-builder/factory/build-validator.js index 8a8e56225b3..ed51ee0eef5 100644 --- a/api/tests/tooling/domain-builder/factory/build-validator.js +++ b/api/tests/tooling/domain-builder/factory/build-validator.js @@ -1,6 +1,6 @@ -const Validator = require('../../../../lib/domain/models/Validator'); -const ValidatorQCU = require('../../../../lib/domain/models/ValidatorQCU'); -const buildSolution = require('./build-solution'); +import { Validator } from '../../../../lib/domain/models/Validator.js'; +import { ValidatorQCU } from '../../../../lib/domain/models/ValidatorQCU.js'; +import { buildSolution } from './build-solution.js'; function buildValidator({ solution = buildSolution() } = {}) { return new Validator({ @@ -14,4 +14,4 @@ buildValidator.ofTypeQCU = function ({ solution = buildSolution() } = {}) { }); }; -module.exports = buildValidator; +export { buildValidator }; diff --git a/api/tests/tooling/domain-builder/factory/index.js b/api/tests/tooling/domain-builder/factory/index.js index 1f70f6d1e03..55b30fc3d94 100644 --- a/api/tests/tooling/domain-builder/factory/index.js +++ b/api/tests/tooling/domain-builder/factory/index.js @@ -1,151 +1,151 @@ -const buildAccountRecoveryDemand = require('./build-account-recovery-demand'); -const buildAdminMember = require('./build-admin-member'); -const buildAllowedCertificationCenterAccess = require('./build-allowed-certification-center-access'); -const buildAnswer = require('./build-answer'); -const buildArea = require('./build-area'); -const buildAssessment = require('./build-assessment'); -const buildAssessmentResult = require('./build-assessment-result'); -const buildAuthenticationMethod = require('./build-authentication-method'); -const buildBadge = require('./build-badge'); -const buildBadgeAcquisition = require('./build-badge-acquisition'); -const buildBadgeCriterion = require('./build-badge-criterion'); -const buildBadgeDetails = require('./build-badge-details'); -const buildBadgeForCalculation = require('./build-badge-for-calculation'); -const buildBadgeCriterionForCalculation = require('./build-badge-criterion-for-calculation'); -const buildSkillSet = require('./build-skill-set'); -const buildCampaign = require('./build-campaign'); -const buildCampaignCollectiveResult = require('./build-campaign-collective-result'); -const buildCampaignParticipation = require('./build-campaign-participation'); -const buildCampaignParticipationBadge = require('./build-campaign-participation-badge'); -const buildCampaignParticipationForUserManagement = require('./build-campaign-participation-for-user-management'); -const buildCampaignParticipationResult = require('./build-campaign-participation-result'); -const buildCampaignParticipationInfo = require('./build-campaign-participation-info'); -const buildCampaignLearningContent = require('./build-campaign-learning-content'); -const buildCampaignManagement = require('./build-campaign-management'); -const buildCampaignReport = require('./build-campaign-report'); -const buildCampaignToJoin = require('./build-campaign-to-join'); -const buildCampaignToStartParticipation = require('./build-campaign-to-start-participation'); -const buildCertifiableBadgeAcquisition = require('./build-certifiable-badge-acquisition'); -const buildCertificationAssessment = require('./build-certification-assessment'); -const buildCertificationAssessmentScore = require('./build-certification-assessment-score'); -const buildCertificationCandidate = require('./build-certification-candidate'); -const buildCertificationCandidateForSupervising = require('./build-certification-candidate-for-supervising'); -const buildCertificationCandidateSubscription = require('./build-certification-candidate-subscription'); -const buildCertificationEligibility = require('./build-certification-eligibility'); -const buildCertificationIssueReport = require('./build-certification-issue-report'); -const buildCertificationOfficer = require('./build-certification-officer'); -const buildSCOCertificationCandidate = require('./build-sco-certification-candidate'); -const buildCertificationAttestation = require('./build-certification-attestation'); -const buildCertificationCenter = require('./build-certification-center'); -const buildCertificationCenterForAdmin = require('./build-certification-center-for-admin'); -const buildCertificationCenterInvitation = require('./build-certification-center-invitation'); -const buildCertificationCenterMembership = require('./build-certification-center-membership'); -const buildCertificationChallenge = require('./build-certification-challenge'); -const buildCertificationChallengeWithType = require('./build-certification-challenge-with-type'); -const buildCertificationCourse = require('./build-certification-course'); -const buildCertificationCpfCity = require('./build-certification-cpf-city'); -const buildCertificationCpfCountry = require('./build-certification-cpf-country'); -const buildCertificationDetails = require('./build-certification-details'); -const buildCertificationPointOfContact = require('./build-certification-point-of-contact'); -const buildCertifiableProfileForLearningContent = require('./build-certifiable-profile-for-learning-content'); -const buildCertificationReport = require('./build-certification-report'); -const buildCertificationResult = require('./build-certification-result'); -const buildCertificationRescoringCompletedEvent = require('./build-certification-rescoring-completed-event'); -const buildCertificationScoringCompletedEvent = require('./build-certification-scoring-completed-event'); -const buildCertifiedArea = require('./build-certified-area'); -const buildCertifiedCompetence = require('./build-certified-competence'); -const buildCertifiedProfile = require('./build-certified-profile'); -const buildCertifiedSkill = require('./build-certified-skill'); -const buildCertifiedTube = require('./build-certified-tube'); -const buildChallenge = require('./build-challenge'); -const buildChallengeLearningContentDataObject = require('./build-challenge-learning-content-data-object'); -const buildCleaCertifiedCandidate = require('./build-clea-certified-candidate'); -const buildCompetence = require('./build-competence'); -const buildCompetenceEvaluation = require('./build-competence-evaluation'); -const buildCompetenceMark = require('./build-competence-mark'); -const buildCompetenceResult = require('./build-competence-result'); -const buildCompetenceTree = require('./build-competence-tree'); -const buildComplementaryCertification = require('./build-complementary-certification'); -const buildComplementaryCertificationForSupervising = require('./build-complementary-certification-for-supervising'); -const buildComplementaryCertificationHabilitation = require('./build-complementary-certification-habilitation'); -const buildComplementaryCertificationScoringCriteria = require('./build-complementary-certification-scoring-criteria'); -const buildCountry = require('./build-country'); -const buildCourse = require('./build-course'); -const buildCpfCertificationResult = require('./build-cpf-certification-result'); -const buildDataProtectionOfficer = require('./build-data-protection-officer'); -const buildFinalizedSession = require('./build-finalized-session'); -const buildFramework = require('./build-framework'); -const buildHint = require('./build-hint'); -const buildSupOrganizationLearner = require('./build-sup-organization-learner'); -const buildJuryCertification = require('./build-jury-certification'); -const buildJuryCertificationSummary = require('./build-jury-certification-summary'); -const buildJurySession = require('./build-jury-session'); -const buildKnowledgeElement = require('./build-knowledge-element'); -const buildLearningContent = require('./build-learning-content'); -const buildMembership = require('./build-membership'); -const buildOrganization = require('./build-organization'); -const buildOrganizationPlacesLot = require('./build-organization-places-lot'); -const buildOrganizationPlacesLotManagement = require('./build-organization-places-lot-management'); -const buildOrganizationForAdmin = require('./build-organization-for-admin'); -const buildOrganizationInvitation = require('./build-organization-invitation'); -const buildOrganizationLearner = require('./build-organization-learner'); -const buildOrganizationLearnerForAdmin = require('./build-organization-learner-for-admin'); -const buildOrganizationLearnerParticipation = require('./build-organization-learner-participation'); -const buildOrganizationTag = require('./build-organization-tag'); -const buildParticipationForCampaignManagement = require('./build-participation-for-campaign-management'); -const buildComplementaryCertificationCourseResult = require('./build-complementary-certification-course-result'); -const buildComplementaryCertificationCourseResultForJuryCertification = require('./build-complementary-certification-course-result-for-certification'); -const buildComplementaryCertificationCourseResultForJuryCertificationWithExternal = require('./build-complementary-certification-course-result-for-certification-with-external'); -const buildComplementaryCertificationScoringWithoutComplementaryReferential = require('./build-complementary-certification-scoring-without-complementary-referential'); -const buildComplementaryCertificationScoringWithComplementaryReferential = require('./build-pix-plus-certification-scoring'); -const buildPlacementProfile = require('./build-placement-profile'); -const buildPoleEmploiSending = require('./build-pole-emploi-sending'); -const buildPrescriber = require('./build-prescriber'); -const buildPrivateCertificate = require('./build-private-certificate'); -const buildPrivateCertificateWithCompetenceTree = require('./build-private-certificate-with-competence-tree'); -const buildProgression = require('./build-progression'); -const buildReproducibilityRate = require('./build-reproducibility-rate'); -const buildResultCompetenceTree = require('./build-result-competence-tree'); -const buildSession = require('./build-session'); -const buildSessionForSupervising = require('./build-session-for-supervising'); -const buildSessionForSupervisorKit = require('./build-session-for-supervisor-kit'); -const buildSessionJuryComment = require('./build-session-jury-comment'); -const buildSessionSummary = require('./build-session-summary'); -const buildShareableCertificate = require('./build-shareable-certificate'); -const buildSkill = require('./build-skill'); -const buildSkillLearningContentDataObject = require('./build-skill-learning-content-data-object'); -const buildSkillCollection = require('./build-skill-collection'); -const buildSolution = require('./build-solution'); -const buildStage = require('./build-stage'); -const buildStageCollectionForTargetProfileManagement = require('./target-profile-management/build-stage-collection'); -const buildStageCollectionForUserCampaignResults = require('./user-campaign-results/build-stage-collection'); -const buildTag = require('./build-tag'); -const buildTargetProfile = require('./build-target-profile'); -const buildTargetProfileForAdmin = require('./build-target-profile-for-admin'); -const buildTargetProfileForCreation = require('./build-target-profile-for-creation'); -const buildOrganizationsToAttachToTargetProfile = require('./build-organizations-to-attach-to-target-profile'); -const buildTargetProfileSummaryForAdmin = require('./build-target-profile-summary-for-admin'); -const buildThematic = require('./build-thematic'); -const buildTraining = require('./build-training'); -const buildTrainingForAdmin = require('./build-training-for-admin'); -const buildTrainingSummary = require('./build-training-summary'); -const buildTrainingTrigger = require('./build-training-trigger'); -const buildTrainingTriggerForAdmin = require('./build-training-trigger-for-admin'); -const buildTrainingTriggerTube = require('./build-training-trigger-tube'); -const buildTube = require('./build-tube'); -const buildTutorial = require('./build-tutorial'); -const buildTutorialForUser = require('./build-tutorial-for-user'); -const buildUser = require('./build-user'); -const buildUserCompetence = require('./build-user-competence'); -const buildUserDetailsForAdmin = require('./build-user-details-for-admin'); -const buildUserOrgaSettings = require('./build-user-orga-settings'); -const buildUserScorecard = require('./build-user-scorecard'); -const buildUserSavedTutorial = require('./build-user-saved-tutorial'); -const buildUserSavedTutorialWithTutorial = require('./build-user-saved-tutorial-with-tutorial'); -const buildValidation = require('./build-validation'); -const buildValidator = require('./build-validator'); +import { buildAccountRecoveryDemand } from './build-account-recovery-demand.js'; +import { buildAdminMember } from './build-admin-member.js'; +import { buildAllowedCertificationCenterAccess } from './build-allowed-certification-center-access.js'; +import { buildAnswer } from './build-answer.js'; +import { buildArea } from './build-area.js'; +import { buildAssessment } from './build-assessment.js'; +import { buildAssessmentResult } from './build-assessment-result.js'; +import { buildAuthenticationMethod } from './build-authentication-method.js'; +import { buildBadge } from './build-badge.js'; +import { buildBadgeAcquisition } from './build-badge-acquisition.js'; +import { buildBadgeCriterion } from './build-badge-criterion.js'; +import { buildBadgeDetails } from './build-badge-details.js'; +import { buildBadgeForCalculation } from './build-badge-for-calculation.js'; +import { buildBadgeCriterionForCalculation } from './build-badge-criterion-for-calculation.js'; +import { buildSkillSet } from './build-skill-set.js'; +import { buildCampaign } from './build-campaign.js'; +import { buildCampaignCollectiveResult } from './build-campaign-collective-result.js'; +import { buildCampaignParticipation } from './build-campaign-participation.js'; +import { buildCampaignParticipationBadge } from './build-campaign-participation-badge.js'; +import { buildCampaignParticipationForUserManagement } from './build-campaign-participation-for-user-management.js'; +import { buildCampaignParticipationResult } from './build-campaign-participation-result.js'; +import { buildCampaignParticipationInfo } from './build-campaign-participation-info.js'; +import { buildCampaignLearningContent } from './build-campaign-learning-content.js'; +import { buildCampaignManagement } from './build-campaign-management.js'; +import { buildCampaignReport } from './build-campaign-report.js'; +import { buildCampaignToJoin } from './build-campaign-to-join.js'; +import { buildCampaignToStartParticipation } from './build-campaign-to-start-participation.js'; +import { buildCertifiableBadgeAcquisition } from './build-certifiable-badge-acquisition.js'; +import { buildCertificationAssessment } from './build-certification-assessment.js'; +import { buildCertificationAssessmentScore } from './build-certification-assessment-score.js'; +import { buildCertificationCandidate } from './build-certification-candidate.js'; +import { buildCertificationCandidateForSupervising } from './build-certification-candidate-for-supervising.js'; +import { buildCertificationCandidateSubscription } from './build-certification-candidate-subscription.js'; +import { buildCertificationEligibility } from './build-certification-eligibility.js'; +import { buildCertificationIssueReport } from './build-certification-issue-report.js'; +import { buildCertificationOfficer } from './build-certification-officer.js'; +import { buildSCOCertificationCandidate } from './build-sco-certification-candidate.js'; +import { buildCertificationAttestation } from './build-certification-attestation.js'; +import { buildCertificationCenter } from './build-certification-center.js'; +import { buildCertificationCenterForAdmin } from './build-certification-center-for-admin.js'; +import { buildCertificationCenterInvitation } from './build-certification-center-invitation.js'; +import { buildCertificationCenterMembership } from './build-certification-center-membership.js'; +import { buildCertificationChallenge } from './build-certification-challenge.js'; +import { buildCertificationChallengeWithType } from './build-certification-challenge-with-type.js'; +import { buildCertificationCourse } from './build-certification-course.js'; +import { buildCertificationCpfCity } from './build-certification-cpf-city.js'; +import { buildCertificationCpfCountry } from './build-certification-cpf-country.js'; +import { buildCertificationDetails } from './build-certification-details.js'; +import { buildCertificationPointOfContact } from './build-certification-point-of-contact.js'; +import { buildCertifiableProfileForLearningContent } from './build-certifiable-profile-for-learning-content.js'; +import { buildCertificationReport } from './build-certification-report.js'; +import { buildCertificationResult } from './build-certification-result.js'; +import { buildCertificationRescoringCompletedEvent } from './build-certification-rescoring-completed-event.js'; +import { buildCertificationScoringCompletedEvent } from './build-certification-scoring-completed-event.js'; +import { buildCertifiedArea } from './build-certified-area.js'; +import { buildCertifiedCompetence } from './build-certified-competence.js'; +import { buildCertifiedProfile } from './build-certified-profile.js'; +import { buildCertifiedSkill } from './build-certified-skill.js'; +import { buildCertifiedTube } from './build-certified-tube.js'; +import { buildChallenge } from './build-challenge.js'; +import { buildChallengeLearningContentDataObject } from './build-challenge-learning-content-data-object.js'; +import { buildCleaCertifiedCandidate } from './build-clea-certified-candidate.js'; +import { buildCompetence } from './build-competence.js'; +import { buildCompetenceEvaluation } from './build-competence-evaluation.js'; +import { buildCompetenceMark } from './build-competence-mark.js'; +import { buildCompetenceResult } from './build-competence-result.js'; +import { buildCompetenceTree } from './build-competence-tree.js'; +import { buildComplementaryCertification } from './build-complementary-certification.js'; +import { buildComplementaryCertificationForSupervising } from './build-complementary-certification-for-supervising.js'; +import { buildComplementaryCertificationHabilitation } from './build-complementary-certification-habilitation.js'; +import { buildComplementaryCertificationScoringCriteria } from './build-complementary-certification-scoring-criteria.js'; +import { buildCountry } from './build-country.js'; +import { buildCourse } from './build-course.js'; +import { buildCpfCertificationResult } from './build-cpf-certification-result.js'; +import * as buildDataProtectionOfficer from './build-data-protection-officer.js'; +import { buildFinalizedSession } from './build-finalized-session.js'; +import { buildFramework } from './build-framework.js'; +import { buildHint } from './build-hint.js'; +import { buildSupOrganizationLearner } from './build-sup-organization-learner.js'; +import { buildJuryCertification } from './build-jury-certification.js'; +import { buildJuryCertificationSummary } from './build-jury-certification-summary.js'; +import { buildJurySession } from './build-jury-session.js'; +import { buildKnowledgeElement } from './build-knowledge-element.js'; +import { buildLearningContent } from './build-learning-content.js'; +import { buildMembership } from './build-membership.js'; +import { buildOrganization } from './build-organization.js'; +import { buildOrganizationPlacesLot } from './build-organization-places-lot.js'; +import { buildOrganizationPlacesLotManagement } from './build-organization-places-lot-management.js'; +import { buildOrganizationForAdmin } from './build-organization-for-admin.js'; +import { buildOrganizationInvitation } from './build-organization-invitation.js'; +import { buildOrganizationLearner } from './build-organization-learner.js'; +import { buildOrganizationLearnerForAdmin } from './build-organization-learner-for-admin.js'; +import { buildOrganizationLearnerParticipation } from './build-organization-learner-participation.js'; +import { buildOrganizationTag } from './build-organization-tag.js'; +import { buildParticipationForCampaignManagement } from './build-participation-for-campaign-management.js'; +import { buildComplementaryCertificationCourseResult } from './build-complementary-certification-course-result.js'; +import { buildComplementaryCertificationCourseResultForJuryCertification } from './build-complementary-certification-course-result-for-certification.js'; +import { buildPixEduComplementaryCertificationCourseResultsForJuryCertificationWithExternal as buildComplementaryCertificationCourseResultForJuryCertificationWithExternal } from './build-complementary-certification-course-result-for-certification-with-external.js'; +import { buildComplementaryCertificationScoringWithoutComplementaryReferential } from './build-complementary-certification-scoring-without-complementary-referential.js'; +import { buildComplementaryCertificationScoringWithComplementaryReferential } from './build-pix-plus-certification-scoring.js'; +import { buildPlacementProfile } from './build-placement-profile.js'; +import { buildPoleEmploiSending } from './build-pole-emploi-sending.js'; +import { buildPrescriber } from './build-prescriber.js'; +import { buildPrivateCertificate } from './build-private-certificate.js'; +import { buildPrivateCertificate as buildPrivateCertificateWithCompetenceTree } from './build-private-certificate-with-competence-tree.js'; +import { buildProgression } from './build-progression.js'; +import { buildReproducibilityRate } from './build-reproducibility-rate.js'; +import { buildResultCompetenceTree } from './build-result-competence-tree.js'; +import { buildSession } from './build-session.js'; +import { buildSessionForSupervising } from './build-session-for-supervising.js'; +import { buildSessionForSupervisorKit } from './build-session-for-supervisor-kit.js'; +import { buildSessionJuryComment } from './build-session-jury-comment.js'; +import { buildSessionSummary } from './build-session-summary.js'; +import { buildShareableCertificate } from './build-shareable-certificate.js'; +import { buildSkill } from './build-skill.js'; +import { buildSkillLearningContentDataObject } from './build-skill-learning-content-data-object.js'; +import { BuildSkillCollection as buildSkillCollection } from './build-skill-collection.js'; +import { buildSolution } from './build-solution.js'; +import { buildStage } from './build-stage.js'; +import { buildStageCollection as buildStageCollectionForTargetProfileManagement } from './target-profile-management/build-stage-collection.js'; +import { buildStageCollection as buildStageCollectionForUserCampaignResults } from './user-campaign-results/build-stage-collection.js'; +import { buildTag } from './build-tag.js'; +import { buildTargetProfile } from './build-target-profile.js'; +import { buildTargetProfileForAdmin } from './build-target-profile-for-admin.js'; +import { buildTargetProfileForCreation } from './build-target-profile-for-creation.js'; +import { buildOrganizationsToAttachToTargetProfile } from './build-organizations-to-attach-to-target-profile.js'; +import { buildTargetProfileSummaryForAdmin } from './build-target-profile-summary-for-admin.js'; +import { buildThematic } from './build-thematic.js'; +import { buildTraining } from './build-training.js'; +import { buildTrainingForAdmin } from './build-training-for-admin.js'; +import { buildTrainingSummary } from './build-training-summary.js'; +import { buildTrainingTrigger } from './build-training-trigger.js'; +import { buildTrainingTriggerForAdmin } from './build-training-trigger-for-admin.js'; +import { buildTrainingTriggerTube } from './build-training-trigger-tube.js'; +import { buildTube } from './build-tube.js'; +import { buildTutorial } from './build-tutorial.js'; +import { buildTutorialForUser } from './build-tutorial-for-user.js'; +import { buildUser } from './build-user.js'; +import { buildUserCompetence } from './build-user-competence.js'; +import { buildUserDetailsForAdmin } from './build-user-details-for-admin.js'; +import { buildUserOrgaSettings } from './build-user-orga-settings.js'; +import { buildUserScorecard } from './build-user-scorecard.js'; +import { buildUserSavedTutorial } from './build-user-saved-tutorial.js'; +import { buildUserSavedTutorialWithTutorial } from './build-user-saved-tutorial-with-tutorial.js'; +import { buildValidation } from './build-validation.js'; +import { buildValidator } from './build-validator.js'; -module.exports = { +export { buildAccountRecoveryDemand, buildAdminMember, buildAllowedCertificationCenterAccess, diff --git a/api/tests/tooling/domain-builder/factory/target-profile-management/build-stage-collection.js b/api/tests/tooling/domain-builder/factory/target-profile-management/build-stage-collection.js index 91da2382b84..1d948a77320 100644 --- a/api/tests/tooling/domain-builder/factory/target-profile-management/build-stage-collection.js +++ b/api/tests/tooling/domain-builder/factory/target-profile-management/build-stage-collection.js @@ -1,7 +1,7 @@ -const StageCollection = require('../../../../../lib/domain/models/target-profile-management/StageCollection'); +import { StageCollection } from '../../../../../lib/domain/models/target-profile-management/StageCollection.js'; const buildStageCollection = function ({ id, stages = [], maxLevel } = {}) { return new StageCollection({ id, stages, maxLevel }); }; -module.exports = buildStageCollection; +export { buildStageCollection }; diff --git a/api/tests/tooling/domain-builder/factory/user-campaign-results/build-stage-collection.js b/api/tests/tooling/domain-builder/factory/user-campaign-results/build-stage-collection.js index 3664ae12eea..6d668f94666 100644 --- a/api/tests/tooling/domain-builder/factory/user-campaign-results/build-stage-collection.js +++ b/api/tests/tooling/domain-builder/factory/user-campaign-results/build-stage-collection.js @@ -1,7 +1,7 @@ -const StageCollection = require('../../../../../lib/domain/models/user-campaign-results/StageCollection'); +import { StageCollection } from '../../../../../lib/domain/models/user-campaign-results/StageCollection.js'; const buildStageCollection = function ({ campaignId, stages } = {}) { return new StageCollection({ campaignId, stages }); }; -module.exports = buildStageCollection; +export { buildStageCollection }; diff --git a/api/tests/tooling/events/event-dispatcher-builder.js b/api/tests/tooling/events/event-dispatcher-builder.js index 053d1f51583..44f55d4e1df 100644 --- a/api/tests/tooling/events/event-dispatcher-builder.js +++ b/api/tests/tooling/events/event-dispatcher-builder.js @@ -1,5 +1,5 @@ -const { sinon } = require('../../test-helper'); -const { _forTestOnly } = require('../../../lib/domain/events/index.js'); +import { sinon } from '../../test-helper.js'; +import { _forTestOnly } from '../../../lib/domain/events/index.js'; function buildEventDispatcherAndHandlersForTest() { const handlerStubs = {}; @@ -13,4 +13,4 @@ function buildEventDispatcherAndHandlersForTest() { }; } -module.exports = buildEventDispatcherAndHandlersForTest; +export { buildEventDispatcherAndHandlersForTest }; diff --git a/api/tests/tooling/fixtures/infrastructure/challengeLearningContentDataObjectFixture.js b/api/tests/tooling/fixtures/infrastructure/challengeLearningContentDataObjectFixture.js index 7000e6b52b9..dfe91f69c17 100644 --- a/api/tests/tooling/fixtures/infrastructure/challengeLearningContentDataObjectFixture.js +++ b/api/tests/tooling/fixtures/infrastructure/challengeLearningContentDataObjectFixture.js @@ -1,4 +1,4 @@ -module.exports = function ChallengeLearningContentDataObjectFixture({ +const ChallengeLearningContentDataObjectFixture = function ({ id = 'recwWzTquPlvIl4So', instruction = "Les moteurs de recherche affichent certains liens en raison d'un accord commercial.\n\nDans quels encadrés se trouvent ces liens ?", proposals = '- 1\n- 2\n- 3\n- 4\n- 5', @@ -54,3 +54,5 @@ module.exports = function ChallengeLearningContentDataObjectFixture({ alternativeInstruction, }; }; + +export { ChallengeLearningContentDataObjectFixture }; diff --git a/api/tests/tooling/fixtures/infrastructure/skillLearningContentDataObjectFixture.js b/api/tests/tooling/fixtures/infrastructure/skillLearningContentDataObjectFixture.js index 181c3a7775d..e7d78d54acd 100644 --- a/api/tests/tooling/fixtures/infrastructure/skillLearningContentDataObjectFixture.js +++ b/api/tests/tooling/fixtures/infrastructure/skillLearningContentDataObjectFixture.js @@ -12,7 +12,7 @@ const DEFAULT_ID = 'recSK0X22abcdefgh', DEFAULT_PIX_VALUE = 2.4, DEFAULT_TUBE_ID = 'recTU0X22abcdefgh'; -module.exports = function SkillLearningContentDataObjectFixture({ +const SkillLearningContentDataObjectFixture = function ({ id = DEFAULT_ID, name = DEFAULT_NAME, hintEnUs = DEFAULT_HINT_EN_US, @@ -41,3 +41,5 @@ module.exports = function SkillLearningContentDataObjectFixture({ tubeId, }; }; + +export { SkillLearningContentDataObjectFixture }; diff --git a/api/tests/tooling/fixtures/infrastructure/tutorialLearningContentDataObjectFixture.js b/api/tests/tooling/fixtures/infrastructure/tutorialLearningContentDataObjectFixture.js index 53c294a0552..7adc1485da3 100644 --- a/api/tests/tooling/fixtures/infrastructure/tutorialLearningContentDataObjectFixture.js +++ b/api/tests/tooling/fixtures/infrastructure/tutorialLearningContentDataObjectFixture.js @@ -1,4 +1,4 @@ -module.exports = function tutorialLearningContentDataObjectFixture({ +const tutorialLearningContentDataObjectFixture = function ({ id = 'receomyzL0AmpMFGw', duration = '00:01:30', format = 'video', @@ -17,3 +17,5 @@ module.exports = function tutorialLearningContentDataObjectFixture({ locale, }; }; + +export { tutorialLearningContentDataObjectFixture }; diff --git a/api/tests/tooling/i18n/i18n.js b/api/tests/tooling/i18n/i18n.js index 84cc4cb4de4..e1025b4680a 100644 --- a/api/tests/tooling/i18n/i18n.js +++ b/api/tests/tooling/i18n/i18n.js @@ -1,5 +1,7 @@ -const path = require('path'); -const i18n = require('i18n'); +import path from 'path'; +import i18n from 'i18n'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); function getI18n() { const directory = path.resolve(path.join(__dirname, '../../../translations')); @@ -13,4 +15,4 @@ function getI18n() { return i18n; } -module.exports = { getI18n }; +export { getI18n }; diff --git a/api/tests/tooling/i18n/i18n_test.js b/api/tests/tooling/i18n/i18n_test.js index 693f7ab07e7..0129ba3516d 100644 --- a/api/tests/tooling/i18n/i18n_test.js +++ b/api/tests/tooling/i18n/i18n_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../test-helper'); -const { getI18n } = require('./i18n'); +import { expect } from '../../test-helper.js'; +import { getI18n } from './i18n.js'; describe('Unit | Tooling | i18n', function () { it('should translate by default to fr', function () { diff --git a/api/tests/tooling/learning-content-builder/build-learning-content.js b/api/tests/tooling/learning-content-builder/build-learning-content.js index 6f82d43cbd6..0a1dc8f5ab7 100644 --- a/api/tests/tooling/learning-content-builder/build-learning-content.js +++ b/api/tests/tooling/learning-content-builder/build-learning-content.js @@ -1,5 +1,7 @@ -const _ = require('lodash'); -const { FRENCH_FRANCE, FRENCH_SPOKEN, ENGLISH_SPOKEN } = require('../../../lib/domain/constants').LOCALE; +import _ from 'lodash'; +import { LOCALE } from '../../../lib/domain/constants.js'; + +const { FRENCH_FRANCE, FRENCH_SPOKEN, ENGLISH_SPOKEN } = LOCALE; const buildLearningContent = function (learningContent) { const allAreas = []; @@ -183,4 +185,4 @@ buildLearningContent.fromAreas = function (learningContent) { return buildLearningContent(frameworks); }; -module.exports = buildLearningContent; +export { buildLearningContent }; diff --git a/api/tests/tooling/learning-content-builder/build-learning-content_test.js b/api/tests/tooling/learning-content-builder/build-learning-content_test.js index ab4a6f716f1..d0da7ac14ac 100644 --- a/api/tests/tooling/learning-content-builder/build-learning-content_test.js +++ b/api/tests/tooling/learning-content-builder/build-learning-content_test.js @@ -1,18 +1,12 @@ -const { expect, learningContentBuilder, mockLearningContent } = require('../../test-helper'); -const { areaDatasource } = require('../../../lib/infrastructure/datasources/learning-content/area-datasource'); -const { - competenceDatasource, -} = require('../../../lib/infrastructure/datasources/learning-content/competence-datasource'); -const { thematicDatasource } = require('../../../lib/infrastructure/datasources/learning-content/thematic-datasource'); -const { tubeDatasource } = require('../../../lib/infrastructure/datasources/learning-content/tube-datasource'); -const { skillDatasource } = require('../../../lib/infrastructure/datasources/learning-content/skill-datasource'); -const { - challengeDatasource, -} = require('../../../lib/infrastructure/datasources/learning-content/challenge-datasource'); -const { courseDatasource } = require('../../../lib/infrastructure/datasources/learning-content/course-datasource'); -const { - frameworkDatasource, -} = require('../../../lib/infrastructure/datasources/learning-content/framework-datasource'); +import { expect, learningContentBuilder, mockLearningContent } from '../../test-helper.js'; +import { areaDatasource } from '../../../lib/infrastructure/datasources/learning-content/area-datasource.js'; +import { competenceDatasource } from '../../../lib/infrastructure/datasources/learning-content/competence-datasource.js'; +import { thematicDatasource } from '../../../lib/infrastructure/datasources/learning-content/thematic-datasource.js'; +import { tubeDatasource } from '../../../lib/infrastructure/datasources/learning-content/tube-datasource.js'; +import { skillDatasource } from '../../../lib/infrastructure/datasources/learning-content/skill-datasource.js'; +import { challengeDatasource } from '../../../lib/infrastructure/datasources/learning-content/challenge-datasource.js'; +import { courseDatasource } from '../../../lib/infrastructure/datasources/learning-content/course-datasource.js'; +import { frameworkDatasource } from '../../../lib/infrastructure/datasources/learning-content/framework-datasource.js'; describe('Integration | buildLearningContent', function () { it('builds areas and frameworks', async function () { @@ -50,7 +44,7 @@ describe('Integration | buildLearningContent', function () { ]; // when - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); // then @@ -117,7 +111,7 @@ describe('Integration | buildLearningContent', function () { ]; // when - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); // then @@ -215,7 +209,7 @@ describe('Integration | buildLearningContent', function () { ]; // when - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); // then @@ -276,7 +270,7 @@ describe('Integration | buildLearningContent', function () { ]; // when - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); // then @@ -336,7 +330,7 @@ describe('Integration | buildLearningContent', function () { ]; // when - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); // then @@ -401,7 +395,7 @@ describe('Integration | buildLearningContent', function () { ]; // when - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); // then @@ -442,7 +436,7 @@ describe('Integration | buildLearningContent', function () { ]; // when - const learningContentObjects = learningContentBuilder.buildLearningContent(learningContent); + const learningContentObjects = learningContentBuilder(learningContent); mockLearningContent(learningContentObjects); // then diff --git a/api/tests/tooling/learning-content-builder/index.js b/api/tests/tooling/learning-content-builder/index.js index 958ba26886a..59d01d0cc8e 100644 --- a/api/tests/tooling/learning-content-builder/index.js +++ b/api/tests/tooling/learning-content-builder/index.js @@ -1,3 +1,3 @@ -module.exports = { - buildLearningContent: require('./build-learning-content'), -}; +import { buildLearningContent } from './build-learning-content.js'; + +export { buildLearningContent }; diff --git a/api/tests/tooling/server/http-test-server.js b/api/tests/tooling/server/http-test-server.js index 0d2b14d0f55..a4c6bbd7ede 100644 --- a/api/tests/tooling/server/http-test-server.js +++ b/api/tests/tooling/server/http-test-server.js @@ -1,8 +1,8 @@ -const Hapi = require('@hapi/hapi'); +import Hapi from '@hapi/hapi'; -const preResponseUtils = require('../../../lib/application/pre-response-utils'); -const { handleFailAction } = require('../../../lib/validate'); -const authentication = require('../../../lib/infrastructure/authentication'); +import * as preResponseUtils from '../../../lib/application/pre-response-utils.js'; +import { handleFailAction } from '../../../lib/validate.js'; +import { authentication } from '../../../lib/infrastructure/authentication.js'; const routesConfig = { routes: { @@ -62,4 +62,4 @@ class HttpTestServer { } } -module.exports = HttpTestServer; +export { HttpTestServer }; diff --git a/api/tests/tooling/temporary-file.js b/api/tests/tooling/temporary-file.js index fd4e0848980..078d4076d07 100644 --- a/api/tests/tooling/temporary-file.js +++ b/api/tests/tooling/temporary-file.js @@ -1,6 +1,6 @@ -const fs = require('fs/promises'); -const path = require('node:path'); -const os = require('os'); +import fs from 'fs/promises'; +import path from 'node:path'; +import os from 'os'; async function removeTempFile(filePath) { return ( @@ -19,7 +19,4 @@ async function createTempFile(file, data) { return filePath; } -module.exports = { - removeTempFile, - createTempFile, -}; +export { removeTempFile, createTempFile }; diff --git a/api/tests/unit/application/account-recovery/account-recovery-controller_test.js b/api/tests/unit/application/account-recovery/account-recovery-controller_test.js index 80d8c35094a..ae9c09ecd03 100644 --- a/api/tests/unit/application/account-recovery/account-recovery-controller_test.js +++ b/api/tests/unit/application/account-recovery/account-recovery-controller_test.js @@ -1,9 +1,7 @@ -const { expect, sinon, hFake, domainBuilder } = require('../../../test-helper'); - -const accountRecoveryController = require('../../../../lib/application/account-recovery/account-recovery-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const studentInformationForAccountRecoverySerializer = require('../../../../lib/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { expect, sinon, hFake, domainBuilder } from '../../../test-helper.js'; +import { accountRecoveryController } from '../../../../lib/application/account-recovery/account-recovery-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Unit | Controller | account-recovery-controller', function () { describe('#sendEmailForAccountRecovery', function () { @@ -32,14 +30,22 @@ describe('Unit | Controller | account-recovery-controller', function () { }, }; - sinon - .stub(studentInformationForAccountRecoverySerializer, 'deserialize') + sinon.stub(usecases, 'sendEmailForAccountRecovery').resolves(); + + const studentInformationForAccountRecoverySerializerStub = { + deserialize: sinon.stub(), + }; + + studentInformationForAccountRecoverySerializerStub.deserialize .withArgs(request.payload) .resolves(studentInformation); - sinon.stub(usecases, 'sendEmailForAccountRecovery').resolves(); + + const dependencies = { + studentInformationForAccountRecoverySerializer: studentInformationForAccountRecoverySerializerStub, + }; // when - const response = await accountRecoveryController.sendEmailForAccountRecovery(request, hFake); + const response = await accountRecoveryController.sendEmailForAccountRecovery(request, hFake, dependencies); // then expect(usecases.sendEmailForAccountRecovery).calledWith({ studentInformation }); diff --git a/api/tests/unit/application/admin-members/admin-member-controller_test.js b/api/tests/unit/application/admin-members/admin-member-controller_test.js index b5d636e0a24..77ee3300d4d 100644 --- a/api/tests/unit/application/admin-members/admin-member-controller_test.js +++ b/api/tests/unit/application/admin-members/admin-member-controller_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, domainBuilder, hFake } = require('../../../test-helper'); +import { expect, sinon, domainBuilder, hFake } from '../../../test-helper.js'; +import { adminMemberController } from '../../../../lib/application/admin-members/admin-member-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; -const adminMemberController = require('../../../../lib/application/admin-members/admin-member-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const adminMemberSerializer = require('../../../../lib/infrastructure/serializers/jsonapi/admin-member-serializer'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; +const { ROLES } = PIX_ADMIN; describe('Unit | Controller | admin-member-controller', function () { describe('#findAll', function () { @@ -13,10 +13,16 @@ describe('Unit | Controller | admin-member-controller', function () { const otherMember = domainBuilder.buildAdminMember(); sinon.stub(usecases, 'getAdminMembers').resolves([member, otherMember]); const serializedMembers = Symbol('serializedMembers'); - sinon.stub(adminMemberSerializer, 'serialize').withArgs([member, otherMember]).returns(serializedMembers); + const serializeStub = sinon.stub(); + serializeStub.withArgs([member, otherMember]).returns(serializedMembers); + const request = {}; + const h = {}; + + const adminMemberSerializer = { serialize: serializeStub }; + const dependencies = { adminMemberSerializer }; // when - const result = await adminMemberController.findAll(); + const result = await adminMemberController.findAll(request, h, dependencies); // then expect(usecases.getAdminMembers).to.have.been.calledOnce; @@ -28,13 +34,16 @@ describe('Unit | Controller | admin-member-controller', function () { it('should get the current admin member', async function () { // given const request = { auth: { credentials: { userId: 1 } } }; + const h = {}; const adminMemberDetails = Symbol('adminMemberDetails'); sinon.stub(usecases, 'getAdminMemberDetails').withArgs({ userId: 1 }).resolves(adminMemberDetails); const serializedUpdatedMember = Symbol('serializedUpdatedMember'); - sinon.stub(adminMemberSerializer, 'serialize').withArgs(adminMemberDetails).returns(serializedUpdatedMember); + const adminMemberSerializerStub = { serialize: sinon.stub() }; + adminMemberSerializerStub.serialize.withArgs(adminMemberDetails).returns(serializedUpdatedMember); + const dependencies = { adminMemberSerializer: adminMemberSerializerStub }; // when - const response = await adminMemberController.getCurrentAdminMember(request); + const response = await adminMemberController.getCurrentAdminMember(request, h, dependencies); // then expect(response).to.be.equal(serializedUpdatedMember); @@ -51,14 +60,22 @@ describe('Unit | Controller | admin-member-controller', function () { sinon.stub(usecases, 'updateAdminMember').withArgs({ id, role }).resolves(updatedMember); const serializedUpdatedMember = Symbol('serializedUpdatedMember'); - sinon.stub(adminMemberSerializer, 'deserialize').returns({ role }); - sinon.stub(adminMemberSerializer, 'serialize').withArgs(updatedMember).returns(serializedUpdatedMember); + const adminMemberSerializerStub = { deserialize: sinon.stub(), serialize: sinon.stub() }; + adminMemberSerializerStub.deserialize.returns({ role }); + adminMemberSerializerStub.serialize.withArgs(updatedMember).returns(serializedUpdatedMember); + + const dependencies = { adminMemberSerializer: adminMemberSerializerStub }; + const h = {}; // when - const result = await adminMemberController.updateAdminMember({ - params: { id }, - payload: { data: { attributes: { role: ROLES.SUPPORT } } }, - }); + const result = await adminMemberController.updateAdminMember( + { + params: { id }, + payload: { data: { attributes: { role: ROLES.SUPPORT } } }, + }, + h, + dependencies + ); // then expect(result).to.equal(serializedUpdatedMember); @@ -74,14 +91,17 @@ describe('Unit | Controller | admin-member-controller', function () { sinon.stub(usecases, 'deactivateAdminMember').withArgs({ id }).resolves(deactivatedMember); const serializedDeactivatedMember = Symbol('serializedDeactivatedMember'); - sinon.stub(adminMemberSerializer, 'serialize').withArgs(deactivatedMember).returns(serializedDeactivatedMember); + const adminMemberSerializerStub = { serialize: sinon.stub() }; + adminMemberSerializerStub.serialize.withArgs(deactivatedMember).returns(serializedDeactivatedMember); + const dependencies = { adminMemberSerializer: adminMemberSerializerStub }; // when const { statusCode } = await adminMemberController.deactivateAdminMember( { params: { id }, }, - hFake + hFake, + dependencies ); // then @@ -97,13 +117,18 @@ describe('Unit | Controller | admin-member-controller', function () { sinon.stub(usecases, 'saveAdminMember').withArgs(attributes).resolves(savedAdminMember); const serializedAdminMember = Symbol('serialized admin member'); - sinon.stub(adminMemberSerializer, 'deserialize').returns(attributes); - sinon.stub(adminMemberSerializer, 'serialize').withArgs(savedAdminMember).returns(serializedAdminMember); + + const adminMemberSerializerStub = { deserialize: sinon.stub(), serialize: sinon.stub() }; + adminMemberSerializerStub.deserialize.returns(attributes); + adminMemberSerializerStub.serialize.withArgs(savedAdminMember).returns(serializedAdminMember); + + const dependencies = { adminMemberSerializer: adminMemberSerializerStub }; // when const { statusCode, source } = await adminMemberController.saveAdminMember( { payload: { data: { attributes } } }, - hFake + hFake, + dependencies ); // then diff --git a/api/tests/unit/application/admin-members/index_test.js b/api/tests/unit/application/admin-members/index_test.js index 216b14d1dd5..926c0d7edeb 100644 --- a/api/tests/unit/application/admin-members/index_test.js +++ b/api/tests/unit/application/admin-members/index_test.js @@ -1,8 +1,11 @@ -const { domainBuilder, expect, sinon, HttpTestServer } = require('../../../test-helper'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; -const adminMemberController = require('../../../../lib/application/admin-members/admin-member-controller'); -const adminMembersRouter = require('../../../../lib/application/admin-members'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); +import { domainBuilder, expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; + +import { adminMemberController } from '../../../../lib/application/admin-members/admin-member-controller.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as adminMembersRouter from '../../../../lib/application/admin-members/index.js'; describe('Unit | Application | Router | admin-members-router', function () { describe('GET /api/admin/admin-members/me', function () { diff --git a/api/tests/unit/application/answers/answer-controller_test.js b/api/tests/unit/application/answers/answer-controller_test.js index a5ec0c6491c..784fd22821b 100644 --- a/api/tests/unit/application/answers/answer-controller_test.js +++ b/api/tests/unit/application/answers/answer-controller_test.js @@ -1,7 +1,6 @@ -const { expect, sinon, domainBuilder, hFake } = require('../../../test-helper'); - -const answerController = require('../../../../lib/application/answers/answer-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, domainBuilder, hFake } from '../../../test-helper.js'; +import { answerController } from '../../../../lib/application/answers/answer-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Controller | answer-controller', function () { let answerSerializerStub; diff --git a/api/tests/unit/application/answers/index_test.js b/api/tests/unit/application/answers/index_test.js index 7222fe81b9b..27479fca64c 100644 --- a/api/tests/unit/application/answers/index_test.js +++ b/api/tests/unit/application/answers/index_test.js @@ -1,7 +1,9 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const moduleUnderTest = require('../../../../lib/application/answers'); -const answerController = require('../../../../lib/application/answers/answer-controller'); -const { features } = require('../../../../lib/config'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import * as moduleUnderTest from '../../../../lib/application/answers/index.js'; +import { answerController } from '../../../../lib/application/answers/answer-controller.js'; +import { config } from '../../../../lib/config.js'; + +const { features } = config; describe('Unit | Application | Router | answer-router', function () { describe('POST /api/answers', function () { diff --git a/api/tests/unit/application/assessment-results/assessment-result-controller_test.js b/api/tests/unit/application/assessment-results/assessment-result-controller_test.js index b63764b83e3..7089a357ab2 100644 --- a/api/tests/unit/application/assessment-results/assessment-result-controller_test.js +++ b/api/tests/unit/application/assessment-results/assessment-result-controller_test.js @@ -1,9 +1,7 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); - -const assessmentResultController = require('../../../../lib/application/assessment-results/assessment-result-controller'); - -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const CompetenceMark = require('../../../../lib/domain/models/CompetenceMark'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { assessmentResultController } from '../../../../lib/application/assessment-results/assessment-result-controller.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import { CompetenceMark } from '../../../../lib/domain/models/CompetenceMark.js'; describe('Unit | Controller | assessment-results', function () { describe('#save', function () { diff --git a/api/tests/unit/application/assessment-results/index_test.js b/api/tests/unit/application/assessment-results/index_test.js index d45942e57e2..f1d49656979 100644 --- a/api/tests/unit/application/assessment-results/index_test.js +++ b/api/tests/unit/application/assessment-results/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/assessment-results'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/assessment-results/index.js'; describe('Unit | Application | Assessmnet results | Route', function () { describe('POST /api/admin/assessment-results', function () { diff --git a/api/tests/unit/application/assessments/assessment-controller-get-next-challenge_test.js b/api/tests/unit/application/assessments/assessment-controller-get-next-challenge_test.js index b1e6bd02dc5..295cdb524ed 100644 --- a/api/tests/unit/application/assessments/assessment-controller-get-next-challenge_test.js +++ b/api/tests/unit/application/assessments/assessment-controller-get-next-challenge_test.js @@ -1,8 +1,10 @@ -const { sinon, expect, domainBuilder, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const assessmentController = require('../../../../lib/application/assessments/assessment-controller'); -const { AssessmentEndedError } = require('../../../../lib/domain/errors'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { FRENCH_FRANCE, FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { sinon, expect, domainBuilder, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { assessmentController } from '../../../../lib/application/assessments/assessment-controller.js'; +import { AssessmentEndedError } from '../../../../lib/domain/errors.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_FRANCE, FRENCH_SPOKEN } = LOCALE; describe('Unit | Controller | assessment-controller-get-next-challenge', function () { describe('#getNextChallenge', function () { diff --git a/api/tests/unit/application/assessments/assessment-controller-save_test.js b/api/tests/unit/application/assessments/assessment-controller-save_test.js index 7edc88a54da..85e870d8de2 100644 --- a/api/tests/unit/application/assessments/assessment-controller-save_test.js +++ b/api/tests/unit/application/assessments/assessment-controller-save_test.js @@ -1,8 +1,6 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); - -const controller = require('../../../../lib/application/assessments/assessment-controller'); - -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { assessmentController as controller } from '../../../../lib/application/assessments/assessment-controller.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Unit | Controller | assessment-controller-save', function () { describe('#save', function () { diff --git a/api/tests/unit/application/assessments/assessment-controller_test.js b/api/tests/unit/application/assessments/assessment-controller_test.js index 39d777c8e28..17d04aba0f5 100644 --- a/api/tests/unit/application/assessments/assessment-controller_test.js +++ b/api/tests/unit/application/assessments/assessment-controller_test.js @@ -1,9 +1,9 @@ -const { sinon, expect, hFake, domainBuilder } = require('../../../test-helper'); -const assessmentController = require('../../../../lib/application/assessments/assessment-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const events = require('../../../../lib/domain/events/index.js'); -const AssessmentCompleted = require('../../../../lib/domain/events/AssessmentCompleted'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { sinon, expect, hFake, domainBuilder } from '../../../test-helper.js'; +import { assessmentController } from '../../../../lib/application/assessments/assessment-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import * as events from '../../../../lib/domain/events/index.js'; +import { AssessmentCompleted } from '../../../../lib/domain/events/AssessmentCompleted.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Unit | Controller | assessment-controller', function () { describe('#get', function () { diff --git a/api/tests/unit/application/assessments/index_test.js b/api/tests/unit/application/assessments/index_test.js index b0bb96ad750..ee8922979de 100644 --- a/api/tests/unit/application/assessments/index_test.js +++ b/api/tests/unit/application/assessments/index_test.js @@ -1,9 +1,9 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const settings = require('../../../../lib/config'); -const assessmentAuthorization = require('../../../../lib/application/preHandlers/assessment-authorization'); -const moduleUnderTest = require('../../../../lib/application/assessments'); -const assessmentController = require('../../../../lib/application/assessments/assessment-controller'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { config as settings } from '../../../../lib/config.js'; +import { assessmentAuthorization } from '../../../../lib/application/preHandlers/assessment-authorization.js'; +import { assessmentController } from '../../../../lib/application/assessments/assessment-controller.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/assessments/index.js'; describe('Unit | Application | Router | assessment-router', function () { describe('POST /api/assessments', function () { diff --git a/api/tests/unit/application/authentication/authentication-controller_test.js b/api/tests/unit/application/authentication/authentication-controller_test.js index 49655301b24..c6a3da64956 100644 --- a/api/tests/unit/application/authentication/authentication-controller_test.js +++ b/api/tests/unit/application/authentication/authentication-controller_test.js @@ -1,7 +1,6 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); - -const authenticationController = require('../../../../lib/application/authentication/authentication-controller'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { authenticationController } from '../../../../lib/application/authentication/authentication-controller.js'; describe('Unit | Application | Controller | Authentication', function () { describe('#createToken', function () { diff --git a/api/tests/unit/application/authentication/oidc/oidc-controller_test.js b/api/tests/unit/application/authentication/oidc/oidc-controller_test.js index 3b202d3bb21..05c519fa4c5 100644 --- a/api/tests/unit/application/authentication/oidc/oidc-controller_test.js +++ b/api/tests/unit/application/authentication/oidc/oidc-controller_test.js @@ -1,7 +1,7 @@ -const { sinon, expect, hFake, catchErr, domainBuilder } = require('../../../../test-helper'); -const oidcController = require('../../../../../lib/application/authentication/oidc/oidc-controller'); -const usecases = require('../../../../../lib/domain/usecases/index.js'); -const { UnauthorizedError } = require('../../../../../lib/application/http-errors'); +import { sinon, expect, hFake, catchErr, domainBuilder } from '../../../../test-helper.js'; +import { oidcController } from '../../../../../lib/application/authentication/oidc/oidc-controller.js'; +import { usecases } from '../../../../../lib/domain/usecases/index.js'; +import { UnauthorizedError } from '../../../../../lib/application/http-errors.js'; describe('Unit | Application | Controller | Authentication | OIDC', function () { const identityProvider = 'OIDC'; diff --git a/api/tests/unit/application/badges/index_test.js b/api/tests/unit/application/badges/index_test.js index a347c852d78..9aa2823e1e6 100644 --- a/api/tests/unit/application/badges/index_test.js +++ b/api/tests/unit/application/badges/index_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, HttpTestServer } = require('../../../test-helper'); -const badgesController = require('../../../../lib/application/badges/badges-controller'); -const badgesRouter = require('../../../../lib/application/badges'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); +import { expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { badgesController } from '../../../../lib/application/badges/badges-controller.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as badgesRouter from '../../../../lib/application/badges/index.js'; describe('Unit | Application | Badges | Routes', function () { describe('DELETE /api/admin/badges/{id}', function () { diff --git a/api/tests/unit/application/cache/cache-controller_test.js b/api/tests/unit/application/cache/cache-controller_test.js index c975b983fd4..128c816eb9c 100644 --- a/api/tests/unit/application/cache/cache-controller_test.js +++ b/api/tests/unit/application/cache/cache-controller_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const cacheController = require('../../../../lib/application/cache/cache-controller'); -const learningContentDatasources = require('../../../../lib/infrastructure/datasources/learning-content'); -const logger = require('../../../../lib/infrastructure/logger'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { cacheController } from '../../../../lib/application/cache/cache-controller.js'; +import * as learningContentDatasources from '../../../../lib/infrastructure/datasources/learning-content/index.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; describe('Unit | Controller | cache-controller', function () { describe('#refreshCacheEntry', function () { diff --git a/api/tests/unit/application/cache/index_test.js b/api/tests/unit/application/cache/index_test.js index bb79f659298..83d3780cd19 100644 --- a/api/tests/unit/application/cache/index_test.js +++ b/api/tests/unit/application/cache/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/cache'); -const cacheController = require('../../../../lib/application/cache/cache-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { cacheController } from '../../../../lib/application/cache/cache-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/cache/index.js'; describe('Unit | Router | cache-router', function () { describe('PATCH /api/cache/{model}/{id}', function () { diff --git a/api/tests/unit/application/campaign-participations/campaign-participation-controller_test.js b/api/tests/unit/application/campaign-participations/campaign-participation-controller_test.js index 28c965ed6bd..6055baf5e49 100644 --- a/api/tests/unit/application/campaign-participations/campaign-participation-controller_test.js +++ b/api/tests/unit/application/campaign-participations/campaign-participation-controller_test.js @@ -1,11 +1,13 @@ -const { sinon, expect, domainBuilder, hFake } = require('../../../test-helper'); -const campaignParticipationController = require('../../../../lib/application/campaign-participations/campaign-participation-controller'); -const events = require('../../../../lib/domain/events/index.js'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const CampaignParticipationResultsShared = require('../../../../lib/domain/events/CampaignParticipationResultsShared'); -const CampaignParticipationStarted = require('../../../../lib/domain/events/CampaignParticipationStarted'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { sinon, expect, domainBuilder, hFake } from '../../../test-helper.js'; +import { campaignParticipationController } from '../../../../lib/application/campaign-participations/campaign-participation-controller.js'; +import * as events from '../../../../lib/domain/events/index.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CampaignParticipationResultsShared } from '../../../../lib/domain/events/CampaignParticipationResultsShared.js'; +import { CampaignParticipationStarted } from '../../../../lib/domain/events/CampaignParticipationStarted.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_SPOKEN } = LOCALE; describe('Unit | Application | Controller | Campaign-Participation', function () { describe('#shareCampaignResult', function () { diff --git a/api/tests/unit/application/campaign-participations/index_test.js b/api/tests/unit/application/campaign-participations/index_test.js index d3e8b579349..d6243159224 100644 --- a/api/tests/unit/application/campaign-participations/index_test.js +++ b/api/tests/unit/application/campaign-participations/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); - -const moduleUnderTest = require('../../../../lib/application/campaign-participations'); -const campaignParticipationController = require('../../../../lib/application/campaign-participations/campaign-participation-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { campaignParticipationController } from '../../../../lib/application/campaign-participations/campaign-participation-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/campaign-participations/index.js'; describe('Unit | Application | Router | campaign-participation-router ', function () { describe('POST /api/campaign-participations', function () { diff --git a/api/tests/unit/application/campaign/campaign-controller_test.js b/api/tests/unit/application/campaign/campaign-controller_test.js index 26a3620259b..7c3ed13c973 100644 --- a/api/tests/unit/application/campaign/campaign-controller_test.js +++ b/api/tests/unit/application/campaign/campaign-controller_test.js @@ -1,10 +1,10 @@ -const { sinon, expect, domainBuilder, hFake, catchErr } = require('../../../test-helper'); +import { sinon, expect, domainBuilder, hFake, catchErr } from '../../../test-helper.js'; +import { campaignController } from '../../../../lib/application/campaigns/campaign-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToAccessEntityError, ForbiddenAccess } from '../../../../lib/domain/errors.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; -const campaignController = require('../../../../lib/application/campaigns/campaign-controller'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); -const { UserNotAuthorizedToAccessEntityError, ForbiddenAccess } = require('../../../../lib/domain/errors'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +const { FRENCH_SPOKEN } = LOCALE; describe('Unit | Application | Controller | Campaign', function () { describe('#save', function () { diff --git a/api/tests/unit/application/campaign/index_test.js b/api/tests/unit/application/campaign/index_test.js index e087684c75d..d2692261715 100644 --- a/api/tests/unit/application/campaign/index_test.js +++ b/api/tests/unit/application/campaign/index_test.js @@ -1,10 +1,10 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const moduleUnderTest = require('../../../../lib/application/campaigns'); -const campaignController = require('../../../../lib/application/campaigns/campaign-controller'); -const campaignStatsController = require('../../../../lib/application/campaigns/campaign-stats-controller'); -const campaignManagementController = require('../../../../lib/application/campaigns/campaign-management-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { campaignController } from '../../../../lib/application/campaigns/campaign-controller.js'; +import { campaignStatsController } from '../../../../lib/application/campaigns/campaign-stats-controller.js'; +import { campaignManagementController } from '../../../../lib/application/campaigns/campaign-management-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/campaigns/index.js'; describe('Unit | Application | Router | campaign-router ', function () { describe('POST /api/campaigns', function () { diff --git a/api/tests/unit/application/campaigns-administration/campaign-controller_test.js b/api/tests/unit/application/campaigns-administration/campaign-controller_test.js index 6a713fff248..3841eae9839 100644 --- a/api/tests/unit/application/campaigns-administration/campaign-controller_test.js +++ b/api/tests/unit/application/campaigns-administration/campaign-controller_test.js @@ -1,13 +1,12 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); - -const campaignController = require('../../../../lib/application/campaigns-administration/campaign-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { campaignController } from '../../../../lib/application/campaigns-administration/campaign-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Application | Controller | Campaign Administration', function () { describe('#archiveCampaigns', function () { let csvCampaignsIdsParserStub; beforeEach(function () { - sinon.stub(usecases, 'campaignAdministrationArchiveCampaign'); + sinon.stub(usecases, 'archiveCampaigns'); csvCampaignsIdsParserStub = { extractCampaignsIds: sinon.stub() }; }); @@ -19,7 +18,7 @@ describe('Unit | Application | Controller | Campaign Administration', function ( const request = { auth: { credentials: { userId } }, payload: path }; csvCampaignsIdsParserStub.extractCampaignsIds.withArgs(path).returns(ids); - usecases.campaignAdministrationArchiveCampaign.withArgs({ userId, ids }); + usecases.archiveCampaigns.withArgs({ userId, ids }); // when const response = await campaignController.archiveCampaigns(request, hFake, { diff --git a/api/tests/unit/application/campaigns-administration/index_test.js b/api/tests/unit/application/campaigns-administration/index_test.js index 08ae0cdd0b9..2e01eb45165 100644 --- a/api/tests/unit/application/campaigns-administration/index_test.js +++ b/api/tests/unit/application/campaigns-administration/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const campaignController = require('../../../../lib/application/campaigns-administration/campaign-controller'); - -const moduleUnderTest = require('../../../../lib/application/campaigns-administration'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { campaignController } from '../../../../lib/application/campaigns-administration/campaign-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/campaigns-administration/index.js'; describe('Unit | Application | Router | campaign-participation-router ', function () { describe('PATCH /api/admin/campaigns/archive-campaigns', function () { diff --git a/api/tests/unit/application/certification-candidates/certification-candidates-controller_test.js b/api/tests/unit/application/certification-candidates/certification-candidates-controller_test.js index fbd1b6d3f84..6c7ed142ab5 100644 --- a/api/tests/unit/application/certification-candidates/certification-candidates-controller_test.js +++ b/api/tests/unit/application/certification-candidates/certification-candidates-controller_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const certificationCandidateController = require('../../../../lib/application/certification-candidates/certification-candidates-controller'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { certificationCandidatesController } from '../../../../lib/application/certification-candidates/certification-candidates-controller.js'; describe('Unit | Controller | certifications-candidate-controller', function () { describe('#authorizeToStart', function () { @@ -25,7 +25,7 @@ describe('Unit | Controller | certifications-candidate-controller', function () .resolves(); // when - const response = await certificationCandidateController.authorizeToStart(request, hFake); + const response = await certificationCandidatesController.authorizeToStart(request, hFake); // then expect(response.statusCode).to.equal(204); @@ -52,30 +52,29 @@ describe('Unit | Controller | certifications-candidate-controller', function () .resolves(); // when - const response = await certificationCandidateController.authorizeToResume(request, hFake); + const response = await certificationCandidatesController.authorizeToResume(request, hFake); // then expect(response.statusCode).to.equal(204); }); }); -}); - -describe('#endAssessmentBySupervisor', function () { - const certificationCandidateId = 2; + describe('#endAssessmentBySupervisor', function () { + const certificationCandidateId = 2; - it('should call the endAssessmentBySupervisor use case', async function () { - // given - sinon.stub(usecases, 'endAssessmentBySupervisor'); - usecases.endAssessmentBySupervisor.resolves(); + it('should call the endAssessmentBySupervisor use case', async function () { + // given + sinon.stub(usecases, 'endAssessmentBySupervisor'); + usecases.endAssessmentBySupervisor.resolves(); - // when - await certificationCandidateController.endAssessmentBySupervisor({ - params: { id: certificationCandidateId }, - }); + // when + await certificationCandidatesController.endAssessmentBySupervisor({ + params: { id: certificationCandidateId }, + }); - // then - expect(usecases.endAssessmentBySupervisor).to.have.been.calledWithExactly({ - certificationCandidateId, + // then + expect(usecases.endAssessmentBySupervisor).to.have.been.calledWithExactly({ + certificationCandidateId, + }); }); }); }); diff --git a/api/tests/unit/application/certification-candidates/index_test.js b/api/tests/unit/application/certification-candidates/index_test.js index a90fc708fd6..5bcf16e057e 100644 --- a/api/tests/unit/application/certification-candidates/index_test.js +++ b/api/tests/unit/application/certification-candidates/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/certification-candidates'); -const sessionSupervisorAuthorization = require('../../../../lib/application/preHandlers/session-supervisor-authorization'); -const certificationCandidatesController = require('../../../../lib/application/certification-candidates/certification-candidates-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import * as moduleUnderTest from '../../../../lib/application/certification-candidates/index.js'; +import { certificationCandidatesController } from '../../../../lib/application/certification-candidates/certification-candidates-controller.js'; +import { assessmentSupervisorAuthorization as sessionSupervisorAuthorization } from '../../../../lib/application/preHandlers/session-supervisor-authorization.js'; describe('Unit | Application | CertificationCandidates | Routes', function () { describe('GET certification-candidates/{id}/authorize-to-start', function () { diff --git a/api/tests/unit/application/certification-center-invitations/certification-center-invitation-controller_test.js b/api/tests/unit/application/certification-center-invitations/certification-center-invitation-controller_test.js index 573feb0a846..2b6f0aca4dc 100644 --- a/api/tests/unit/application/certification-center-invitations/certification-center-invitation-controller_test.js +++ b/api/tests/unit/application/certification-center-invitations/certification-center-invitation-controller_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, hFake, domainBuilder } = require('../../../test-helper'); -const certificationCenterInvitationController = require('../../../../lib/application/certification-center-invitations/certification-center-invitation-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); +import { expect, sinon, hFake, domainBuilder } from '../../../test-helper.js'; +import { certificationCenterInvitationController } from '../../../../lib/application/certification-center-invitations/certification-center-invitation-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; describe('Unit | Application | Certification-center-Invitations | Certification-center-invitation-controller', function () { describe('#acceptCertificationCenterInvitation', function () { diff --git a/api/tests/unit/application/certification-centers/certification-center-controller_test.js b/api/tests/unit/application/certification-centers/certification-center-controller_test.js index 7acefdd3fa7..28a115ab20f 100644 --- a/api/tests/unit/application/certification-centers/certification-center-controller_test.js +++ b/api/tests/unit/application/certification-centers/certification-center-controller_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, domainBuilder, hFake } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const Session = require('../../../../lib/domain/models/Session'); - -const certificationCenterController = require('../../../../lib/application/certification-centers/certification-center-controller'); +import { expect, sinon, domainBuilder, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Session } from '../../../../lib/domain/models/Session.js'; +import { certificationCenterController } from '../../../../lib/application/certification-centers/certification-center-controller.js'; describe('Unit | Controller | certifications-center-controller', function () { describe('#saveSession', function () { diff --git a/api/tests/unit/application/certification-centers/index_test.js b/api/tests/unit/application/certification-centers/index_test.js index 3ee5da93cf7..08c94070292 100644 --- a/api/tests/unit/application/certification-centers/index_test.js +++ b/api/tests/unit/application/certification-centers/index_test.js @@ -1,13 +1,16 @@ -const { writeFile, stat, unlink } = require('fs').promises; +import fs from 'fs'; +import { writeFile, stat, unlink } from 'fs/promises'; -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { certificationCenterController } from '../../../../lib/application/certification-centers/certification-center-controller.js'; -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/certification-centers'); -const certificationCenterController = require('../../../../lib/application/certification-centers/certification-center-controller'); -const FormData = require('form-data'); -const fs = require('fs'); -const streamToPromise = require('stream-to-promise'); +import * as moduleUnderTest from '../../../../lib/application/certification-centers/index.js'; +import FormData from 'form-data'; +import streamToPromise from 'stream-to-promise'; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Unit | Router | certification-center-router', function () { describe('POST /api/certification-centers/{certificationCenterId}/session', function () { diff --git a/api/tests/unit/application/certification-courses/certification-course-controller_test.js b/api/tests/unit/application/certification-courses/certification-course-controller_test.js index c1e128281a1..413e9c149de 100644 --- a/api/tests/unit/application/certification-courses/certification-course-controller_test.js +++ b/api/tests/unit/application/certification-courses/certification-course-controller_test.js @@ -1,15 +1,9 @@ -const { - sinon, - expect, - hFake, - generateValidRequestAuthorizationHeader, - domainBuilder, -} = require('../../../test-helper'); -const certificationCourseController = require('../../../../lib/application/certification-courses/certification-course-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); - -const CertificationCourse = require('../../../../lib/domain/models/CertificationCourse'); +import { sinon, expect, hFake, generateValidRequestAuthorizationHeader, domainBuilder } from '../../../test-helper.js'; + +import { certificationCourseController } from '../../../../lib/application/certification-courses/certification-course-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { CertificationCourse } from '../../../../lib/domain/models/CertificationCourse.js'; describe('Unit | Controller | certification-course-controller', function () { let certificationDetailsSerializer; diff --git a/api/tests/unit/application/certification-courses/index_test.js b/api/tests/unit/application/certification-courses/index_test.js index fd8755c8050..24636122f6e 100644 --- a/api/tests/unit/application/certification-courses/index_test.js +++ b/api/tests/unit/application/certification-courses/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/certification-courses'); -const certificationCoursesController = require('../../../../lib/application/certification-courses/certification-course-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { certificationCourseController as certificationCoursesController } from '../../../../lib/application/certification-courses/certification-course-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/certification-courses/index.js'; describe('Unit | Application | Certifications Course | Route', function () { describe('GET /api/admin/certifications/{id}/details', function () { diff --git a/api/tests/unit/application/certification-issue-reports/certification-issue-report-controller_test.js b/api/tests/unit/application/certification-issue-reports/certification-issue-report-controller_test.js index 08a027a11f6..f7b7c5bd86f 100644 --- a/api/tests/unit/application/certification-issue-reports/certification-issue-report-controller_test.js +++ b/api/tests/unit/application/certification-issue-reports/certification-issue-report-controller_test.js @@ -1,6 +1,6 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); -const certificationIssueReportController = require('../../../../lib/application/certification-issue-reports/certification-issue-report-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { certificationIssueReportController } from '../../../../lib/application/certification-issue-reports/certification-issue-report-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Controller | certification-issue-report-controller', function () { describe('#deleteCertificationIssueReport', function () { diff --git a/api/tests/unit/application/certification-issue-reports/index_test.js b/api/tests/unit/application/certification-issue-reports/index_test.js index 24767251dd6..c06c44708f4 100644 --- a/api/tests/unit/application/certification-issue-reports/index_test.js +++ b/api/tests/unit/application/certification-issue-reports/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const certificationIssueReportController = require('../../../../lib/application/certification-issue-reports/certification-issue-report-controller'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/certification-issue-reports'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { certificationIssueReportController } from '../../../../lib/application/certification-issue-reports/certification-issue-report-controller.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/certification-issue-reports/index.js'; describe('Unit | Application | Certifications Issue Report | Route', function () { describe('DELETE /api/certification-issue-reports/{id}', function () { diff --git a/api/tests/unit/application/certification-point-of-contacts/certification-point-of-contact-controller_test.js b/api/tests/unit/application/certification-point-of-contacts/certification-point-of-contact-controller_test.js index 9ec296b0f58..30ce64eda4d 100644 --- a/api/tests/unit/application/certification-point-of-contacts/certification-point-of-contact-controller_test.js +++ b/api/tests/unit/application/certification-point-of-contacts/certification-point-of-contact-controller_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, hFake } = require('../../../test-helper'); -const certificationPointOfContactController = require('../../../../lib/application/certification-point-of-contacts/certification-point-of-contact-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, domainBuilder, hFake } from '../../../test-helper.js'; +import { certificationPointOfContactController } from '../../../../lib/application/certification-point-of-contacts/certification-point-of-contact-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Controller | certifications-point-of-contact-controller', function () { describe('#get', function () { diff --git a/api/tests/unit/application/certification-point-of-contacts/index_test.js b/api/tests/unit/application/certification-point-of-contacts/index_test.js index 50cd1c17df9..f0bd8fde193 100644 --- a/api/tests/unit/application/certification-point-of-contacts/index_test.js +++ b/api/tests/unit/application/certification-point-of-contacts/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/certification-point-of-contacts'); -const certificationPointOfContactController = require('../../../../lib/application/certification-point-of-contacts/certification-point-of-contact-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { certificationPointOfContactController } from '../../../../lib/application/certification-point-of-contacts/certification-point-of-contact-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/certification-point-of-contacts/index.js'; describe('Unit | Router | certification-point-of-contact-router', function () { describe('GET /api/certification-point-of-contacts/me', function () { diff --git a/api/tests/unit/application/certification-report/certification-report-controller_test.js b/api/tests/unit/application/certification-report/certification-report-controller_test.js index 55a26467c60..1ee9a41760e 100644 --- a/api/tests/unit/application/certification-report/certification-report-controller_test.js +++ b/api/tests/unit/application/certification-report/certification-report-controller_test.js @@ -1,6 +1,6 @@ -const { sinon, expect, hFake, domainBuilder } = require('../../../test-helper'); -const certificationReportController = require('../../../../lib/application/certification-reports/certification-report-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { sinon, expect, hFake, domainBuilder } from '../../../test-helper.js'; +import { certificationReportController } from '../../../../lib/application/certification-reports/certification-report-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Controller | certification-report-controller', function () { describe('#saveCertificationIssueReport', function () { diff --git a/api/tests/unit/application/certification-report/index_test.js b/api/tests/unit/application/certification-report/index_test.js index 7522270b587..be30b2506c7 100644 --- a/api/tests/unit/application/certification-report/index_test.js +++ b/api/tests/unit/application/certification-report/index_test.js @@ -1,9 +1,9 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const certificationReportController = require('../../../../lib/application/certification-reports/certification-report-controller'); -const { NotFoundError } = require('../../../../lib/application/http-errors'); -const authorization = require('../../../../lib/application/preHandlers/authorization'); -const moduleUnderTest = require('../../../../lib/application/certification-reports'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { certificationReportController } from '../../../../lib/application/certification-reports/certification-report-controller.js'; +import { NotFoundError } from '../../../../lib/application/http-errors.js'; +import { authorization } from '../../../../lib/application/preHandlers/authorization.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/certification-reports/index.js'; describe('Unit | Application | Certifications Report | Route', function () { describe('POST /api/certification-reports/{id}/certification-issue-reports', function () { diff --git a/api/tests/unit/application/certifications/certification-controller_test.js b/api/tests/unit/application/certifications/certification-controller_test.js index 45987e65c14..fc634b66b32 100644 --- a/api/tests/unit/application/certifications/certification-controller_test.js +++ b/api/tests/unit/application/certifications/certification-controller_test.js @@ -1,9 +1,8 @@ -const { expect, sinon, domainBuilder, hFake } = require('../../../test-helper'); - -const certificationController = require('../../../../lib/application/certifications/certification-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const ChallengeNeutralized = require('../../../../lib/domain/events/ChallengeNeutralized'); -const ChallengeDeneutralized = require('../../../../lib/domain/events/ChallengeDeneutralized'); +import { expect, sinon, domainBuilder, hFake } from '../../../test-helper.js'; +import { certificationController } from '../../../../lib/application/certifications/certification-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { ChallengeNeutralized } from '../../../../lib/domain/events/ChallengeNeutralized.js'; +import { ChallengeDeneutralized } from '../../../../lib/domain/events/ChallengeDeneutralized.js'; describe('Unit | Controller | certifications-controller', function () { describe('#findUserCertifications', function () { diff --git a/api/tests/unit/application/certifications/index_test.js b/api/tests/unit/application/certifications/index_test.js index 5a4f7f4d426..d135cdec5c4 100644 --- a/api/tests/unit/application/certifications/index_test.js +++ b/api/tests/unit/application/certifications/index_test.js @@ -1,8 +1,7 @@ -const { sinon, expect, HttpTestServer } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); - -const certificationController = require('../../../../lib/application/certifications/certification-controller'); -const moduleUnderTest = require('../../../../lib/application/certifications'); +import { sinon, expect, HttpTestServer } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { certificationController } from '../../../../lib/application/certifications/certification-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/certifications/index.js'; describe('Unit | Application | Certification | Routes', function () { context('POST /api/admin/certification/neutralize-challenge', function () { diff --git a/api/tests/unit/application/challenges/challenge-controller_test.js b/api/tests/unit/application/challenges/challenge-controller_test.js index 3ad2287c5b6..dc29a9b6d42 100644 --- a/api/tests/unit/application/challenges/challenge-controller_test.js +++ b/api/tests/unit/application/challenges/challenge-controller_test.js @@ -1,6 +1,5 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); - -const challengeController = require('../../../../lib/application/challenges/challenge-controller'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { challengeController } from '../../../../lib/application/challenges/challenge-controller.js'; describe('Unit | Controller | challenge-controller', function () { let challengeRepository; diff --git a/api/tests/unit/application/challenges/index_test.js b/api/tests/unit/application/challenges/index_test.js index 761cef16bae..0dbb9e29c42 100644 --- a/api/tests/unit/application/challenges/index_test.js +++ b/api/tests/unit/application/challenges/index_test.js @@ -1,6 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const challengeController = require('../../../../lib/application/challenges/challenge-controller'); -const moduleUnderTest = require('../../../../lib/application/challenges'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { challengeController } from '../../../../lib/application/challenges/challenge-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/challenges/index.js'; describe('Unit | Router | challenge-router', function () { describe('GET /api/challenges/{id}', function () { diff --git a/api/tests/unit/application/competence-evaluations/competence-evaluation-controller_test.js b/api/tests/unit/application/competence-evaluations/competence-evaluation-controller_test.js index 08443a3408d..b3f23c22bba 100644 --- a/api/tests/unit/application/competence-evaluations/competence-evaluation-controller_test.js +++ b/api/tests/unit/application/competence-evaluations/competence-evaluation-controller_test.js @@ -1,6 +1,6 @@ -const { sinon, expect, domainBuilder, hFake } = require('../../../test-helper'); -const competenceEvaluationController = require('../../../../lib/application/competence-evaluations/competence-evaluation-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { sinon, expect, domainBuilder, hFake } from '../../../test-helper.js'; +import { competenceEvaluationController } from '../../../../lib/application/competence-evaluations/competence-evaluation-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Application | Controller | Competence-Evaluation', function () { describe('#startOrResume', function () { diff --git a/api/tests/unit/application/complementary-certification-course-results/index_test.js b/api/tests/unit/application/complementary-certification-course-results/index_test.js index bd5e0707c82..3fbe5bfb7aa 100644 --- a/api/tests/unit/application/complementary-certification-course-results/index_test.js +++ b/api/tests/unit/application/complementary-certification-course-results/index_test.js @@ -1,6 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/complementary-certification-course-results'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/complementary-certification-course-results/index.js'; describe('Unit | Application | Complementary Certification Course Results | Route', function () { describe('POST /api/admin/complementary-certification-course-results', function () { diff --git a/api/tests/unit/application/complementary-certifications/index_test.js b/api/tests/unit/application/complementary-certifications/index_test.js index cc9f23df70e..73983fa8e54 100644 --- a/api/tests/unit/application/complementary-certifications/index_test.js +++ b/api/tests/unit/application/complementary-certifications/index_test.js @@ -1,7 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const moduleUnderTest = require('../../../../lib/application/complementary-certifications'); -const complementaryCertificationController = require('../../../../lib/application/complementary-certifications/complementary-certification-controller'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { complementaryCertificationController } from '../../../../lib/application/complementary-certifications/complementary-certification-controller.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/complementary-certifications/index.js'; describe('Unit | Application | Router | complementary-certifications-router', function () { describe('GET /api/habilitations', function () { diff --git a/api/tests/unit/application/countries/country-controller_test.js b/api/tests/unit/application/countries/country-controller_test.js index d48c788e7da..8db9c6e9f95 100644 --- a/api/tests/unit/application/countries/country-controller_test.js +++ b/api/tests/unit/application/countries/country-controller_test.js @@ -1,14 +1,7 @@ -const { - expect, - hFake, - sinon, - generateValidRequestAuthorizationHeader, - domainBuilder, -} = require('../../../test-helper'); +import { expect, hFake, sinon, generateValidRequestAuthorizationHeader, domainBuilder } from '../../../test-helper.js'; -const usecases = require('../../../../lib/domain/usecases/index.js'); - -const countryController = require('../../../../lib/application/countries/country-controller'); +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { countryController } from '../../../../lib/application/countries/country-controller.js'; describe('Unit | Controller | country-controller', function () { describe('#findCountries', function () { diff --git a/api/tests/unit/application/countries/index_test.js b/api/tests/unit/application/countries/index_test.js index 91fc0731d51..d2174f280d3 100644 --- a/api/tests/unit/application/countries/index_test.js +++ b/api/tests/unit/application/countries/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/countries'); -const countryController = require('../../../../lib/application/countries/country-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { countryController } from '../../../../lib/application/countries/country-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/countries/index.js'; describe('Unit | Router | country-router', function () { describe('GET /api/countries', function () { diff --git a/api/tests/unit/application/courses/course-controller_test.js b/api/tests/unit/application/courses/course-controller_test.js index 8c45b79d733..3bc237e9f7b 100644 --- a/api/tests/unit/application/courses/course-controller_test.js +++ b/api/tests/unit/application/courses/course-controller_test.js @@ -1,8 +1,6 @@ -const { expect, hFake, sinon, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); - -const Course = require('../../../../lib/domain/models/Course'); - -const courseController = require('../../../../lib/application/courses/course-controller'); +import { expect, hFake, sinon, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { Course } from '../../../../lib/domain/models/Course.js'; +import { courseController } from '../../../../lib/application/courses/course-controller.js'; describe('Unit | Controller | course-controller', function () { let courseServiceStub; diff --git a/api/tests/unit/application/courses/index_test.js b/api/tests/unit/application/courses/index_test.js index bbb3be8a306..7a78a95a8b1 100644 --- a/api/tests/unit/application/courses/index_test.js +++ b/api/tests/unit/application/courses/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/courses'); -const courseController = require('../../../../lib/application/courses/course-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { courseController } from '../../../../lib/application/courses/course-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/courses/index.js'; describe('Unit | Router | course-router', function () { describe('GET /api/courses/{id}', function () { diff --git a/api/tests/unit/application/error-manager_test.js b/api/tests/unit/application/error-manager_test.js index 0fa6b43ce0f..a0eb012ef9d 100644 --- a/api/tests/unit/application/error-manager_test.js +++ b/api/tests/unit/application/error-manager_test.js @@ -1,6 +1,6 @@ -const { expect, hFake, sinon } = require('../../test-helper'); +import { expect, hFake, sinon } from '../../test-helper.js'; -const { +import { AccountRecoveryDemandExpired, AdminMemberError, AlreadyRegisteredEmailAndUsernameError, @@ -40,11 +40,11 @@ const { SendingEmailToInvalidEmailAddressError, LocaleFormatError, LocaleNotSupportedError, -} = require('../../../lib/domain/errors'); -const { HttpErrors } = require('../../../lib/application/http-errors.js'); +} from '../../../lib/domain/errors.js'; -const { handle } = require('../../../lib/application/error-manager'); -const { SESSION_SUPERVISING } = require('../../../lib/domain/constants/session-supervising'); +import { HttpErrors } from '../../../lib/application/http-errors.js'; +import { handle } from '../../../lib/application/error-manager.js'; +import { SESSION_SUPERVISING } from '../../../lib/domain/constants/session-supervising.js'; describe('Unit | Application | ErrorManager', function () { describe('#handle', function () { diff --git a/api/tests/unit/application/errors_test.js b/api/tests/unit/application/errors_test.js index 74a68b41ee3..502a3a18c55 100644 --- a/api/tests/unit/application/errors_test.js +++ b/api/tests/unit/application/errors_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../test-helper'); -const { BaseHttpError, MissingQueryParamError } = require('../../../lib/application/http-errors'); +import { expect } from '../../test-helper.js'; +import { BaseHttpError, MissingQueryParamError } from '../../../lib/application/http-errors.js'; describe('Unit | Application | HTTP Errors', function () { describe('#BaseHttpError', function () { diff --git a/api/tests/unit/application/feedbacks/feedback-controller_test.js b/api/tests/unit/application/feedbacks/feedback-controller_test.js index b1177518a68..0907ee020ed 100644 --- a/api/tests/unit/application/feedbacks/feedback-controller_test.js +++ b/api/tests/unit/application/feedbacks/feedback-controller_test.js @@ -1,10 +1,11 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; -const { cloneDeep } = require('lodash'); +import lodash from 'lodash'; -const Feedback = require('../../../../lib/infrastructure/orm-models/Feedback'); +const { cloneDeep } = lodash; -const moduleUnderTest = require('../../../../lib/application/feedbacks'); +import { Feedback } from '../../../../lib/infrastructure/orm-models/Feedback.js'; +import * as moduleUnderTest from '../../../../lib/application/feedbacks/index.js'; describe('Unit | Controller | feedback-controller', function () { let httpTestServer; diff --git a/api/tests/unit/application/feedbacks/index_test.js b/api/tests/unit/application/feedbacks/index_test.js index 18f7b4719fc..7262c2c7164 100644 --- a/api/tests/unit/application/feedbacks/index_test.js +++ b/api/tests/unit/application/feedbacks/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/feedbacks'); -const feedbackController = require('../../../../lib/application/feedbacks/feedback-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { feedbackController } from '../../../../lib/application/feedbacks/feedback-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/feedbacks/index.js'; describe('Unit | Router | feedback-router', function () { describe('POST /api/feedbacks', function () { diff --git a/api/tests/unit/application/frameworks/frameworks-controller_test.js b/api/tests/unit/application/frameworks/frameworks-controller_test.js index 4a003c3ebe8..b3d3afc02fe 100644 --- a/api/tests/unit/application/frameworks/frameworks-controller_test.js +++ b/api/tests/unit/application/frameworks/frameworks-controller_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const frameworksController = require('../../../../lib/application/frameworks/frameworks-controller'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { frameworksController } from '../../../../lib/application/frameworks/frameworks-controller.js'; describe('Unit | Controller | frameworks-controller', function () { let frameworks; diff --git a/api/tests/unit/application/frameworks/index_test.js b/api/tests/unit/application/frameworks/index_test.js index 3f540723da9..06b5c0d3fe1 100644 --- a/api/tests/unit/application/frameworks/index_test.js +++ b/api/tests/unit/application/frameworks/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const frameworksController = require('../../../../lib/application/frameworks/frameworks-controller'); -const moduleUnderTest = require('../../../../lib/application/frameworks'); +import { expect, HttpTestServer, sinon, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { frameworksController } from '../../../../lib/application/frameworks/frameworks-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/frameworks/index.js'; describe('Unit | Application | Frameworks | Routes', function () { describe('GET /api/admin/frameworks', function () { diff --git a/api/tests/unit/application/healthcheck/healthcheck-controller_test.js b/api/tests/unit/application/healthcheck/healthcheck-controller_test.js index 294b6461f56..93abbf56ff6 100644 --- a/api/tests/unit/application/healthcheck/healthcheck-controller_test.js +++ b/api/tests/unit/application/healthcheck/healthcheck-controller_test.js @@ -1,15 +1,15 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const { knex } = require('../../../../db/knex-database-connection'); -const { redisMonitor } = require('../../../../lib/infrastructure/utils/redis-monitor'); - -const healthcheckController = require('../../../../lib/application/healthcheck/healthcheck-controller'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { knex } from '../../../../db/knex-database-connection.js'; +import { redisMonitor } from '../../../../lib/infrastructure/utils/redis-monitor.js'; +import { healthcheckController } from '../../../../lib/application/healthcheck/healthcheck-controller.js'; describe('Unit | Controller | healthcheckController', function () { describe('#get', function () { it('should reply with the API description', async function () { - // when + // given const mockedRequest = { i18n: { __: sinon.stub() } }; + // when const response = await healthcheckController.get(mockedRequest, hFake); // then diff --git a/api/tests/unit/application/healthcheck/index_test.js b/api/tests/unit/application/healthcheck/index_test.js index de218a6517b..ddb55dbcdd1 100644 --- a/api/tests/unit/application/healthcheck/index_test.js +++ b/api/tests/unit/application/healthcheck/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/healthcheck'); -const healthcheckController = require('../../../../lib/application/healthcheck/healthcheck-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { healthcheckController } from '../../../../lib/application/healthcheck/healthcheck-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/healthcheck/index.js'; describe('Unit | Router | HealthcheckRouter', function () { describe('GET /api', function () { diff --git a/api/tests/unit/application/lcms/index_test.js b/api/tests/unit/application/lcms/index_test.js index fe67fe7ad80..6dffd23f379 100644 --- a/api/tests/unit/application/lcms/index_test.js +++ b/api/tests/unit/application/lcms/index_test.js @@ -1,10 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); - -const moduleUnderTest = require('../../../../lib/application/lcms'); - -const lcmsController = require('../../../../lib/application/lcms/lcms-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { lcmsController } from '../../../../lib/application/lcms/lcms-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/lcms/index.js'; describe('Unit | Router | lcms-router', function () { let httpTestServer; diff --git a/api/tests/unit/application/lcms/lcms-controller_test.js b/api/tests/unit/application/lcms/lcms-controller_test.js index bf6dcae4baa..cf1683dcab7 100644 --- a/api/tests/unit/application/lcms/lcms-controller_test.js +++ b/api/tests/unit/application/lcms/lcms-controller_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const lcmsController = require('../../../../lib/application/lcms/lcms-controller'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { lcmsController } from '../../../../lib/application/lcms/lcms-controller.js'; describe('Unit | Controller | lcms-controller', function () { describe('#createRelease', function () { diff --git a/api/tests/unit/application/memberships/index_test.js b/api/tests/unit/application/memberships/index_test.js index 6622e526b66..a6d7b9d6c8f 100644 --- a/api/tests/unit/application/memberships/index_test.js +++ b/api/tests/unit/application/memberships/index_test.js @@ -1,10 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); - -const moduleUnderTest = require('../../../../lib/application/memberships'); - -const membershipController = require('../../../../lib/application/memberships/membership-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { membershipController } from '../../../../lib/application/memberships/membership-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/memberships/index.js'; describe('Unit | Router | membership-router', function () { describe('PATCH /api/admin/memberships/{id}', function () { diff --git a/api/tests/unit/application/memberships/membership-controller_test.js b/api/tests/unit/application/memberships/membership-controller_test.js index 84dd25ccece..2b39786aca7 100644 --- a/api/tests/unit/application/memberships/membership-controller_test.js +++ b/api/tests/unit/application/memberships/membership-controller_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, hFake, domainBuilder } = require('../../../test-helper'); - -const membershipController = require('../../../../lib/application/memberships/membership-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const Membership = require('../../../../lib/domain/models/Membership'); +import { expect, sinon, hFake, domainBuilder } from '../../../test-helper.js'; +import { membershipController } from '../../../../lib/application/memberships/membership-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; describe('Unit | Controller | membership-controller', function () { describe('#create', function () { diff --git a/api/tests/unit/application/organization-invitations/index_test.js b/api/tests/unit/application/organization-invitations/index_test.js index ce7e4bb16c9..855f71a3fb2 100644 --- a/api/tests/unit/application/organization-invitations/index_test.js +++ b/api/tests/unit/application/organization-invitations/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/organization-invitations'); -const organizationInvitationController = require('../../../../lib/application/organization-invitations/organization-invitation-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { organizationInvitationController } from '../../../../lib/application/organization-invitations/organization-invitation-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/organization-invitations/index.js'; describe('Unit | Router | organization-invitation-router', function () { describe('POST /api/organization-invitations/{id}/response', function () { diff --git a/api/tests/unit/application/organization-invitations/organization-invitation-controller_test.js b/api/tests/unit/application/organization-invitations/organization-invitation-controller_test.js index 3d9cdfd895a..fd090dd2245 100644 --- a/api/tests/unit/application/organization-invitations/organization-invitation-controller_test.js +++ b/api/tests/unit/application/organization-invitations/organization-invitation-controller_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, catchErr, domainBuilder, hFake } = require('../../../test-helper'); - -const { MissingQueryParamError } = require('../../../../lib/application/http-errors'); -const organizationInvitationController = require('../../../../lib/application/organization-invitations/organization-invitation-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, catchErr, domainBuilder, hFake } from '../../../test-helper.js'; +import { MissingQueryParamError } from '../../../../lib/application/http-errors.js'; +import { organizationInvitationController } from '../../../../lib/application/organization-invitations/organization-invitation-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Application | Organization-Invitations | organization-invitation-controller', function () { describe('#acceptOrganizationInvitation', function () { diff --git a/api/tests/unit/application/organization-learners/index_test.js b/api/tests/unit/application/organization-learners/index_test.js index 5fb8815d113..de6b5cf20b7 100644 --- a/api/tests/unit/application/organization-learners/index_test.js +++ b/api/tests/unit/application/organization-learners/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const organizationLearnerController = require('../../../../lib/application/organization-learners/organization-learner-controller'); -const moduleUnderTest = require('../../../../lib/application/organization-learners'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { organizationLearnerController } from '../../../../lib/application/organization-learners/organization-learner-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/organization-learners/index.js'; describe('Unit | Application | Router | organization-learner-router', function () { context('Routes /admin', function () { diff --git a/api/tests/unit/application/organization-learners/organization-learner-controller_test.js b/api/tests/unit/application/organization-learners/organization-learner-controller_test.js index 2629621b3a2..037ad26d535 100644 --- a/api/tests/unit/application/organization-learners/organization-learner-controller_test.js +++ b/api/tests/unit/application/organization-learners/organization-learner-controller_test.js @@ -1,6 +1,6 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const organizationLearnerController = require('../../../../lib/application/organization-learners/organization-learner-controller'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { organizationLearnerController } from '../../../../lib/application/organization-learners/organization-learner-controller.js'; describe('Unit | Application | Organization-Learner | organization-learner-controller', function () { describe('#getOrganizationLearnerActivity', function () { diff --git a/api/tests/unit/application/organizations-administration/index_test.js b/api/tests/unit/application/organizations-administration/index_test.js index 214c2c8cb23..470289219b1 100644 --- a/api/tests/unit/application/organizations-administration/index_test.js +++ b/api/tests/unit/application/organizations-administration/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/organizations-administration'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import * as moduleUnderTest from '../../../../lib/application/organizations-administration/index.js'; describe('Unit | Router | organization-administration-router', function () { describe('PATCH /api/admin/organizations/{id}', function () { diff --git a/api/tests/unit/application/organizations-administration/organization-administration-controller_test.js b/api/tests/unit/application/organizations-administration/organization-administration-controller_test.js index e07915bfcab..3ebcdd8f000 100644 --- a/api/tests/unit/application/organizations-administration/organization-administration-controller_test.js +++ b/api/tests/unit/application/organizations-administration/organization-administration-controller_test.js @@ -1,6 +1,6 @@ -const { domainBuilder, expect, hFake, sinon } = require('../../../test-helper'); -const organizationController = require('../../../../lib/application/organizations-administration/organization-administration-controller.js'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { domainBuilder, expect, hFake, sinon } from '../../../test-helper.js'; +import * as organizationController from '../../../../lib/application/organizations-administration/organization-administration-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Application | Organizations | organization-administration-controller', function () { describe('#updateOrganizationInformation', function () { diff --git a/api/tests/unit/application/organizations/helpers.js b/api/tests/unit/application/organizations/helpers.js index 0e55858a29d..af23b563dc4 100644 --- a/api/tests/unit/application/organizations/helpers.js +++ b/api/tests/unit/application/organizations/helpers.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const { mapCertificabilityByLabel } = require('../../../../lib/application/organizations/helpers'); +import { expect } from '../../../test-helper.js'; +import { mapCertificabilityByLabel } from '../../../../lib/application/organizations/helpers.js'; describe('Unit | Application | Organizations | helpers', function () { it('map the certificability eligible value', async function () { diff --git a/api/tests/unit/application/organizations/index_test.js b/api/tests/unit/application/organizations/index_test.js index 962beecb93d..34def26f485 100644 --- a/api/tests/unit/application/organizations/index_test.js +++ b/api/tests/unit/application/organizations/index_test.js @@ -1,11 +1,10 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const organizationController = require('../../../../lib/application/organizations/organization-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const identifiersType = require('../../../../lib/domain/types/identifiers-type'); -const moduleUnderTest = require('../../../../lib/application/organizations'); -const organizationPlacesCategories = require('../../../../lib/domain/constants/organization-places-categories'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { organizationController } from '../../../../lib/application/organizations/organization-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { identifiersType } from '../../../../lib/domain/types/identifiers-type.js'; +import * as moduleUnderTest from '../../../../lib/application/organizations/index.js'; +import * as organizationPlacesCategories from '../../../../lib/domain/constants/organization-places-categories.js'; describe('Unit | Router | organization-router', function () { describe('GET /api/admin/organizations', function () { diff --git a/api/tests/unit/application/organizations/organization-controller_test.js b/api/tests/unit/application/organizations/organization-controller_test.js index d545e827dbb..0fea8261f28 100644 --- a/api/tests/unit/application/organizations/organization-controller_test.js +++ b/api/tests/unit/application/organizations/organization-controller_test.js @@ -1,22 +1,14 @@ -const { - domainBuilder, - expect, - generateValidRequestAuthorizationHeader, - hFake, - sinon, -} = require('../../../test-helper'); - -const Organization = require('../../../../lib/domain/models/Organization'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const Membership = require('../../../../lib/domain/models/Membership'); -const ScoOrganizationParticipant = require('../../../../lib/domain/read-models/ScoOrganizationParticipant'); -const SupOrganizationParticipant = require('../../../../lib/domain/read-models/SupOrganizationParticipant'); - -const organizationController = require('../../../../lib/application/organizations/organization-controller.js'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const queryParamsUtils = require('../../../../lib/infrastructure/utils/query-params-utils'); - -const { getI18n } = require('../../../tooling/i18n/i18n'); +import { domainBuilder, expect, generateValidRequestAuthorizationHeader, hFake, sinon } from '../../../test-helper.js'; + +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { ScoOrganizationParticipant } from '../../../../lib/domain/read-models/ScoOrganizationParticipant.js'; +import { SupOrganizationParticipant } from '../../../../lib/domain/read-models/SupOrganizationParticipant.js'; +import { organizationController } from '../../../../lib/application/organizations/organization-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import * as queryParamsUtils from '../../../../lib/infrastructure/utils/query-params-utils.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; describe('Unit | Application | Organizations | organization-controller', function () { let request; diff --git a/api/tests/unit/application/passwords/index_test.js b/api/tests/unit/application/passwords/index_test.js index aed3d83b144..ef66a90af66 100644 --- a/api/tests/unit/application/passwords/index_test.js +++ b/api/tests/unit/application/passwords/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/passwords'); -const passwordController = require('../../../../lib/application/passwords/password-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { passwordController } from '../../../../lib/application/passwords/password-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/passwords/index.js'; describe('Unit | Router | Password router', function () { describe('POST /api/password-reset-demands', function () { diff --git a/api/tests/unit/application/passwords/password-controller_test.js b/api/tests/unit/application/passwords/password-controller_test.js index 44d4d4074ca..cfa60979643 100644 --- a/api/tests/unit/application/passwords/password-controller_test.js +++ b/api/tests/unit/application/passwords/password-controller_test.js @@ -1,8 +1,6 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); - -const passwordController = require('../../../../lib/application/passwords/password-controller'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { passwordController } from '../../../../lib/application/passwords/password-controller.js'; describe('Unit | Controller | PasswordController', function () { describe('#createResetDemand', function () { diff --git a/api/tests/unit/application/pole-emploi/index_test.js b/api/tests/unit/application/pole-emploi/index_test.js index 9ef3ed34842..752863f937f 100644 --- a/api/tests/unit/application/pole-emploi/index_test.js +++ b/api/tests/unit/application/pole-emploi/index_test.js @@ -1,11 +1,12 @@ -const { +import { expect, HttpTestServer, sinon, generateValidRequestAuthorizationHeaderForApplication, -} = require('../../../test-helper'); -const poleEmploiController = require('../../../../lib/application/pole-emploi/pole-emploi-controller'); -const moduleUnderTest = require('../../../../lib/application/pole-emploi'); +} from '../../../test-helper.js'; + +import { poleEmploiController } from '../../../../lib/application/pole-emploi/pole-emploi-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/pole-emploi/index.js'; describe('Unit | Router | pole-emploi-router', function () { describe('GET /api/pole-emploi/envois', function () { diff --git a/api/tests/unit/application/pole-emploi/pole-emploi-controller_test.js b/api/tests/unit/application/pole-emploi/pole-emploi-controller_test.js index 8a65c055a23..4974a416147 100644 --- a/api/tests/unit/application/pole-emploi/pole-emploi-controller_test.js +++ b/api/tests/unit/application/pole-emploi/pole-emploi-controller_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const poleEmploiController = require('../../../../lib/application/pole-emploi/pole-emploi-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { poleEmploiController } from '../../../../lib/application/pole-emploi/pole-emploi-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Controller | pole-emploi-controller', function () { describe('#getSendings', function () { diff --git a/api/tests/unit/application/pre-response-utils_test.js b/api/tests/unit/application/pre-response-utils_test.js index e22e707f867..2eb7960c65a 100644 --- a/api/tests/unit/application/pre-response-utils_test.js +++ b/api/tests/unit/application/pre-response-utils_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, hFake } = require('../../test-helper'); -const { BaseHttpError } = require('../../../lib/application/http-errors'); -const { handleDomainAndHttpErrors } = require('../../../lib/application/pre-response-utils'); - -const { DomainError } = require('../../../lib/domain/errors'); +import { expect, sinon, hFake } from '../../test-helper.js'; +import { BaseHttpError } from '../../../lib/application/http-errors.js'; +import { handleDomainAndHttpErrors } from '../../../lib/application/pre-response-utils.js'; +import { DomainError } from '../../../lib/domain/errors.js'; describe('Unit | Application | PreResponse-utils', function () { describe('#handleDomainAndHttpErrors', function () { diff --git a/api/tests/unit/application/preHandlers/assessment-authorization_test.js b/api/tests/unit/application/preHandlers/assessment-authorization_test.js deleted file mode 100644 index ef2dc06caeb..00000000000 --- a/api/tests/unit/application/preHandlers/assessment-authorization_test.js +++ /dev/null @@ -1,108 +0,0 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const AssessmentAuthorization = require('../../../../lib/application/preHandlers/assessment-authorization'); - -describe('Unit | Pre-handler | Assessment Authorization', function () { - describe('#verify', function () { - const request = { - headers: { authorization: 'VALID_TOKEN' }, - params: { - id: 8, - }, - }; - let requestResponseUtils; - let assessmentRepository; - let validationErrorSerializer; - - beforeEach(function () { - requestResponseUtils = { - extractUserIdFromRequest: sinon.stub(), - }; - assessmentRepository = { - getByAssessmentIdAndUserId: sinon.stub(), - }; - validationErrorSerializer = { - serialize: sinon.stub(), - }; - }); - - it('should get userId from token', async function () { - // given - requestResponseUtils.extractUserIdFromRequest.returns('userId'); - assessmentRepository.getByAssessmentIdAndUserId.resolves(); - validationErrorSerializer.serialize.returns(); - - // when - await AssessmentAuthorization.verify(request, hFake, { - requestResponseUtils, - assessmentRepository, - validationErrorSerializer, - }); - - // then - expect(requestResponseUtils.extractUserIdFromRequest).to.have.been.calledWith(request); - }); - - describe('When assessment is linked to userId (userId exist)', function () { - it('should reply with assessment', async function () { - // given - const fetchedAssessment = {}; - const extractedUserId = 'userId'; - requestResponseUtils.extractUserIdFromRequest.returns(extractedUserId); - assessmentRepository.getByAssessmentIdAndUserId.resolves(fetchedAssessment); - - // when - const response = await AssessmentAuthorization.verify(request, hFake, { - requestResponseUtils, - assessmentRepository, - validationErrorSerializer, - }); - - // then - sinon.assert.calledOnce(assessmentRepository.getByAssessmentIdAndUserId); - sinon.assert.calledWith(assessmentRepository.getByAssessmentIdAndUserId, request.params.id, extractedUserId); - expect(response).to.deep.equal(fetchedAssessment); - }); - }); - - describe('When assessment is linked a null userId', function () { - it('should reply with assessment', async function () { - // given - const fetchedAssessment = {}; - const extractedUserId = null; - requestResponseUtils.extractUserIdFromRequest.returns(extractedUserId); - assessmentRepository.getByAssessmentIdAndUserId.resolves(fetchedAssessment); - - // when - const response = await AssessmentAuthorization.verify(request, hFake, { - requestResponseUtils, - assessmentRepository, - validationErrorSerializer, - }); - - // then - expect(assessmentRepository.getByAssessmentIdAndUserId).to.have.been.calledWith(request.params.id, null); - expect(response).to.deep.equal(fetchedAssessment); - }); - }); - - describe('When userId (from token) is not linked to assessment', function () { - it('should take over the request and response with 401 status code', async function () { - // given - const extractedUserId = null; - requestResponseUtils.extractUserIdFromRequest.returns(extractedUserId); - assessmentRepository.getByAssessmentIdAndUserId.rejects(); - - // when - const response = await AssessmentAuthorization.verify(request, hFake, { - requestResponseUtils, - assessmentRepository, - validationErrorSerializer, - }); - - // then - expect(response.statusCode).to.equal(401); - expect(response.isTakeOver).to.be.true; - }); - }); - }); -}); diff --git a/api/tests/unit/application/preHandlers/authorization_test.js b/api/tests/unit/application/preHandlers/authorization_test.js index 16ddcf5ecaa..2a3896c5e32 100644 --- a/api/tests/unit/application/preHandlers/authorization_test.js +++ b/api/tests/unit/application/preHandlers/authorization_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, domainBuilder, catchErr, hFake } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/application/http-errors'); -const { +import { expect, sinon, domainBuilder, catchErr, hFake } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/application/http-errors.js'; +import { verifyCertificationSessionAuthorization, verifySessionAuthorization, -} = require('../../../../lib/application/preHandlers/authorization'); +} from '../../../../lib/application/preHandlers/authorization.js'; describe('Unit | Pre-handler | Authorization', function () { const userId = 1; diff --git a/api/tests/unit/application/preHandlers/models/CampaignAuthorization_test.js b/api/tests/unit/application/preHandlers/models/CampaignAuthorization_test.js index 83243d6bb53..7d8931f018c 100644 --- a/api/tests/unit/application/preHandlers/models/CampaignAuthorization_test.js +++ b/api/tests/unit/application/preHandlers/models/CampaignAuthorization_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const CampaignAuthorization = require('../../../../../lib/application/preHandlers/models/CampaignAuthorization'); +import { expect } from '../../../../test-helper.js'; +import { CampaignAuthorization } from '../../../../../lib/application/preHandlers/models/CampaignAuthorization.js'; describe('Unit | Domain | models | CampaignAuthorization', function () { describe('#isAllowedToManage', function () { diff --git a/api/tests/unit/application/preHandlers/session-supervisor-authorization_test.js b/api/tests/unit/application/preHandlers/session-supervisor-authorization_test.js index 3c6e8e0bee6..c65fa28f08f 100644 --- a/api/tests/unit/application/preHandlers/session-supervisor-authorization_test.js +++ b/api/tests/unit/application/preHandlers/session-supervisor-authorization_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const sessionSupervisorAuthorization = require('../../../../lib/application/preHandlers/session-supervisor-authorization'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { assessmentSupervisorAuthorization as sessionSupervisorAuthorization } from '../../../../lib/application/preHandlers/session-supervisor-authorization.js'; describe('Unit | Pre-handler | Supervisor Authorization', function () { let supervisorAccessRepository; diff --git a/api/tests/unit/application/preHandlers/user-existence-verification_test.js b/api/tests/unit/application/preHandlers/user-existence-verification_test.js index c2bea2b2842..8aa2763c017 100644 --- a/api/tests/unit/application/preHandlers/user-existence-verification_test.js +++ b/api/tests/unit/application/preHandlers/user-existence-verification_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const userVerification = require('../../../../lib/application/preHandlers/user-existence-verification'); -const { UserNotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { userVerification } from '../../../../lib/application/preHandlers/user-existence-verification.js'; +import { UserNotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | Pre-handler | User Verification', function () { describe('#verifyById', function () { diff --git a/api/tests/unit/application/prescribers/index_test.js b/api/tests/unit/application/prescribers/index_test.js index 66b1ffca13c..7f8e0db23cf 100644 --- a/api/tests/unit/application/prescribers/index_test.js +++ b/api/tests/unit/application/prescribers/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const moduleUnderTest = require('../../../../lib/application/prescribers'); -const prescriberController = require('../../../../lib/application/prescribers/prescriber-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { prescriberController } from '../../../../lib/application/prescribers/prescriber-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/prescribers/index.js'; describe('Unit | Router | prescriber-router', function () { describe('GET /api/prescription/prescribers/{id}', function () { diff --git a/api/tests/unit/application/prescribers/prescriber-controller_test.js b/api/tests/unit/application/prescribers/prescriber-controller_test.js index e8cfa5eee51..14b741f53e8 100644 --- a/api/tests/unit/application/prescribers/prescriber-controller_test.js +++ b/api/tests/unit/application/prescribers/prescriber-controller_test.js @@ -1,8 +1,6 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); - -const prescriberController = require('../../../../lib/application/prescribers/prescriber-controller'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { prescriberController } from '../../../../lib/application/prescribers/prescriber-controller.js'; describe('Unit | Controller | prescriber-controller', function () { describe('#get', function () { diff --git a/api/tests/unit/application/progressions/index_test.js b/api/tests/unit/application/progressions/index_test.js index f135a065598..b04b7639c6e 100644 --- a/api/tests/unit/application/progressions/index_test.js +++ b/api/tests/unit/application/progressions/index_test.js @@ -1,7 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/progressions'); -const progressionController = require('../../../../lib/application/progressions/progression-controller'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { progressionController } from '../../../../lib/application/progressions/progression-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/progressions/index.js'; describe('Unit | Router | progression-router', function () { describe('GET /api/progressions/{id}', function () { diff --git a/api/tests/unit/application/progressions/progression-controller_test.js b/api/tests/unit/application/progressions/progression-controller_test.js index 0a49039ea79..72bc36493a8 100644 --- a/api/tests/unit/application/progressions/progression-controller_test.js +++ b/api/tests/unit/application/progressions/progression-controller_test.js @@ -1,7 +1,6 @@ -const { expect, sinon, domainBuilder, hFake } = require('../../../test-helper'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); -const progressionController = require('../../../../lib/application/progressions/progression-controller'); +import { expect, sinon, domainBuilder, hFake } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { progressionController } from '../../../../lib/application/progressions/progression-controller.js'; describe('Unit | Controller | progression-controller', function () { const userId = 60; diff --git a/api/tests/unit/application/sco-organization-learners/sco-organization-learner-controller_test.js b/api/tests/unit/application/sco-organization-learners/sco-organization-learner-controller_test.js index 883767703e9..b565684c848 100644 --- a/api/tests/unit/application/sco-organization-learners/sco-organization-learner-controller_test.js +++ b/api/tests/unit/application/sco-organization-learners/sco-organization-learner-controller_test.js @@ -1,8 +1,6 @@ -const { expect, hFake, sinon } = require('../../../test-helper'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); - -const scoOrganizationLearnerController = require('../../../../lib/application/sco-organization-learners/sco-organization-learner-controller'); +import { expect, hFake, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { scoOrganizationLearnerController } from '../../../../lib/application/sco-organization-learners/sco-organization-learner-controller.js'; describe('Unit | Application | Controller | sco-organization-learner', function () { describe('#createUserAndReconcileToOrganizationLearnerFromExternalUser', function () { diff --git a/api/tests/unit/application/scorecards/index_test.js b/api/tests/unit/application/scorecards/index_test.js index 09f04b45837..cb530ce5925 100644 --- a/api/tests/unit/application/scorecards/index_test.js +++ b/api/tests/unit/application/scorecards/index_test.js @@ -1,6 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const scorecardController = require('../../../../lib/application/scorecards/scorecard-controller'); -const moduleUnderTest = require('../../../../lib/application/scorecards'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { scorecardController } from '../../../../lib/application/scorecards/scorecard-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/scorecards/index.js'; describe('Unit | Router | scorecard-router', function () { describe('GET /api/scorecards/{id}', function () { diff --git a/api/tests/unit/application/scorecards/scorecard-controller_test.js b/api/tests/unit/application/scorecards/scorecard-controller_test.js index 2cdda87058c..a7422b38a78 100644 --- a/api/tests/unit/application/scorecards/scorecard-controller_test.js +++ b/api/tests/unit/application/scorecards/scorecard-controller_test.js @@ -1,9 +1,7 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); - -const scorecardController = require('../../../../lib/application/scorecards/scorecard-controller'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); -const requestResponseUtils = require('../../../../lib/infrastructure/utils/request-response-utils.js'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { scorecardController } from '../../../../lib/application/scorecards/scorecard-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import * as requestResponseUtils from '../../../../lib/infrastructure/utils/request-response-utils.js'; describe('Unit | Controller | scorecard-controller', function () { const authenticatedUserId = '12'; diff --git a/api/tests/unit/application/security-pre-handlers_test.js b/api/tests/unit/application/security-pre-handlers_test.js index 220b28e2d3e..492b85d8c45 100644 --- a/api/tests/unit/application/security-pre-handlers_test.js +++ b/api/tests/unit/application/security-pre-handlers_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, hFake, domainBuilder } = require('../../test-helper'); - -const securityPreHandlers = require('../../../lib/application/security-pre-handlers'); -const tokenService = require('../../../lib/domain/services/token-service'); -const { NotFoundError } = require('../../../lib/domain/errors'); +import { expect, sinon, hFake, domainBuilder } from '../../test-helper.js'; +import { securityPreHandlers } from '../../../lib/application/security-pre-handlers.js'; +import { tokenService } from '../../../lib/domain/services/token-service.js'; +import { NotFoundError } from '../../../lib/domain/errors.js'; describe('Unit | Application | SecurityPreHandlers', function () { describe('#checkAdminMemberHasRoleSuperAdmin', function () { let request; diff --git a/api/tests/unit/application/session/finalized-session-controller_test.js b/api/tests/unit/application/session/finalized-session-controller_test.js index de25eff4ae4..868a8544b03 100644 --- a/api/tests/unit/application/session/finalized-session-controller_test.js +++ b/api/tests/unit/application/session/finalized-session-controller_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, hFake } = require('../../../test-helper'); -const finalizedSessionController = require('../../../../lib/application/sessions/finalized-session-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, hFake } from '../../../test-helper.js'; +import { finalizedSessionController } from '../../../../lib/application/sessions/finalized-session-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Controller | finalized-session', function () { let request; diff --git a/api/tests/unit/application/session/index_test.js b/api/tests/unit/application/session/index_test.js index 4ccaa41d330..a689305fabe 100644 --- a/api/tests/unit/application/session/index_test.js +++ b/api/tests/unit/application/session/index_test.js @@ -1,19 +1,20 @@ -const { writeFile, stat, unlink } = require('fs').promises; -const fs = require('fs'); -const FormData = require('form-data'); -const streamToPromise = require('stream-to-promise'); -const { NotFoundError } = require('../../../../lib/application/http-errors'); - -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const sessionController = require('../../../../lib/application/sessions/session-controller'); -const sessionForSupervisingController = require('../../../../lib/application/sessions/session-for-supervising-controller'); -const sessionWithCleaCertifiedCandidateController = require('../../../../lib/application/sessions/session-with-clea-certified-candidate-controller'); -const finalizedSessionController = require('../../../../lib/application/sessions/finalized-session-controller'); -const authorization = require('../../../../lib/application/preHandlers/authorization'); -const moduleUnderTest = require('../../../../lib/application/sessions'); -const sessionSupervisorAuthorization = require('../../../../lib/application/preHandlers/session-supervisor-authorization'); +import fs from 'fs'; +import { writeFile, stat, unlink } from 'fs/promises'; + +import FormData from 'form-data'; +import streamToPromise from 'stream-to-promise'; +import { NotFoundError } from '../../../../lib/application/http-errors.js'; +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { sessionController } from '../../../../lib/application/sessions/session-controller.js'; +import { sessionForSupervisingController } from '../../../../lib/application/sessions/session-for-supervising-controller.js'; +import { sessionWithCleaCertifiedCandidateController } from '../../../../lib/application/sessions/session-with-clea-certified-candidate-controller.js'; +import { finalizedSessionController } from '../../../../lib/application/sessions/finalized-session-controller.js'; +import { authorization } from '../../../../lib/application/preHandlers/authorization.js'; +import * as moduleUnderTest from '../../../../lib/application/sessions/index.js'; +import { assessmentSupervisorAuthorization as sessionSupervisorAuthorization } from '../../../../lib/application/preHandlers/session-supervisor-authorization.js'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Unit | Application | Sessions | Routes', function () { describe('GET /api/sessions/{id}', function () { diff --git a/api/tests/unit/application/session/session-controller_test.js b/api/tests/unit/application/session/session-controller_test.js index 874db2e1eef..68527767167 100644 --- a/api/tests/unit/application/session/session-controller_test.js +++ b/api/tests/unit/application/session/session-controller_test.js @@ -1,15 +1,15 @@ -const { expect, sinon, hFake, domainBuilder, catchErr } = require('../../../test-helper'); -const sessionController = require('../../../../lib/application/sessions/session-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const UserAlreadyLinkedToCertificationCandidate = require('../../../../lib/domain/events/UserAlreadyLinkedToCertificationCandidate'); -const UserLinkedToCertificationCandidate = require('../../../../lib/domain/events/UserLinkedToCertificationCandidate'); -const { SessionPublicationBatchResult } = require('../../../../lib/domain/models/SessionPublicationBatchResult'); -const logger = require('../../../../lib/infrastructure/logger'); -const { SessionPublicationBatchError } = require('../../../../lib/application/http-errors'); -const certificationResultUtils = require('../../../../lib/infrastructure/utils/csv/certification-results.js'); -const queryParamsUtils = require('../../../../lib/infrastructure/utils/query-params-utils'); -const events = require('../../../../lib/domain/events'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import { expect, sinon, hFake, domainBuilder, catchErr } from '../../../test-helper.js'; +import { sessionController } from '../../../../lib/application/sessions/session-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserAlreadyLinkedToCertificationCandidate } from '../../../../lib/domain/events/UserAlreadyLinkedToCertificationCandidate.js'; +import { UserLinkedToCertificationCandidate } from '../../../../lib/domain/events/UserLinkedToCertificationCandidate.js'; +import { SessionPublicationBatchResult } from '../../../../lib/domain/models/SessionPublicationBatchResult.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; +import { SessionPublicationBatchError } from '../../../../lib/application/http-errors.js'; +import * as certificationResultUtils from '../../../../lib/infrastructure/utils/csv/certification-results.js'; +import * as queryParamsUtils from '../../../../lib/infrastructure/utils/query-params-utils.js'; +import * as events from '../../../../lib/domain/events/index.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; describe('Unit | Controller | sessionController', function () { let request; @@ -1012,7 +1012,7 @@ describe('Unit | Controller | sessionController', function () { }; // when - await sessionController.delete(request, hFake); + await sessionController.remove(request, hFake); // then expect(usecases.deleteSession).to.have.been.calledWithExactly({ diff --git a/api/tests/unit/application/session/session-for-supervising-controller_test.js b/api/tests/unit/application/session/session-for-supervising-controller_test.js index c1bec19df4f..aaa3230d874 100644 --- a/api/tests/unit/application/session/session-for-supervising-controller_test.js +++ b/api/tests/unit/application/session/session-for-supervising-controller_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, hFake, domainBuilder } = require('../../../test-helper'); -const sessionForSupervisingController = require('../../../../lib/application/sessions/session-for-supervising-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const sessionForSupervisingSerializer = require('../../../../lib/infrastructure/serializers/jsonapi/session-for-supervising-serializer'); +import { expect, sinon, hFake, domainBuilder } from '../../../test-helper.js'; +import { sessionForSupervisingController } from '../../../../lib/application/sessions/session-for-supervising-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import * as sessionForSupervisingSerializer from '../../../../lib/infrastructure/serializers/jsonapi/session-for-supervising-serializer.js'; describe('Unit | Controller | session-for-supervising', function () { describe('#get', function () { diff --git a/api/tests/unit/application/session/session-with-clea-certified-candidate-controller_test.js b/api/tests/unit/application/session/session-with-clea-certified-candidate-controller_test.js index 9e539a6cdb7..f1bab8ae92a 100644 --- a/api/tests/unit/application/session/session-with-clea-certified-candidate-controller_test.js +++ b/api/tests/unit/application/session/session-with-clea-certified-candidate-controller_test.js @@ -1,6 +1,6 @@ -const { domainBuilder, sinon, hFake, expect } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const sessionWithCleaCertifiedCandidateController = require('../../../../lib/application/sessions/session-with-clea-certified-candidate-controller'); +import { domainBuilder, sinon, hFake, expect } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { sessionWithCleaCertifiedCandidateController } from '../../../../lib/application/sessions/session-with-clea-certified-candidate-controller.js'; describe('Unit | Controller | session-with-clea-certified-candidate', function () { describe('#getCleaCertifiedCandidateDataCsv', function () { diff --git a/api/tests/unit/application/tags/index_test.js b/api/tests/unit/application/tags/index_test.js index 1603ecad9bd..a73103c0001 100644 --- a/api/tests/unit/application/tags/index_test.js +++ b/api/tests/unit/application/tags/index_test.js @@ -1,8 +1,7 @@ -const { domainBuilder, expect, sinon, HttpTestServer } = require('../../../test-helper'); - -const moduleUnderTest = require('../../../../lib/application/tags'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const tagController = require('../../../../lib/application/tags/tag-controller'); +import { domainBuilder, expect, sinon, HttpTestServer } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { tagController } from '../../../../lib/application/tags/tag-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/tags/index.js'; describe('Unit | Application | Router | tag-router', function () { describe('GET /api/admin/tags', function () { diff --git a/api/tests/unit/application/tags/tag-controller_test.js b/api/tests/unit/application/tags/tag-controller_test.js index 21140d03d76..936ec711d6c 100644 --- a/api/tests/unit/application/tags/tag-controller_test.js +++ b/api/tests/unit/application/tags/tag-controller_test.js @@ -1,7 +1,6 @@ -const { expect, sinon, domainBuilder, hFake } = require('../../../test-helper'); - -const tagController = require('../../../../lib/application/tags/tag-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, domainBuilder, hFake } from '../../../test-helper.js'; +import { tagController } from '../../../../lib/application/tags/tag-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Application | Tags | tag-controller', function () { describe('#create', function () { diff --git a/api/tests/unit/application/target-profiles/index_test.js b/api/tests/unit/application/target-profiles/index_test.js index 44a0c2d35c3..5107a5265c8 100644 --- a/api/tests/unit/application/target-profiles/index_test.js +++ b/api/tests/unit/application/target-profiles/index_test.js @@ -1,7 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const targetProfileController = require('../../../../lib/application/target-profiles/target-profile-controller'); -const moduleUnderTest = require('../../../../lib/application/target-profiles'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { targetProfileController } from '../../../../lib/application/target-profiles/target-profile-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/target-profiles/index.js'; describe('Unit | Application | Target Profiles | Routes', function () { describe('GET /api/admin/target-profile-summaries', function () { diff --git a/api/tests/unit/application/target-profiles/target-profile-controller_test.js b/api/tests/unit/application/target-profiles/target-profile-controller_test.js index 982f5e7c831..46c0e4598fd 100644 --- a/api/tests/unit/application/target-profiles/target-profile-controller_test.js +++ b/api/tests/unit/application/target-profiles/target-profile-controller_test.js @@ -1,10 +1,7 @@ -const { expect, sinon, hFake, domainBuilder } = require('../../../test-helper'); -const targetProfileController = require('../../../../lib/application/target-profiles/target-profile-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const tokenService = require('../../../../lib/domain/services/token-service'); -const targetProfileAttachOrganizationSerializer = require('../../../../lib/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer'); -const learningContentPDFPresenter = require('../../../../lib/application/target-profiles/presenter/pdf/learning-content-pdf-presenter'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { expect, sinon, hFake, domainBuilder } from '../../../test-helper.js'; +import { targetProfileController } from '../../../../lib/application/target-profiles/target-profile-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Unit | Controller | target-profile-controller', function () { describe('#createTargetProfile', function () { @@ -103,10 +100,11 @@ describe('Unit | Controller | target-profile-controller', function () { describe('#attachOrganizations', function () { let request; + let targetProfileAttachOrganizationSerializer; beforeEach(function () { sinon.stub(usecases, 'attachOrganizationsToTargetProfile'); - sinon.stub(targetProfileAttachOrganizationSerializer, 'serialize'); + targetProfileAttachOrganizationSerializer = { serialize: sinon.stub() }; request = { params: { @@ -125,7 +123,9 @@ describe('Unit | Controller | target-profile-controller', function () { usecases.attachOrganizationsToTargetProfile.resolves(); targetProfileAttachOrganizationSerializer.serialize.returns(serializer); - const response = await targetProfileController.attachOrganizations(request, hFake); + const response = await targetProfileController.attachOrganizations(request, hFake, { + targetProfileAttachOrganizationSerializer, + }); // then expect(targetProfileAttachOrganizationSerializer.serialize).to.have.been.called; expect(response.statusCode).to.equal(200); @@ -134,7 +134,9 @@ describe('Unit | Controller | target-profile-controller', function () { it('should call usecase', async function () { // when - await targetProfileController.attachOrganizations(request, hFake); + await targetProfileController.attachOrganizations(request, hFake, { + targetProfileAttachOrganizationSerializer, + }); // then expect(usecases.attachOrganizationsToTargetProfile).to.have.been.calledOnce; @@ -234,10 +236,13 @@ describe('Unit | Controller | target-profile-controller', function () { accessToken, }, }; - sinon.stub(tokenService, 'extractUserId').withArgs(accessToken).returns(66); + const tokenService = { + extractUserId: sinon.stub(), + }; + tokenService.extractUserId.withArgs(accessToken).returns(66); // when - const response = await targetProfileController.getContentAsJsonFile(request, hFake); + const response = await targetProfileController.getContentAsJsonFile(request, hFake, { tokenService }); // then expect(response.source).to.equal('json_content'); @@ -257,10 +262,12 @@ describe('Unit | Controller | target-profile-controller', function () { .stub(usecases, 'getLearningContentByTargetProfile') .withArgs({ targetProfileId: 123, language: 'fr' }) .resolves(learningContent); - sinon - .stub(learningContentPDFPresenter, 'present') - .withArgs(learningContent, 'titre du doc', 'fr') - .resolves(pdfBuffer); + + const learningContentPDFPresenter = { + present: sinon.stub(), + }; + + learningContentPDFPresenter.present.withArgs(learningContent, 'titre du doc', 'fr').resolves(pdfBuffer); const request = { params: { id: 123, @@ -273,7 +280,9 @@ describe('Unit | Controller | target-profile-controller', function () { }; // when - const response = await targetProfileController.getLearningContentAsPdf(request, hFake); + const response = await targetProfileController.getLearningContentAsPdf(request, hFake, { + learningContentPDFPresenter, + }); // then expect(response.headers['Content-Disposition'].startsWith('attachment; filename=titre du doc_')).to.be.true; diff --git a/api/tests/unit/application/trainings/index_test.js b/api/tests/unit/application/trainings/index_test.js index 05be8b4198f..db7961b59d7 100644 --- a/api/tests/unit/application/trainings/index_test.js +++ b/api/tests/unit/application/trainings/index_test.js @@ -1,8 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const trainingController = require('../../../../lib/application/trainings/training-controller'); -const moduleUnderTest = require('../../../../lib/application/trainings'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { trainingController } from '../../../../lib/application/trainings/training-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/trainings/index.js'; describe('Unit | Router | training-router', function () { describe('GET /api/admin/trainings/${trainingId}', function () { diff --git a/api/tests/unit/application/trainings/training-controller_test.js b/api/tests/unit/application/trainings/training-controller_test.js index abc2867d85f..f71d7e2c631 100644 --- a/api/tests/unit/application/trainings/training-controller_test.js +++ b/api/tests/unit/application/trainings/training-controller_test.js @@ -1,8 +1,8 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); -const trainingController = require('../../../../lib/application/trainings/training-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const TrainingTrigger = require('../../../../lib/domain/models/TrainingTrigger'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { trainingController } from '../../../../lib/application/trainings/training-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { TrainingTrigger } from '../../../../lib/domain/models/TrainingTrigger.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Unit | Controller | training-controller', function () { describe('#findPaginatedTrainingSummaries', function () { diff --git a/api/tests/unit/application/tutorial-evaluations/index_test.js b/api/tests/unit/application/tutorial-evaluations/index_test.js index ba664e56daf..45cc89a8e6d 100644 --- a/api/tests/unit/application/tutorial-evaluations/index_test.js +++ b/api/tests/unit/application/tutorial-evaluations/index_test.js @@ -1,7 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const tutorialEvaluationsController = require('../../../../lib/application/tutorial-evaluations/tutorial-evaluations-controller'); -const moduleUnderTest = require('../../../../lib/application/tutorial-evaluations'); -const TutorialEvaluation = require('../../../../lib/domain/models/TutorialEvaluation'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { tutorialEvaluationsController } from '../../../../lib/application/tutorial-evaluations/tutorial-evaluations-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/tutorial-evaluations/index.js'; +import { TutorialEvaluation } from '../../../../lib/domain/models/TutorialEvaluation.js'; describe('Unit | Router | tutorial-evaluations-router', function () { describe('PUT /api/users/tutorials/{tutorialId}/evaluate', function () { diff --git a/api/tests/unit/application/tutorial-evaluations/tutorial-evaluations-controller_test.js b/api/tests/unit/application/tutorial-evaluations/tutorial-evaluations-controller_test.js index b4a8e807008..11bd3f85285 100644 --- a/api/tests/unit/application/tutorial-evaluations/tutorial-evaluations-controller_test.js +++ b/api/tests/unit/application/tutorial-evaluations/tutorial-evaluations-controller_test.js @@ -1,7 +1,7 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); -const tutorialEvaluationsController = require('../../../../lib/application/tutorial-evaluations/tutorial-evaluations-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const TutorialEvaluation = require('../../../../lib/domain/models/TutorialEvaluation'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { tutorialEvaluationsController } from '../../../../lib/application/tutorial-evaluations/tutorial-evaluations-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { TutorialEvaluation } from '../../../../lib/domain/models/TutorialEvaluation.js'; describe('Unit | Controller | Tutorial-evaluations', function () { describe('#evaluate', function () { diff --git a/api/tests/unit/application/usecases/checkAdminMemberHasRoleCertif_test.js b/api/tests/unit/application/usecases/checkAdminMemberHasRoleCertif_test.js index c2581d9b4e3..1b03f247dc8 100644 --- a/api/tests/unit/application/usecases/checkAdminMemberHasRoleCertif_test.js +++ b/api/tests/unit/application/usecases/checkAdminMemberHasRoleCertif_test.js @@ -1,10 +1,11 @@ -const { expect, sinon } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkAdminMemberHasRoleCertif'); -const tokenService = require('../../../../lib/domain/services/token-service'); +import { expect, sinon } from '../../../test-helper.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import * as useCase from '../../../../lib/application/usecases/checkAdminMemberHasRoleCertif.js'; describe('Unit | Application | Use Case | checkAdminMemberHasRoleCertifUseCase', function () { const userId = '1234'; let adminMemberRepositoryStub; + beforeEach(function () { sinon.stub(tokenService, 'extractUserId').resolves(userId); adminMemberRepositoryStub = { diff --git a/api/tests/unit/application/usecases/checkAdminMemberHasRolePixMetier_test.js b/api/tests/unit/application/usecases/checkAdminMemberHasRolePixMetier_test.js index 4d4877d7f95..49857a3e363 100644 --- a/api/tests/unit/application/usecases/checkAdminMemberHasRolePixMetier_test.js +++ b/api/tests/unit/application/usecases/checkAdminMemberHasRolePixMetier_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkAdminMemberHasRoleMetier'); -const tokenService = require('../../../../lib/domain/services/token-service'); +import { expect, sinon } from '../../../test-helper.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import * as useCase from '../../../../lib/application/usecases/checkAdminMemberHasRoleMetier.js'; describe('Unit | Application | Use Case | checkAdminMemberHasRoleMetier', function () { const userId = '1234'; diff --git a/api/tests/unit/application/usecases/checkAdminMemberHasRolePixSupport_test.js b/api/tests/unit/application/usecases/checkAdminMemberHasRolePixSupport_test.js index f4e0ea821f2..fa7a2dfd7dd 100644 --- a/api/tests/unit/application/usecases/checkAdminMemberHasRolePixSupport_test.js +++ b/api/tests/unit/application/usecases/checkAdminMemberHasRolePixSupport_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkAdminMemberHasRoleSupport'); -const tokenService = require('../../../../lib/domain/services/token-service'); +import { expect, sinon } from '../../../test-helper.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import * as useCase from '../../../../lib/application/usecases/checkAdminMemberHasRoleSupport.js'; describe('Unit | Application | Use Case | checkAdminMemberHasRoleSupport', function () { const userId = '1234'; diff --git a/api/tests/unit/application/usecases/checkAdminMemberHasRoleSuperAdmin_test.js b/api/tests/unit/application/usecases/checkAdminMemberHasRoleSuperAdmin_test.js index 2b9bd125f71..d15ea4cb35a 100644 --- a/api/tests/unit/application/usecases/checkAdminMemberHasRoleSuperAdmin_test.js +++ b/api/tests/unit/application/usecases/checkAdminMemberHasRoleSuperAdmin_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkAdminMemberHasRoleSuperAdmin'); -const tokenService = require('../../../../lib/domain/services/token-service'); +import { expect, sinon } from '../../../test-helper.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import * as useCase from '../../../../lib/application/usecases/checkAdminMemberHasRoleSuperAdmin.js'; describe('Unit | Application | Use Case | checkAdminMemberHasRoleSuperAdmin', function () { const userId = '1234'; diff --git a/api/tests/unit/application/usecases/checkOrganizationIsScoAndManagingStudent_test.js b/api/tests/unit/application/usecases/checkOrganizationIsScoAndManagingStudent_test.js index 4e7dc3aed84..0502afebe8f 100644 --- a/api/tests/unit/application/usecases/checkOrganizationIsScoAndManagingStudent_test.js +++ b/api/tests/unit/application/usecases/checkOrganizationIsScoAndManagingStudent_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkOrganizationIsScoAndManagingStudent'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as useCase from '../../../../lib/application/usecases/checkOrganizationIsScoAndManagingStudent.js'; describe('Unit | Application | Use Case | checkOrganizationIsScoAndManagingStudent', function () { context('When organization is SCO managing students', function () { diff --git a/api/tests/unit/application/usecases/checkPix1dEnabled_test.js b/api/tests/unit/application/usecases/checkPix1dEnabled_test.js index ae611f35d05..1edb3d79825 100644 --- a/api/tests/unit/application/usecases/checkPix1dEnabled_test.js +++ b/api/tests/unit/application/usecases/checkPix1dEnabled_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkPix1dEnabled'); -const settings = require('../../../../lib/config'); +import { expect, sinon } from '../../../test-helper.js'; +import * as useCase from '../../../../lib/application/usecases/checkPix1dEnabled.js'; +import { config as settings } from '../../../../lib/config.js'; describe('Unit | Application | Use Case | checkPix1dEnabled', function () { it('should resolve true when the admin member has role super admin', async function () { diff --git a/api/tests/unit/application/usecases/checkUserBelongsToLearnersOrganization_test.js b/api/tests/unit/application/usecases/checkUserBelongsToLearnersOrganization_test.js index 9cca3e08988..1ba7a9268c5 100644 --- a/api/tests/unit/application/usecases/checkUserBelongsToLearnersOrganization_test.js +++ b/api/tests/unit/application/usecases/checkUserBelongsToLearnersOrganization_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const usecase = require('../../../../lib/application/usecases/checkUserBelongsToLearnersOrganization'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as usecase from '../../../../lib/application/usecases/checkUserBelongsToLearnersOrganization.js'; describe('Unit | Application | Use Case | checkUserBelongsToLearnersOrganization', function () { let membershipRepositoryStub; diff --git a/api/tests/unit/application/usecases/checkUserBelongsToOrganizationManagingStudents_test.js b/api/tests/unit/application/usecases/checkUserBelongsToOrganizationManagingStudents_test.js index 9dd271a87d7..94bb9ad73b7 100644 --- a/api/tests/unit/application/usecases/checkUserBelongsToOrganizationManagingStudents_test.js +++ b/api/tests/unit/application/usecases/checkUserBelongsToOrganizationManagingStudents_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const usecase = require('../../../../lib/application/usecases/checkUserBelongsToOrganizationManagingStudents'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as usecase from '../../../../lib/application/usecases/checkUserBelongsToOrganizationManagingStudents.js'; describe('Unit | Application | Use Case | checkUserBelongsToOrganizationManagingStudents', function () { let membershipRepositoryStub; diff --git a/api/tests/unit/application/usecases/checkUserBelongsToOrganization_test.js b/api/tests/unit/application/usecases/checkUserBelongsToOrganization_test.js index ceb017b3799..8340baf27ad 100644 --- a/api/tests/unit/application/usecases/checkUserBelongsToOrganization_test.js +++ b/api/tests/unit/application/usecases/checkUserBelongsToOrganization_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkUserBelongsToOrganization'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as useCase from '../../../../lib/application/usecases/checkUserBelongsToOrganization.js'; describe('Unit | Application | Use Case | checkUserBelongsToOrganization', function () { let membershipRepositoryStub; diff --git a/api/tests/unit/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents_test.js b/api/tests/unit/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents_test.js index 3d9b97af91c..1dc022ae32e 100644 --- a/api/tests/unit/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents_test.js +++ b/api/tests/unit/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as useCase from '../../../../lib/application/usecases/checkUserBelongsToScoOrganizationAndManagesStudents.js'; describe('Unit | Application | Use Case | checkUserBelongsToScoOrganizationAndManagesStudents', function () { let membershipRepositoryStub; diff --git a/api/tests/unit/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents_test.js b/api/tests/unit/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents_test.js index dff54f02dce..135a67e939b 100644 --- a/api/tests/unit/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents_test.js +++ b/api/tests/unit/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as useCase from '../../../../lib/application/usecases/checkUserBelongsToSupOrganizationAndManagesStudents.js'; describe('Unit | Application | Use Case | checkUserBelongsToSupOrganizationAndManagesStudents', function () { let membershipRepositoryStub; diff --git a/api/tests/unit/application/usecases/checkUserIsAdminInOrganization_test.js b/api/tests/unit/application/usecases/checkUserIsAdminInOrganization_test.js index e453b1929fd..1bb99d0ed94 100644 --- a/api/tests/unit/application/usecases/checkUserIsAdminInOrganization_test.js +++ b/api/tests/unit/application/usecases/checkUserIsAdminInOrganization_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const useCase = require('../../../../lib/application/usecases/checkUserIsAdminInOrganization'); -const Membership = require('../../../../lib/domain/models/Membership'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as useCase from '../../../../lib/application/usecases/checkUserIsAdminInOrganization.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; describe('Unit | Application | Use Case | CheckUserIsAdminInOrganization', function () { let membershipRepositoryStub; diff --git a/api/tests/unit/application/usecases/checkUserIsMemberOfCertificationCenterSession_test.js b/api/tests/unit/application/usecases/checkUserIsMemberOfCertificationCenterSession_test.js index dee014635da..7f9078a0d37 100644 --- a/api/tests/unit/application/usecases/checkUserIsMemberOfCertificationCenterSession_test.js +++ b/api/tests/unit/application/usecases/checkUserIsMemberOfCertificationCenterSession_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecase = require('../../../../lib/application/usecases/checkUserIsMemberOfCertificationCenterSession'); +import { expect, sinon } from '../../../test-helper.js'; +import * as usecase from '../../../../lib/application/usecases/checkUserIsMemberOfCertificationCenterSession.js'; describe('Unit | Application | Use Case | CheckUserIsMemberOfCertificationCenterSession', function () { let certificationCourseRepositoryStub; diff --git a/api/tests/unit/application/usecases/checkUserIsMemberOfCertificationCenter_test.js b/api/tests/unit/application/usecases/checkUserIsMemberOfCertificationCenter_test.js index 0efaf662744..9e068d2edea 100644 --- a/api/tests/unit/application/usecases/checkUserIsMemberOfCertificationCenter_test.js +++ b/api/tests/unit/application/usecases/checkUserIsMemberOfCertificationCenter_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const usecase = require('../../../../lib/application/usecases/checkUserIsMemberOfCertificationCenter'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as usecase from '../../../../lib/application/usecases/checkUserIsMemberOfCertificationCenter.js'; describe('Unit | Application | Use Case | CheckUserIsMemberOfCertificationCenter', function () { let certificationCenterMembershipRepositoryStub; diff --git a/api/tests/unit/application/usecases/checkUserOwnsCertificationCourse_test.js b/api/tests/unit/application/usecases/checkUserOwnsCertificationCourse_test.js index 7ea14ce0541..41a7f6d3225 100644 --- a/api/tests/unit/application/usecases/checkUserOwnsCertificationCourse_test.js +++ b/api/tests/unit/application/usecases/checkUserOwnsCertificationCourse_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecase = require('../../../../lib/application/usecases/checkUserOwnsCertificationCourse'); +import { expect, sinon } from '../../../test-helper.js'; +import * as usecase from '../../../../lib/application/usecases/checkUserOwnsCertificationCourse.js'; describe('Unit | Application | Use Case | checkUserOwnsCertificationCourse', function () { context('When user is member of certification center session', function () { diff --git a/api/tests/unit/application/user-orga-settings/index_test.js b/api/tests/unit/application/user-orga-settings/index_test.js index b00cfa3ac43..22d570d8c0a 100644 --- a/api/tests/unit/application/user-orga-settings/index_test.js +++ b/api/tests/unit/application/user-orga-settings/index_test.js @@ -1,6 +1,6 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const userOrgaSettingsController = require('../../../../lib/application/user-orga-settings/user-orga-settings-controller'); -const moduleUnderTest = require('../../../../lib/application/user-orga-settings'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { userOrgaSettingsController } from '../../../../lib/application/user-orga-settings/user-orga-settings-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/user-orga-settings/index.js'; describe('Unit | Router | user-orga-settings-router', function () { describe('PUT /api/user-orga-settings/{id}', function () { diff --git a/api/tests/unit/application/user-orga-settings/user-orga-settings-controller_test.js b/api/tests/unit/application/user-orga-settings/user-orga-settings-controller_test.js index 0573b29fcea..c9b0f51fcee 100644 --- a/api/tests/unit/application/user-orga-settings/user-orga-settings-controller_test.js +++ b/api/tests/unit/application/user-orga-settings/user-orga-settings-controller_test.js @@ -1,8 +1,6 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); - -const userOrgaSettingsController = require('../../../../lib/application/user-orga-settings/user-orga-settings-controller'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { userOrgaSettingsController } from '../../../../lib/application/user-orga-settings/user-orga-settings-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Controller | user-orga-settings-controller', function () { describe('#createOrUpdate', function () { diff --git a/api/tests/unit/application/user-tutorials/index_test.js b/api/tests/unit/application/user-tutorials/index_test.js index b14fbbd4927..ab49011dd46 100644 --- a/api/tests/unit/application/user-tutorials/index_test.js +++ b/api/tests/unit/application/user-tutorials/index_test.js @@ -1,7 +1,7 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const userTutorialsController = require('../../../../lib/application/user-tutorials/user-tutorials-controller'); -const moduleUnderTest = require('../../../../lib/application/user-tutorials'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { userTutorialsController } from '../../../../lib/application/user-tutorials/user-tutorials-controller.js'; +import * as moduleUnderTest from '../../../../lib/application/user-tutorials/index.js'; describe('Unit | Router | user-tutorials-router', function () { describe('GET /api/users/{userId}/tutorials', function () { diff --git a/api/tests/unit/application/user-tutorials/user-tutorials-controller_test.js b/api/tests/unit/application/user-tutorials/user-tutorials-controller_test.js index e2ae00b948a..dca25c5514d 100644 --- a/api/tests/unit/application/user-tutorials/user-tutorials-controller_test.js +++ b/api/tests/unit/application/user-tutorials/user-tutorials-controller_test.js @@ -1,6 +1,6 @@ -const { sinon, expect, hFake } = require('../../../test-helper'); -const userTutorialsController = require('../../../../lib/application/user-tutorials/user-tutorials-controller'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { sinon, expect, hFake } from '../../../test-helper.js'; +import { userTutorialsController } from '../../../../lib/application/user-tutorials/user-tutorials-controller.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | Controller | User-tutorials', function () { describe('#add', function () { diff --git a/api/tests/unit/application/users/index_test.js b/api/tests/unit/application/users/index_test.js index 53ff847f433..14768ec5900 100644 --- a/api/tests/unit/application/users/index_test.js +++ b/api/tests/unit/application/users/index_test.js @@ -1,10 +1,9 @@ -const { expect, HttpTestServer, sinon } = require('../../../test-helper'); - -const securityPreHandlers = require('../../../../lib/application/security-pre-handlers'); -const userVerification = require('../../../../lib/application/preHandlers/user-existence-verification'); -const userController = require('../../../../lib/application/users/user-controller'); -const moduleUnderTest = require('../../../../lib/application/users'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); +import { expect, HttpTestServer, sinon } from '../../../test-helper.js'; +import { securityPreHandlers } from '../../../../lib/application/security-pre-handlers.js'; +import { userVerification } from '../../../../lib/application/preHandlers/user-existence-verification.js'; +import { userController } from '../../../../lib/application/users/user-controller.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; +import * as moduleUnderTest from '../../../../lib/application/users/index.js'; describe('Unit | Router | user-router', function () { describe('POST /api/users', function () { diff --git a/api/tests/unit/application/users/user-controller_test.js b/api/tests/unit/application/users/user-controller_test.js index 85a97946bfb..25fc673f3e5 100644 --- a/api/tests/unit/application/users/user-controller_test.js +++ b/api/tests/unit/application/users/user-controller_test.js @@ -1,15 +1,12 @@ -const { sinon, expect, domainBuilder, hFake } = require('../../../test-helper'); - -const User = require('../../../../lib/domain/models/User'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const queryParamsUtils = require('../../../../lib/infrastructure/utils/query-params-utils'); -const requestResponseUtils = require('../../../../lib/infrastructure/utils/request-response-utils'); -const { getI18n } = require('../../../tooling/i18n/i18n'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); - -const userController = require('../../../../lib/application/users/user-controller'); -const UserOrganizationForAdmin = require('../../../../lib/domain/read-models/UserOrganizationForAdmin'); +import { sinon, expect, domainBuilder, hFake } from '../../../test-helper.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import * as queryParamsUtils from '../../../../lib/infrastructure/utils/query-params-utils.js'; +import * as requestResponseUtils from '../../../../lib/infrastructure/utils/request-response-utils.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { userController } from '../../../../lib/application/users/user-controller.js'; +import { UserOrganizationForAdmin } from '../../../../lib/domain/read-models/UserOrganizationForAdmin.js'; describe('Unit | Controller | user-controller', function () { let userSerializer; diff --git a/api/tests/unit/domain/errors_test.js b/api/tests/unit/domain/errors_test.js index 802b2ef9dea..85971841f2d 100644 --- a/api/tests/unit/domain/errors_test.js +++ b/api/tests/unit/domain/errors_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../test-helper'); -const errors = require('../../../lib/domain/errors'); +import { expect } from '../../test-helper.js'; +import * as errors from '../../../lib/domain/errors.js'; describe('Unit | Domain | Errors', function () { it('should export a AdminMemberError', function () { diff --git a/api/tests/unit/domain/events/AssessmentCompleted_test.js b/api/tests/unit/domain/events/AssessmentCompleted_test.js index 2509d8cee96..5b4f55c888d 100644 --- a/api/tests/unit/domain/events/AssessmentCompleted_test.js +++ b/api/tests/unit/domain/events/AssessmentCompleted_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const AssessmentCompleted = require('../../../../lib/domain/events/AssessmentCompleted'); +import { expect } from '../../../test-helper.js'; +import { AssessmentCompleted } from '../../../../lib/domain/events/AssessmentCompleted.js'; describe('Unit | Domain | Events | AssessmentCompleted', function () { describe('#isCertificationType', function () { diff --git a/api/tests/unit/domain/events/check-event-type_test.js b/api/tests/unit/domain/events/check-event-type_test.js index 64f10e3b584..7cf492dd158 100644 --- a/api/tests/unit/domain/events/check-event-type_test.js +++ b/api/tests/unit/domain/events/check-event-type_test.js @@ -1,5 +1,5 @@ -const { expect, catchErr } = require('../../../test-helper'); -const { checkEventTypes } = require('../../../../lib/domain/events/check-event-types'); +import { expect, catchErr } from '../../../test-helper.js'; +import { checkEventTypes } from '../../../../lib/domain/events/check-event-types.js'; describe('Unit | Domain | Events | check-event-types', function () { it('throw with right message when event of wrong type ', async function () { diff --git a/api/tests/unit/domain/events/event-choreography-certification-rescoring-after-jury_test.js b/api/tests/unit/domain/events/event-choreography-certification-rescoring-after-jury_test.js index 136059a386b..b1beb7844a9 100644 --- a/api/tests/unit/domain/events/event-choreography-certification-rescoring-after-jury_test.js +++ b/api/tests/unit/domain/events/event-choreography-certification-rescoring-after-jury_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const buildEventDispatcherAndHandlersForTest = require('../../../tooling/events/event-dispatcher-builder'); -const CertificationJuryDone = require('../../../../lib/domain/events/CertificationJuryDone'); +import { expect } from '../../../test-helper.js'; +import { buildEventDispatcherAndHandlersForTest } from '../../../tooling/events/event-dispatcher-builder.js'; +import { CertificationJuryDone } from '../../../../lib/domain/events/CertificationJuryDone.js'; describe('Event Choreography | CertificationJuryDone', function () { it('Should trigger the certification rescoring', async function () { diff --git a/api/tests/unit/domain/events/event-choreography-finalized-session_test.js b/api/tests/unit/domain/events/event-choreography-finalized-session_test.js index e4ee5f51cd5..b04c5f71e8d 100644 --- a/api/tests/unit/domain/events/event-choreography-finalized-session_test.js +++ b/api/tests/unit/domain/events/event-choreography-finalized-session_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../test-helper'); -const buildEventDispatcherAndHandlersForTest = require('../../../tooling/events/event-dispatcher-builder'); -const SessionFinalized = require('../../../../lib/domain/events/SessionFinalized'); -const AutoJuryDone = require('../../../../lib/domain/events/AutoJuryDone'); +import { expect } from '../../../test-helper.js'; +import { buildEventDispatcherAndHandlersForTest } from '../../../tooling/events/event-dispatcher-builder.js'; +import { SessionFinalized } from '../../../../lib/domain/events/SessionFinalized.js'; +import { AutoJuryDone } from '../../../../lib/domain/events/AutoJuryDone.js'; describe('Event Choreography | Finalized session', function () { it('Should trigger the automated jury', async function () { diff --git a/api/tests/unit/domain/events/event-choreography-pole-emploi-participation-finished_test.js b/api/tests/unit/domain/events/event-choreography-pole-emploi-participation-finished_test.js index 59ecfdef25d..14cdb27bd60 100644 --- a/api/tests/unit/domain/events/event-choreography-pole-emploi-participation-finished_test.js +++ b/api/tests/unit/domain/events/event-choreography-pole-emploi-participation-finished_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const buildEventDispatcherAndHandlersForTest = require('../../../tooling/events/event-dispatcher-builder'); -const AssessmentCompleted = require('../../../../lib/domain/events/AssessmentCompleted'); +import { expect } from '../../../test-helper.js'; +import { buildEventDispatcherAndHandlersForTest } from '../../../tooling/events/event-dispatcher-builder.js'; +import { AssessmentCompleted } from '../../../../lib/domain/events/AssessmentCompleted.js'; describe('Event Choreography | Pole Emploi Participation Finished', function () { it('Should trigger Pole Emploi participation finished handler on AssessmentCompleted event', async function () { diff --git a/api/tests/unit/domain/events/event-choreography-pole-emploi-participation-started_test.js b/api/tests/unit/domain/events/event-choreography-pole-emploi-participation-started_test.js index bd273197180..5a5ade25795 100644 --- a/api/tests/unit/domain/events/event-choreography-pole-emploi-participation-started_test.js +++ b/api/tests/unit/domain/events/event-choreography-pole-emploi-participation-started_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const buildEventDispatcherAndHandlersForTest = require('../../../tooling/events/event-dispatcher-builder'); -const CampaignParticipationStarted = require('../../../../lib/domain/events/CampaignParticipationStarted'); +import { expect } from '../../../test-helper.js'; +import { buildEventDispatcherAndHandlersForTest } from '../../../tooling/events/event-dispatcher-builder.js'; +import { CampaignParticipationStarted } from '../../../../lib/domain/events/CampaignParticipationStarted.js'; describe('Event Choreography | Pole Emploi Participation Started', function () { it('Should trigger Pole Emploi participation started handler on CampaignParticipationStarted event', async function () { diff --git a/api/tests/unit/domain/events/event-choreography-rescore-certification_test.js b/api/tests/unit/domain/events/event-choreography-rescore-certification_test.js index cf3ff212c55..41d8ee5442f 100644 --- a/api/tests/unit/domain/events/event-choreography-rescore-certification_test.js +++ b/api/tests/unit/domain/events/event-choreography-rescore-certification_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../test-helper'); -const buildEventDispatcherAndHandlersForTest = require('../../../tooling/events/event-dispatcher-builder'); -const ChallengeNeutralized = require('../../../../lib/domain/events/ChallengeNeutralized'); -const ChallengeDeneutralized = require('../../../../lib/domain/events/ChallengeDeneutralized'); +import { expect } from '../../../test-helper.js'; +import { buildEventDispatcherAndHandlersForTest } from '../../../tooling/events/event-dispatcher-builder.js'; +import { ChallengeNeutralized } from '../../../../lib/domain/events/ChallengeNeutralized.js'; +import { ChallengeDeneutralized } from '../../../../lib/domain/events/ChallengeDeneutralized.js'; describe('Event Choreography | Rescore Certification', function () { it('Should trigger Certification Rescoring handler on ChallengeNeutralized event', async function () { diff --git a/api/tests/unit/domain/events/event-choreography-score-certification_test.js b/api/tests/unit/domain/events/event-choreography-score-certification_test.js index 75d341b1dfc..8a972e1387f 100644 --- a/api/tests/unit/domain/events/event-choreography-score-certification_test.js +++ b/api/tests/unit/domain/events/event-choreography-score-certification_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const buildEventDispatcherAndHandlersForTest = require('../../../tooling/events/event-dispatcher-builder'); -const AssessmentCompleted = require('../../../../lib/domain/events/AssessmentCompleted'); +import { expect } from '../../../test-helper.js'; +import { buildEventDispatcherAndHandlersForTest } from '../../../tooling/events/event-dispatcher-builder.js'; +import { AssessmentCompleted } from '../../../../lib/domain/events/AssessmentCompleted.js'; describe('Event Choreography | Score Certification', function () { it('Should trigger Certification Scoring handler on Assessment Completed event', async function () { diff --git a/api/tests/unit/domain/events/event-choreography-score-pix-plus-certification_test.js b/api/tests/unit/domain/events/event-choreography-score-pix-plus-certification_test.js index 22d8c46b3ef..b0c5c88251c 100644 --- a/api/tests/unit/domain/events/event-choreography-score-pix-plus-certification_test.js +++ b/api/tests/unit/domain/events/event-choreography-score-pix-plus-certification_test.js @@ -1,8 +1,8 @@ -const { expect } = require('../../../test-helper'); -const buildEventDispatcherAndHandlersForTest = require('../../../tooling/events/event-dispatcher-builder'); -const AssessmentCompleted = require('../../../../lib/domain/events/AssessmentCompleted'); -const CertificationScoringCompleted = require('../../../../lib/domain/events/CertificationScoringCompleted'); -const CertificationRescoringCompleted = require('../../../../lib/domain/events/CertificationRescoringCompleted'); +import { expect } from '../../../test-helper.js'; +import { buildEventDispatcherAndHandlersForTest } from '../../../tooling/events/event-dispatcher-builder.js'; +import { AssessmentCompleted } from '../../../../lib/domain/events/AssessmentCompleted.js'; +import { CertificationScoringCompleted } from '../../../../lib/domain/events/CertificationScoringCompleted.js'; +import { CertificationRescoringCompleted } from '../../../../lib/domain/events/CertificationRescoringCompleted.js'; describe('Event Choreography | Score Pix+ Certification', function () { it('chains Certification Scoring and Pix+ Certification Scoring on Certification Scoring Completed', async function () { diff --git a/api/tests/unit/domain/events/handle-auto-jury_test.js b/api/tests/unit/domain/events/handle-auto-jury_test.js index 45055f168d3..898eabdf30a 100644 --- a/api/tests/unit/domain/events/handle-auto-jury_test.js +++ b/api/tests/unit/domain/events/handle-auto-jury_test.js @@ -1,13 +1,13 @@ -const { sinon, expect, catchErr, domainBuilder } = require('../../../test-helper'); -const handleAutoJury = require('../../../../lib/domain/events/handle-auto-jury'); -const SessionFinalized = require('../../../../lib/domain/events/SessionFinalized'); -const AutoJuryDone = require('../../../../lib/domain/events/AutoJuryDone'); -const CertificationJuryDone = require('../../../../lib/domain/events/CertificationJuryDone'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const { +import { sinon, expect, catchErr, domainBuilder } from '../../../test-helper.js'; +import { handleAutoJury } from '../../../../lib/domain/events/handle-auto-jury.js'; +import { SessionFinalized } from '../../../../lib/domain/events/SessionFinalized.js'; +import { AutoJuryDone } from '../../../../lib/domain/events/AutoJuryDone.js'; +import { CertificationJuryDone } from '../../../../lib/domain/events/CertificationJuryDone.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { CertificationIssueReportSubcategories, - CertificationIssueReportCategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); + CertificationIssueReportCategory, +} from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; describe('Unit | Domain | Events | handle-auto-jury', function () { it('fails when event is not of correct type', async function () { @@ -49,12 +49,12 @@ describe('Unit | Domain | Events | handle-auto-jury', function () { }); const certificationCourse = domainBuilder.buildCertificationCourse(); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, subcategory: CertificationIssueReportSubcategories.WEBSITE_BLOCKED, questionNumber: 1, }); const certificationIssueReport2 = domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.FRAUD, + category: CertificationIssueReportCategory.FRAUD, subcategory: undefined, questionNumber: 1, }); @@ -170,7 +170,7 @@ describe('Unit | Domain | Events | handle-auto-jury', function () { }); const certificationCourse = domainBuilder.buildCertificationCourse(); const certificationIssueReport1 = domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, subcategory: CertificationIssueReportSubcategories.WEBSITE_BLOCKED, questionNumber: 1, }); @@ -593,7 +593,7 @@ describe('Unit | Domain | Events | handle-auto-jury', function () { }); const certificationCourse = domainBuilder.buildCertificationCourse({ id: 4567, sessionId: 1234 }); const certificationIssueReport1 = domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.FRAUD, + category: CertificationIssueReportCategory.FRAUD, subcategory: null, questionNumber: 1, }); @@ -659,12 +659,12 @@ describe('Unit | Domain | Events | handle-auto-jury', function () { }); const certificationCourse = domainBuilder.buildCertificationCourse({ id: 4567, sessionId: 1234 }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, subcategory: CertificationIssueReportSubcategories.IMAGE_NOT_DISPLAYING, questionNumber: 1, }); const certificationIssueReport2 = domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, subcategory: CertificationIssueReportSubcategories.WEBSITE_BLOCKED, questionNumber: 1, }); diff --git a/api/tests/unit/domain/events/handle-certification-rescoring_test.js b/api/tests/unit/domain/events/handle-certification-rescoring_test.js index 9f92cfc9f10..9d274d33b75 100644 --- a/api/tests/unit/domain/events/handle-certification-rescoring_test.js +++ b/api/tests/unit/domain/events/handle-certification-rescoring_test.js @@ -1,12 +1,13 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const { handleCertificationRescoring } = require('../../../../lib/domain/events')._forTestOnly.handlers; -const ChallengeNeutralized = require('../../../../lib/domain/events/ChallengeNeutralized'); -const ChallengeDeneutralized = require('../../../../lib/domain/events/ChallengeDeneutralized'); -const CertificationJuryDone = require('../../../../lib/domain/events/CertificationJuryDone'); -const CertificationAssessment = require('../../../../lib/domain/models/CertificationAssessment'); -const CertificationResult = require('../../../../lib/domain/models/CertificationResult'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const { CertificationComputeError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { _forTestOnly } from '../../../../lib/domain/events/index.js'; +const { handleCertificationRescoring } = _forTestOnly.handlers; +import { ChallengeNeutralized } from '../../../../lib/domain/events/ChallengeNeutralized.js'; +import { ChallengeDeneutralized } from '../../../../lib/domain/events/ChallengeDeneutralized.js'; +import { CertificationJuryDone } from '../../../../lib/domain/events/CertificationJuryDone.js'; +import { CertificationAssessment } from '../../../../lib/domain/models/CertificationAssessment.js'; +import { CertificationResult } from '../../../../lib/domain/models/CertificationResult.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import { CertificationComputeError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Events | handle-certification-rescoring', function () { it('computes and persists the assessment result and competence marks when computation succeeds', async function () { diff --git a/api/tests/unit/domain/events/handle-certification-scoring_test.js b/api/tests/unit/domain/events/handle-certification-scoring_test.js index 2258cb21167..e091bf9485d 100644 --- a/api/tests/unit/domain/events/handle-certification-scoring_test.js +++ b/api/tests/unit/domain/events/handle-certification-scoring_test.js @@ -1,10 +1,11 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { handleCertificationScoring } = require('../../../../lib/domain/events')._forTestOnly.handlers; -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const { CertificationComputeError } = require('../../../../lib/domain/errors'); -const AssessmentCompleted = require('../../../../lib/domain/events/AssessmentCompleted'); -const CertificationCourse = require('../../../../lib/domain/models/CertificationCourse'); -const CertificationScoringCompleted = require('../../../../lib/domain/events/CertificationScoringCompleted'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { _forTestOnly } from '../../../../lib/domain/events/index.js'; +const { handleCertificationScoring } = _forTestOnly.handlers; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import { CertificationComputeError } from '../../../../lib/domain/errors.js'; +import { AssessmentCompleted } from '../../../../lib/domain/events/AssessmentCompleted.js'; +import { CertificationCourse } from '../../../../lib/domain/models/CertificationCourse.js'; +import { CertificationScoringCompleted } from '../../../../lib/domain/events/CertificationScoringCompleted.js'; describe('Unit | Domain | Events | handle-certification-scoring', function () { let scoringCertificationService; diff --git a/api/tests/unit/domain/events/handle-complementary-certifications-scoring_test.js b/api/tests/unit/domain/events/handle-complementary-certifications-scoring_test.js index b6341e88d0c..17c0bea0f99 100644 --- a/api/tests/unit/domain/events/handle-complementary-certifications-scoring_test.js +++ b/api/tests/unit/domain/events/handle-complementary-certifications-scoring_test.js @@ -1,7 +1,8 @@ -const { ReproducibilityRate } = require('../../../../lib/domain/models/ReproducibilityRate'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); -const { catchErr, expect, sinon, domainBuilder } = require('../../../test-helper'); -const { handleComplementaryCertificationsScoring } = require('../../../../lib/domain/events')._forTestOnly.handlers; +import { ReproducibilityRate } from '../../../../lib/domain/models/ReproducibilityRate.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; +import { catchErr, expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { _forTestOnly } from '../../../../lib/domain/events/index.js'; +const { handleComplementaryCertificationsScoring } = _forTestOnly.handlers; describe('Unit | Domain | Events | handle-complementary-certification-certifications-scoring', function () { const certificationAssessmentRepository = {}; diff --git a/api/tests/unit/domain/events/handle-pole-emploi-participation-finished_test.js b/api/tests/unit/domain/events/handle-pole-emploi-participation-finished_test.js index 412dd3b4884..a91851a28d0 100644 --- a/api/tests/unit/domain/events/handle-pole-emploi-participation-finished_test.js +++ b/api/tests/unit/domain/events/handle-pole-emploi-participation-finished_test.js @@ -1,8 +1,9 @@ -const { catchErr, expect, sinon, domainBuilder } = require('../../../test-helper'); -const AssessmentCompleted = require('../../../../lib/domain/events/AssessmentCompleted'); -const PoleEmploiSending = require('../../../../lib/domain/models/PoleEmploiSending'); -const PoleEmploiPayload = require('../../../../lib/infrastructure/externals/pole-emploi/PoleEmploiPayload'); -const { handlePoleEmploiParticipationFinished } = require('../../../../lib/domain/events')._forTestOnly.handlers; +import { catchErr, expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { AssessmentCompleted } from '../../../../lib/domain/events/AssessmentCompleted.js'; +import { PoleEmploiSending } from '../../../../lib/domain/models/PoleEmploiSending.js'; +import { PoleEmploiPayload } from '../../../../lib/infrastructure/externals/pole-emploi/PoleEmploiPayload.js'; +import { _forTestOnly } from '../../../../lib/domain/events/index.js'; +const { handlePoleEmploiParticipationFinished } = _forTestOnly.handlers; describe('Unit | Domain | Events | handle-pole-emploi-participation-finished', function () { let event, dependencies, expectedResults; diff --git a/api/tests/unit/domain/events/handle-pole-emploi-participation-started_test.js b/api/tests/unit/domain/events/handle-pole-emploi-participation-started_test.js index f08fd3a04e4..154936cb7d1 100644 --- a/api/tests/unit/domain/events/handle-pole-emploi-participation-started_test.js +++ b/api/tests/unit/domain/events/handle-pole-emploi-participation-started_test.js @@ -1,8 +1,9 @@ -const { catchErr, expect, sinon, domainBuilder } = require('../../../test-helper'); -const CampaignParticipationStarted = require('../../../../lib/domain/events/CampaignParticipationStarted'); -const PoleEmploiSending = require('../../../../lib/domain/models/PoleEmploiSending'); -const PoleEmploiPayload = require('../../../../lib/infrastructure/externals/pole-emploi/PoleEmploiPayload'); -const { handlePoleEmploiParticipationStarted } = require('../../../../lib/domain/events')._forTestOnly.handlers; +import { catchErr, expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { CampaignParticipationStarted } from '../../../../lib/domain/events/CampaignParticipationStarted.js'; +import { PoleEmploiSending } from '../../../../lib/domain/models/PoleEmploiSending.js'; +import { PoleEmploiPayload } from '../../../../lib/infrastructure/externals/pole-emploi/PoleEmploiPayload.js'; +import { _forTestOnly } from '../../../../lib/domain/events/index.js'; +const { handlePoleEmploiParticipationStarted } = _forTestOnly.handlers; describe('Unit | Domain | Events | handle-pole-emploi-participation-started', function () { let event, dependencies, expectedResults; diff --git a/api/tests/unit/domain/events/handle-session-finalized_test.js b/api/tests/unit/domain/events/handle-session-finalized_test.js index 4094d2f8630..db1f57d28fe 100644 --- a/api/tests/unit/domain/events/handle-session-finalized_test.js +++ b/api/tests/unit/domain/events/handle-session-finalized_test.js @@ -1,9 +1,9 @@ -const { catchErr, expect, domainBuilder, sinon } = require('../../../test-helper'); -const handleFinalizedSession = require('../../../../lib/domain/events/handle-session-finalized'); -const JuryCertificationSummary = require('../../../../lib/domain/read-models/JuryCertificationSummary'); -const { status: assessmentResultStatuses } = require('../../../../lib/domain/models/AssessmentResult'); -const AutoJuryDone = require('../../../../lib/domain/events/AutoJuryDone'); -const FinalizedSession = require('../../../../lib/domain/models/FinalizedSession'); +import { catchErr, expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { handleSessionFinalized as handleFinalizedSession } from '../../../../lib/domain/events/handle-session-finalized.js'; +import { JuryCertificationSummary } from '../../../../lib/domain/read-models/JuryCertificationSummary.js'; +import { status as assessmentResultStatuses } from '../../../../lib/domain/models/AssessmentResult.js'; +import { AutoJuryDone } from '../../../../lib/domain/events/AutoJuryDone.js'; +import { FinalizedSession } from '../../../../lib/domain/models/FinalizedSession.js'; const juryCertificationSummaryRepository = { findBySessionId: sinon.stub() }; const finalizedSessionRepository = { save: sinon.stub() }; diff --git a/api/tests/unit/domain/models/AdminMember_test.js b/api/tests/unit/domain/models/AdminMember_test.js index a67f747ddbe..bab14f9dd28 100644 --- a/api/tests/unit/domain/models/AdminMember_test.js +++ b/api/tests/unit/domain/models/AdminMember_test.js @@ -1,8 +1,10 @@ -const { expect } = require('../../../test-helper'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; -const { ObjectValidationError } = require('../../../../lib/domain/errors'); +import { expect } from '../../../test-helper.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; -const AdminMember = require('../../../../lib/domain/models/AdminMember'); +const { ROLES } = PIX_ADMIN; + +import { ObjectValidationError } from '../../../../lib/domain/errors.js'; +import { AdminMember } from '../../../../lib/domain/models/AdminMember.js'; describe('Unit | Domain | Models | AdminMember', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/AnswerCollectionForScoring_test.js b/api/tests/unit/domain/models/AnswerCollectionForScoring_test.js index e50fe23894c..c662fadb2d2 100644 --- a/api/tests/unit/domain/models/AnswerCollectionForScoring_test.js +++ b/api/tests/unit/domain/models/AnswerCollectionForScoring_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const AnswerCollectionForScoring = require('../../../../lib/domain/models/AnswerCollectionForScoring'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { AnswerCollectionForScoring } from '../../../../lib/domain/models/AnswerCollectionForScoring.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; describe('Unit | Domain | Models | AnswerCollectionForScoring', function () { context('#numberOfChallenges', function () { diff --git a/api/tests/unit/domain/models/AnswerStatus_test.js b/api/tests/unit/domain/models/AnswerStatus_test.js index 8cf564ca45c..cf5538f1cf6 100644 --- a/api/tests/unit/domain/models/AnswerStatus_test.js +++ b/api/tests/unit/domain/models/AnswerStatus_test.js @@ -1,5 +1,8 @@ -const { expect } = require('chai'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); +import chai from 'chai'; + +const { expect } = chai; + +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; describe('AnswerStatus', function () { context('AnswerStatus#isOK', function () { diff --git a/api/tests/unit/domain/models/Answer_test.js b/api/tests/unit/domain/models/Answer_test.js index a7095dc46fe..e976e09cbac 100644 --- a/api/tests/unit/domain/models/Answer_test.js +++ b/api/tests/unit/domain/models/Answer_test.js @@ -1,6 +1,6 @@ -const Answer = require('../../../../lib/domain/models/Answer'); -const Skill = require('../../../../lib/domain/models/Skill'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { Answer } from '../../../../lib/domain/models/Answer.js'; +import { Skill } from '../../../../lib/domain/models/Skill.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | Answer', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/AssessmentResult_test.js b/api/tests/unit/domain/models/AssessmentResult_test.js index 283ce6c50e3..1b8ec11c00e 100644 --- a/api/tests/unit/domain/models/AssessmentResult_test.js +++ b/api/tests/unit/domain/models/AssessmentResult_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Unit | Domain | Models | AssessmentResult', function () { describe('#buildAlgoErrorResult', function () { diff --git a/api/tests/unit/domain/models/Assessment_test.js b/api/tests/unit/domain/models/Assessment_test.js index 07eba66240f..0c60c8cf994 100644 --- a/api/tests/unit/domain/models/Assessment_test.js +++ b/api/tests/unit/domain/models/Assessment_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Unit | Domain | Models | Assessment', function () { describe('#constuctor', function () { diff --git a/api/tests/unit/domain/models/AuthenticationMethod_test.js b/api/tests/unit/domain/models/AuthenticationMethod_test.js index 00911f4dfb0..beb72f3b476 100644 --- a/api/tests/unit/domain/models/AuthenticationMethod_test.js +++ b/api/tests/unit/domain/models/AuthenticationMethod_test.js @@ -1,8 +1,7 @@ -const { expect } = require('../../../test-helper'); -const { ObjectValidationError } = require('../../../../lib/domain/errors'); - -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); +import { expect } from '../../../test-helper.js'; +import { ObjectValidationError } from '../../../../lib/domain/errors.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; describe('Unit | Domain | Models | AuthenticationMethod', function () { describe('buildPixAuthenticationMethod', function () { diff --git a/api/tests/unit/domain/models/AuthenticationSessionContent_test.js b/api/tests/unit/domain/models/AuthenticationSessionContent_test.js index 4760d4d87a1..b1a9f3c4305 100644 --- a/api/tests/unit/domain/models/AuthenticationSessionContent_test.js +++ b/api/tests/unit/domain/models/AuthenticationSessionContent_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const AuthenticationSessionContent = require('../../../../lib/domain/models/AuthenticationSessionContent'); +import { expect } from '../../../test-helper.js'; +import { AuthenticationSessionContent } from '../../../../lib/domain/models/AuthenticationSessionContent.js'; describe('Unit | Domain | Models | AuthenticationSessionContent', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/BadgeAcquisition_test.js b/api/tests/unit/domain/models/BadgeAcquisition_test.js index 3b17c23945c..284733e13d5 100644 --- a/api/tests/unit/domain/models/BadgeAcquisition_test.js +++ b/api/tests/unit/domain/models/BadgeAcquisition_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | BadgeAcquisition', function () { describe('#get badgeKey', function () { diff --git a/api/tests/unit/domain/models/BadgeForCalculation_test.js b/api/tests/unit/domain/models/BadgeForCalculation_test.js index 10ab113705b..a39c9dcb145 100644 --- a/api/tests/unit/domain/models/BadgeForCalculation_test.js +++ b/api/tests/unit/domain/models/BadgeForCalculation_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | BadgeForCalculation', function () { describe('#shouldBeObtained', function () { diff --git a/api/tests/unit/domain/models/CampaignCreator_test.js b/api/tests/unit/domain/models/CampaignCreator_test.js index 0139c78d51b..313fdfe7bf1 100644 --- a/api/tests/unit/domain/models/CampaignCreator_test.js +++ b/api/tests/unit/domain/models/CampaignCreator_test.js @@ -1,8 +1,8 @@ -const CampaignCreator = require('../../../../lib/domain/models/CampaignCreator'); -const { expect, catchErr } = require('../../../test-helper'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignForCreation = require('../../../../lib/domain/models/CampaignForCreation'); -const { UserNotAuthorizedToCreateCampaignError, EntityValidationError } = require('../../../../lib/domain/errors'); +import { CampaignCreator } from '../../../../lib/domain/models/CampaignCreator.js'; +import { expect, catchErr } from '../../../test-helper.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignForCreation } from '../../../../lib/domain/models/CampaignForCreation.js'; +import { UserNotAuthorizedToCreateCampaignError, EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | CampaignCreator', function () { describe('#createCampaign', function () { diff --git a/api/tests/unit/domain/models/CampaignForArchiving_test.js b/api/tests/unit/domain/models/CampaignForArchiving_test.js index 2d4edb211e8..5bd4621132d 100644 --- a/api/tests/unit/domain/models/CampaignForArchiving_test.js +++ b/api/tests/unit/domain/models/CampaignForArchiving_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr } = require('../../../test-helper'); -const Campaign = require('../../../../lib/domain/models/CampaignForArchiving'); -const { ArchivedCampaignError, ObjectValidationError } = require('../../../../lib/domain/errors'); +import { expect, catchErr } from '../../../test-helper.js'; +import { CampaignForArchiving as Campaign } from '../../../../lib/domain/models/CampaignForArchiving.js'; +import { ArchivedCampaignError, ObjectValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | CampaignForArchiving', function () { describe('#archive', function () { diff --git a/api/tests/unit/domain/models/CampaignForCreation_test.js b/api/tests/unit/domain/models/CampaignForCreation_test.js index 1e820048020..0796cdd8af3 100644 --- a/api/tests/unit/domain/models/CampaignForCreation_test.js +++ b/api/tests/unit/domain/models/CampaignForCreation_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr } = require('../../../test-helper'); -const CampaignForCreation = require('../../../../lib/domain/models/CampaignForCreation'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); +import { expect, catchErr } from '../../../test-helper.js'; +import { CampaignForCreation } from '../../../../lib/domain/models/CampaignForCreation.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; describe('Unit | Domain | Models | CampaignForCreation', function () { describe('#create', function () { diff --git a/api/tests/unit/domain/models/CampaignParticipant_test.js b/api/tests/unit/domain/models/CampaignParticipant_test.js index ae8e00a33c2..7c489b6866b 100644 --- a/api/tests/unit/domain/models/CampaignParticipant_test.js +++ b/api/tests/unit/domain/models/CampaignParticipant_test.js @@ -1,10 +1,11 @@ -const CampaignParticipant = require('../../../../lib/domain/models/CampaignParticipant'); -const { expect, domainBuilder, catchErr } = require('../../../test-helper'); -const { +import { CampaignParticipant } from '../../../../lib/domain/models/CampaignParticipant.js'; +import { expect, domainBuilder, catchErr } from '../../../test-helper.js'; + +import { EntityValidationError, ForbiddenAccess, AlreadyExistingCampaignParticipationError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | CampaignParticipant', function () { describe('#start', function () { diff --git a/api/tests/unit/domain/models/CampaignParticipationResult_test.js b/api/tests/unit/domain/models/CampaignParticipationResult_test.js index 2a35ce079b6..9de9b6f2c9c 100644 --- a/api/tests/unit/domain/models/CampaignParticipationResult_test.js +++ b/api/tests/unit/domain/models/CampaignParticipationResult_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../test-helper'); -const Area = require('../../../../lib/domain/models/Area'); -const CampaignParticipationResult = require('../../../../lib/domain/models/CampaignParticipationResult'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); +import { expect } from '../../../test-helper.js'; +import { Area } from '../../../../lib/domain/models/Area.js'; +import { CampaignParticipationResult } from '../../../../lib/domain/models/CampaignParticipationResult.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; describe('Unit | Domain | Models | CampaignParticipationResult', function () { describe('#buildFrom', function () { diff --git a/api/tests/unit/domain/models/CampaignParticipation_test.js b/api/tests/unit/domain/models/CampaignParticipation_test.js index fdbeeb3f1d0..a1b18b09588 100644 --- a/api/tests/unit/domain/models/CampaignParticipation_test.js +++ b/api/tests/unit/domain/models/CampaignParticipation_test.js @@ -1,15 +1,17 @@ -const CampaignParticipation = require('../../../../lib/domain/models/CampaignParticipation'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const { expect, domainBuilder, sinon, catchErr } = require('../../../test-helper'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { +import { CampaignParticipation } from '../../../../lib/domain/models/CampaignParticipation.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { expect, domainBuilder, sinon, catchErr } from '../../../test-helper.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; + +import { ArchivedCampaignError, AssessmentNotCompletedError, AlreadySharedCampaignParticipationError, CantImproveCampaignParticipationError, CampaignParticipationDeletedError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; + const { TO_SHARE, SHARED } = CampaignParticipationStatuses; describe('Unit | Domain | Models | CampaignParticipation', function () { diff --git a/api/tests/unit/domain/models/CampaignToStartParticipation_test.js b/api/tests/unit/domain/models/CampaignToStartParticipation_test.js index 6464bc38768..85ae593fec9 100644 --- a/api/tests/unit/domain/models/CampaignToStartParticipation_test.js +++ b/api/tests/unit/domain/models/CampaignToStartParticipation_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; describe('Unit | Domain | Models | CampaignToStartParticipation', function () { describe('#isAssessment', function () { diff --git a/api/tests/unit/domain/models/Campaign_test.js b/api/tests/unit/domain/models/Campaign_test.js index c7c3bc8e79b..13b0f63ac2a 100644 --- a/api/tests/unit/domain/models/Campaign_test.js +++ b/api/tests/unit/domain/models/Campaign_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | Campaign', function () { describe('#organizationId', function () { diff --git a/api/tests/unit/domain/models/CertifiableProfileForLearningContent_test.js b/api/tests/unit/domain/models/CertifiableProfileForLearningContent_test.js index 4b67ff24cf6..3c6a8b29070 100644 --- a/api/tests/unit/domain/models/CertifiableProfileForLearningContent_test.js +++ b/api/tests/unit/domain/models/CertifiableProfileForLearningContent_test.js @@ -1,6 +1,5 @@ -const CertifiableProfileForLearningContent = require('../../../../lib/domain/models/CertifiableProfileForLearningContent'); - -const { expect, domainBuilder } = require('../../../test-helper'); +import { CertifiableProfileForLearningContent } from '../../../../lib/domain/models/CertifiableProfileForLearningContent.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | CertifiableProfileForLearningContent', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/CertificationAssessmentScore_test.js b/api/tests/unit/domain/models/CertificationAssessmentScore_test.js index 08413bc9df7..872dd3ce8dd 100644 --- a/api/tests/unit/domain/models/CertificationAssessmentScore_test.js +++ b/api/tests/unit/domain/models/CertificationAssessmentScore_test.js @@ -1,5 +1,5 @@ -const CertificationAssessmentScore = require('../../../../lib/domain/models/CertificationAssessmentScore'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { CertificationAssessmentScore } from '../../../../lib/domain/models/CertificationAssessmentScore.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | CertificationAssessmentScore', function () { describe('#get nbPix', function () { diff --git a/api/tests/unit/domain/models/CertificationAssessment_test.js b/api/tests/unit/domain/models/CertificationAssessment_test.js index b9f47360e47..a8541b7d098 100644 --- a/api/tests/unit/domain/models/CertificationAssessment_test.js +++ b/api/tests/unit/domain/models/CertificationAssessment_test.js @@ -1,14 +1,15 @@ -const _ = require('lodash'); -const CertificationAssessment = require('../../../../lib/domain/models/CertificationAssessment'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const NeutralizationAttempt = require('../../../../lib/domain/models/NeutralizationAttempt'); -const CertificationAnswerStatusChangeAttempt = require('../../../../lib/domain/models/CertificationAnswerStatusChangeAttempt'); -const { expect, domainBuilder } = require('../../../test-helper'); -const { +import _ from 'lodash'; +import { CertificationAssessment } from '../../../../lib/domain/models/CertificationAssessment.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { NeutralizationAttempt } from '../../../../lib/domain/models/NeutralizationAttempt.js'; +import { CertificationAnswerStatusChangeAttempt } from '../../../../lib/domain/models/CertificationAnswerStatusChangeAttempt.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; + +import { ObjectValidationError, ChallengeToBeNeutralizedNotFoundError, ChallengeToBeDeneutralizedNotFoundError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | CertificationAssessment', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/CertificationAttestation_test.js b/api/tests/unit/domain/models/CertificationAttestation_test.js index 20bcf7956f9..c32780356c4 100644 --- a/api/tests/unit/domain/models/CertificationAttestation_test.js +++ b/api/tests/unit/domain/models/CertificationAttestation_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | CertificationAttestation', function () { context('#setResultCompetenceTree', function () { diff --git a/api/tests/unit/domain/models/CertificationCandidateForSupervising_test.js b/api/tests/unit/domain/models/CertificationCandidateForSupervising_test.js index 9f48d47ba8d..ede974bf279 100644 --- a/api/tests/unit/domain/models/CertificationCandidateForSupervising_test.js +++ b/api/tests/unit/domain/models/CertificationCandidateForSupervising_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | Certification Candidate for supervising', function () { describe('#authorizeToStart', function () { diff --git a/api/tests/unit/domain/models/CertificationCandidate_test.js b/api/tests/unit/domain/models/CertificationCandidate_test.js index 822e45d5df8..5045e3df6d2 100644 --- a/api/tests/unit/domain/models/CertificationCandidate_test.js +++ b/api/tests/unit/domain/models/CertificationCandidate_test.js @@ -1,12 +1,14 @@ -const { expect, domainBuilder, catchErr } = require('../../../test-helper'); -const CertificationCandidate = require('../../../../lib/domain/models/CertificationCandidate'); -const { +import { expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { CertificationCandidate } from '../../../../lib/domain/models/CertificationCandidate.js'; + +import { InvalidCertificationCandidate, CertificationCandidatePersonalInfoFieldMissingError, CertificationCandidatePersonalInfoWrongFormat, -} = require('../../../../lib/domain/errors'); -const { CERTIFICATION_CANDIDATES_ERRORS } = require('../../../../lib/domain/constants/certification-candidates-errors'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +} from '../../../../lib/domain/errors.js'; + +import { CERTIFICATION_CANDIDATES_ERRORS } from '../../../../lib/domain/constants/certification-candidates-errors.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; const i18n = getI18n(); const translate = i18n.__; diff --git a/api/tests/unit/domain/models/CertificationCenterInvitation_test.js b/api/tests/unit/domain/models/CertificationCenterInvitation_test.js index 010032e2836..4afcf18379f 100644 --- a/api/tests/unit/domain/models/CertificationCenterInvitation_test.js +++ b/api/tests/unit/domain/models/CertificationCenterInvitation_test.js @@ -1,7 +1,7 @@ -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); -const { expect, sinon } = require('../../../test-helper'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); -const randomString = require('randomstring'); +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; +import { expect, sinon } from '../../../test-helper.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import randomString from 'randomstring'; describe('Unit | Domain | Models | CertificationCenterInvitation', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/CertificationCenterInvitedUser_test.js b/api/tests/unit/domain/models/CertificationCenterInvitedUser_test.js index 80ddf9f380d..0b2ea13f472 100644 --- a/api/tests/unit/domain/models/CertificationCenterInvitedUser_test.js +++ b/api/tests/unit/domain/models/CertificationCenterInvitedUser_test.js @@ -1,7 +1,7 @@ -const CertificationCenterInvitedUser = require('../../../../lib/domain/models/CertificationCenterInvitedUser'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); -const { expect, catchErr, domainBuilder } = require('../../../test-helper'); -const { NotFoundError, AlreadyAcceptedOrCancelledInvitationError } = require('../../../../lib/domain/errors'); +import { CertificationCenterInvitedUser } from '../../../../lib/domain/models/CertificationCenterInvitedUser.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; +import { expect, catchErr, domainBuilder } from '../../../test-helper.js'; +import { NotFoundError, AlreadyAcceptedOrCancelledInvitationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | CertificationCenterInvitedUser', function () { describe('#acceptInvitation', function () { diff --git a/api/tests/unit/domain/models/CertificationCenter_test.js b/api/tests/unit/domain/models/CertificationCenter_test.js index ccd5d541a6c..d61a5ed9e8e 100644 --- a/api/tests/unit/domain/models/CertificationCenter_test.js +++ b/api/tests/unit/domain/models/CertificationCenter_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | CertificationCenter', function () { describe('#isSco', function () { diff --git a/api/tests/unit/domain/models/CertificationChallengeWithType_test.js b/api/tests/unit/domain/models/CertificationChallengeWithType_test.js index ce1cd41b3fb..4822a48f292 100644 --- a/api/tests/unit/domain/models/CertificationChallengeWithType_test.js +++ b/api/tests/unit/domain/models/CertificationChallengeWithType_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CertificationChallengeWithType = require('../../../../lib/domain/models/CertificationChallengeWithType'); -const { Type } = require('../../../../lib/domain/models/Challenge'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CertificationChallengeWithType } from '../../../../lib/domain/models/CertificationChallengeWithType.js'; +import { Type } from '../../../../lib/domain/models/Challenge.js'; describe('Unit | Domain | Models | CertificationChallengeWithType', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/CertificationChallenge_test.js b/api/tests/unit/domain/models/CertificationChallenge_test.js index 8ab5e6e246d..9356e2c0e61 100644 --- a/api/tests/unit/domain/models/CertificationChallenge_test.js +++ b/api/tests/unit/domain/models/CertificationChallenge_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const CertificationChallenge = require('../../../../lib/domain/models/CertificationChallenge'); +import { expect } from '../../../test-helper.js'; +import { CertificationChallenge } from '../../../../lib/domain/models/CertificationChallenge.js'; describe('Unit | Domain | Models | CertificationChallenge', function () { describe('#static createForPixCertification', function () { diff --git a/api/tests/unit/domain/models/CertificationContract_test.js b/api/tests/unit/domain/models/CertificationContract_test.js index 60013bd99fe..1c4360fa66f 100644 --- a/api/tests/unit/domain/models/CertificationContract_test.js +++ b/api/tests/unit/domain/models/CertificationContract_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder, catchErr } = require('../../../test-helper'); -const { CertificationComputeError } = require('../../../../lib/domain/errors'); -const CertificationContract = require('../../../../lib/domain/models/CertificationContract'); -const _ = require('lodash'); +import { expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { CertificationComputeError } from '../../../../lib/domain/errors.js'; +import { CertificationContract } from '../../../../lib/domain/models/CertificationContract.js'; +import _ from 'lodash'; describe('Unit | Domain | Models | CertificationContract', function () { context('#assertThatWeHaveEnoughAnswers', function () { diff --git a/api/tests/unit/domain/models/CertificationCourse_test.js b/api/tests/unit/domain/models/CertificationCourse_test.js index 42461408f58..9e66e446a2d 100644 --- a/api/tests/unit/domain/models/CertificationCourse_test.js +++ b/api/tests/unit/domain/models/CertificationCourse_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | CertificationCourse', function () { describe('#cancel #isCancelled', function () { diff --git a/api/tests/unit/domain/models/CertificationIssueReportResolutionStrategies_test.js b/api/tests/unit/domain/models/CertificationIssueReportResolutionStrategies_test.js index 4d192e32347..5efa4372417 100644 --- a/api/tests/unit/domain/models/CertificationIssueReportResolutionStrategies_test.js +++ b/api/tests/unit/domain/models/CertificationIssueReportResolutionStrategies_test.js @@ -1,20 +1,18 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const { - CertificationIssueReportCategories, +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { + CertificationIssueReportCategory, CertificationIssueReportSubcategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); -const CertificationIssueReportResolutionAttempt = require('../../../../lib/domain/models/CertificationIssueReportResolutionAttempt'); -const { +} from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; +import { CertificationIssueReportResolutionAttempt } from '../../../../lib/domain/models/CertificationIssueReportResolutionAttempt.js'; +import { CertificationIssueReportResolutionStrategies, -} = require('../../../../lib/domain/models/CertificationIssueReportResolutionStrategies'); -const { neutralizeWithoutCheckingStrategy, neutralizeIfImageOrEmbedStrategy, neutralizeIfAttachmentStrategy, neutralizeIfTimedChallengeStrategy, neutralizeOrValidateIfFocusedChallengeStrategy, doNotResolveStrategy, -} = require('../../../../lib/domain/models/CertificationIssueReportResolutionStrategies'); +} from '../../../../lib/domain/models/CertificationIssueReportResolutionStrategies.js'; describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies', function () { context('#NEUTRALIZE_WITHOUT_CHECKING', function () { @@ -29,7 +27,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -59,7 +57,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -90,7 +88,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -120,7 +118,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -154,7 +152,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithImage = domainBuilder.buildChallenge({ illustrationUrl: 'image_url' }); @@ -189,7 +187,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithImage = domainBuilder.buildChallenge({ illustrationUrl: 'image_url' }); @@ -226,7 +224,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithEmbed = domainBuilder.buildChallenge({ embedUrl: 'embed_url' }); @@ -261,7 +259,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithEmbed = domainBuilder.buildChallenge({ embedUrl: 'embed_url' }); @@ -293,7 +291,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -321,7 +319,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -350,7 +348,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithoutIllustrationAndEmbed = domainBuilder.buildChallenge({ @@ -390,7 +388,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithoutIllustration = domainBuilder.buildChallenge({ illustrationUrl: null }); @@ -431,7 +429,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithImage = domainBuilder.buildChallenge({ illustrationUrl: 'image_url' }); @@ -466,7 +464,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithImage = domainBuilder.buildChallenge({ illustrationUrl: 'image_url' }); @@ -504,7 +502,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.FILE_NOT_OPENING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithAttachment = domainBuilder.buildChallenge({ @@ -541,7 +539,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.FILE_NOT_OPENING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); @@ -576,7 +574,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.SOFTWARE_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -604,7 +602,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.FILE_NOT_OPENING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -633,7 +631,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.FILE_NOT_OPENING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithoutAttachment = domainBuilder.buildChallenge({ attachments: [] }); @@ -667,7 +665,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.FILE_NOT_OPENING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithoutAttachment = domainBuilder.buildChallenge({ attachments: [] }); @@ -708,7 +706,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.FILE_NOT_OPENING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithAttachment = domainBuilder.buildChallenge({ @@ -745,7 +743,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.FILE_NOT_OPENING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const challengeWithAttachment = domainBuilder.buildChallenge({ @@ -785,7 +783,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EXTRA_TIME_EXCEEDED, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const timedChallenge = domainBuilder.buildChallenge({ @@ -822,7 +820,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EXTRA_TIME_EXCEEDED, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); @@ -857,7 +855,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EXTRA_TIME_EXCEEDED, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -885,7 +883,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EXTRA_TIME_EXCEEDED, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -914,7 +912,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EXTRA_TIME_EXCEEDED, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const notTimedChallenge = domainBuilder.buildChallenge({}); @@ -948,7 +946,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EXTRA_TIME_EXCEEDED, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const notTimedChallenge = domainBuilder.buildChallenge({}); @@ -989,7 +987,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EXTRA_TIME_EXCEEDED, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const timedChallenge = domainBuilder.buildChallenge({ @@ -1026,7 +1024,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EXTRA_TIME_EXCEEDED, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const timedChallenge = domainBuilder.buildChallenge({ @@ -1069,7 +1067,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.UNINTENTIONAL_FOCUS_OUT, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const focusedChallenge = domainBuilder.buildChallenge({ focused: true }); @@ -1106,7 +1104,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.UNINTENTIONAL_FOCUS_OUT, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); @@ -1150,7 +1148,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.UNINTENTIONAL_FOCUS_OUT, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const focusedChallenge = domainBuilder.buildChallenge({ focused: true }); @@ -1187,7 +1185,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' }); const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.UNINTENTIONAL_FOCUS_OUT, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); @@ -1224,7 +1222,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.UNINTENTIONAL_FOCUS_OUT, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -1252,7 +1250,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.UNINTENTIONAL_FOCUS_OUT, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const certificationIssueReportRepository = { @@ -1282,7 +1280,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.UNINTENTIONAL_FOCUS_OUT, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const notFocusedChallenge = domainBuilder.buildChallenge({ focused: false }); @@ -1316,7 +1314,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.UNINTENTIONAL_FOCUS_OUT, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); const notFocusedChallenge = domainBuilder.buildChallenge({ focused: false }); @@ -1355,7 +1353,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EMBED_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); @@ -1375,7 +1373,7 @@ describe('Unit | Domain | Models | CertificationIssueReportResolutionStrategies' // given const certificationIssueReport = domainBuilder.buildCertificationIssueReport({ subcategory: CertificationIssueReportSubcategories.EMBED_NOT_WORKING, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, questionNumber: 1, }); diff --git a/api/tests/unit/domain/models/CertificationIssueReport_test.js b/api/tests/unit/domain/models/CertificationIssueReport_test.js index 54b6ab35fb0..16fed7db56e 100644 --- a/api/tests/unit/domain/models/CertificationIssueReport_test.js +++ b/api/tests/unit/domain/models/CertificationIssueReport_test.js @@ -1,14 +1,15 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CertificationIssueReport = require('../../../../lib/domain/models/CertificationIssueReport'); -const { - CertificationIssueReportCategories, +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CertificationIssueReport } from '../../../../lib/domain/models/CertificationIssueReport.js'; +import { + CertificationIssueReportCategory, CertificationIssueReportSubcategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); -const { +} from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; + +import { InvalidCertificationIssueReportForSaving, DeprecatedCertificationIssueReportSubcategoryError, DeprecatedCertificationIssueReportCategoryError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; const MISSING_VALUE = null; const EMPTY_VALUE = ''; @@ -23,7 +24,7 @@ describe('Unit | Domain | Models | CertificationIssueReport', function () { beforeEach(function () { certificationIssueReportDTO = { certificationCourseId: 123, - category: CertificationIssueReportCategories.NON_BLOCKING_TECHNICAL_ISSUE, + category: CertificationIssueReportCategory.NON_BLOCKING_TECHNICAL_ISSUE, description: 'Une description obligatoire', }; }); @@ -61,7 +62,7 @@ describe('Unit | Domain | Models | CertificationIssueReport', function () { beforeEach(function () { certificationIssueReportDTO = { certificationCourseId: 123, - category: CertificationIssueReportCategories.NON_BLOCKING_CANDIDATE_ISSUE, + category: CertificationIssueReportCategory.NON_BLOCKING_CANDIDATE_ISSUE, description: 'Une description obligatoire', }; }); @@ -99,7 +100,7 @@ describe('Unit | Domain | Models | CertificationIssueReport', function () { beforeEach(function () { certificationIssueReportDTO = { certificationCourseId: 123, - category: CertificationIssueReportCategories.SIGNATURE_ISSUE, + category: CertificationIssueReportCategory.SIGNATURE_ISSUE, description: 'Une description obligatoire', }; }); @@ -127,7 +128,7 @@ describe('Unit | Domain | Models | CertificationIssueReport', function () { beforeEach(function () { certificationIssueReportDTO = { certificationCourseId: 123, - category: CertificationIssueReportCategories.CANDIDATE_INFORMATIONS_CHANGES, + category: CertificationIssueReportCategory.CANDIDATE_INFORMATIONS_CHANGES, description: 'Une description obligatoire', subcategory: CertificationIssueReportSubcategories.NAME_OR_BIRTHDATE, }; @@ -181,7 +182,7 @@ describe('Unit | Domain | Models | CertificationIssueReport', function () { beforeEach(function () { certificationIssueReportDTO = { certificationCourseId: 123, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, subcategory: CertificationIssueReportSubcategories.IMAGE_NOT_DISPLAYING, questionNumber: 5, }; @@ -231,7 +232,7 @@ describe('Unit | Domain | Models | CertificationIssueReport', function () { const createIssueReport = () => CertificationIssueReport.create({ ...certificationIssueReportDTO, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, subcategory: CertificationIssueReportSubcategories.LINK_NOT_WORKING, }); @@ -277,7 +278,7 @@ describe('Unit | Domain | Models | CertificationIssueReport', function () { it('should be valid', function () { const certificationIssueReportDTO = { certificationCourseId: 123, - category: CertificationIssueReportCategories.FRAUD, + category: CertificationIssueReportCategory.FRAUD, }; expect(() => CertificationIssueReport.create(certificationIssueReportDTO)).not.to.throw(); @@ -290,7 +291,7 @@ describe('Unit | Domain | Models | CertificationIssueReport', function () { beforeEach(function () { certificationIssueReportDTO = { certificationCourseId: 123, - category: CertificationIssueReportCategories.TECHNICAL_PROBLEM, + category: CertificationIssueReportCategory.TECHNICAL_PROBLEM, description: 'Une description obligatoire', }; }); diff --git a/api/tests/unit/domain/models/CertificationOfficer_test.js b/api/tests/unit/domain/models/CertificationOfficer_test.js index 94a2000be3a..1717b40714f 100644 --- a/api/tests/unit/domain/models/CertificationOfficer_test.js +++ b/api/tests/unit/domain/models/CertificationOfficer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const CertificationOfficer = require('../../../../lib/domain/models/CertificationOfficer'); +import { expect } from '../../../test-helper.js'; +import { CertificationOfficer } from '../../../../lib/domain/models/CertificationOfficer.js'; describe('Unit | Domain | Models | CertificationOfficer', function () { describe('#getFullName', function () { diff --git a/api/tests/unit/domain/models/CertificationReport_test.js b/api/tests/unit/domain/models/CertificationReport_test.js index d1e88c4694f..04977d80583 100644 --- a/api/tests/unit/domain/models/CertificationReport_test.js +++ b/api/tests/unit/domain/models/CertificationReport_test.js @@ -1,9 +1,9 @@ -const { expect, EMPTY_BLANK_AND_NULL, domainBuilder, catchErr } = require('../../../test-helper'); -const CertificationReport = require('../../../../lib/domain/models/CertificationReport'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { InvalidCertificationReportForFinalization } = require('../../../../lib/domain/errors'); -const keys = require('lodash/keys'); - +import { expect, EMPTY_BLANK_AND_NULL, domainBuilder, catchErr } from '../../../test-helper.js'; +import { CertificationReport } from '../../../../lib/domain/models/CertificationReport.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { InvalidCertificationReportForFinalization } from '../../../../lib/domain/errors.js'; +import lodash from 'lodash'; +const { keys } = lodash; describe('Unit | Domain | Models | CertificationReport', function () { describe('#constructor', function () { // eslint-disable-next-line mocha/no-setup-in-describe diff --git a/api/tests/unit/domain/models/CertificationResult_test.js b/api/tests/unit/domain/models/CertificationResult_test.js index 92cd63be54f..a7b6e8c0db9 100644 --- a/api/tests/unit/domain/models/CertificationResult_test.js +++ b/api/tests/unit/domain/models/CertificationResult_test.js @@ -1,5 +1,5 @@ -const CertificationResult = require('../../../../lib/domain/models/CertificationResult'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { CertificationResult } from '../../../../lib/domain/models/CertificationResult.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | CertificationResult', function () { context('#static from', function () { diff --git a/api/tests/unit/domain/models/CertifiedLevel_test.js b/api/tests/unit/domain/models/CertifiedLevel_test.js index 342a69cfce2..5a56c909fb5 100644 --- a/api/tests/unit/domain/models/CertifiedLevel_test.js +++ b/api/tests/unit/domain/models/CertifiedLevel_test.js @@ -1,7 +1,6 @@ -const { expect } = require('../../../test-helper'); -const { CertifiedLevel } = require('../../../../lib/domain/models/CertifiedLevel'); - -const { MINIMUM_REPRODUCIBILITY_RATE_TO_BE_TRUSTED, UNCERTIFIED_LEVEL } = require('../../../../lib/domain/constants'); +import { expect } from '../../../test-helper.js'; +import { CertifiedLevel } from '../../../../lib/domain/models/CertifiedLevel.js'; +import { MINIMUM_REPRODUCIBILITY_RATE_TO_BE_TRUSTED, UNCERTIFIED_LEVEL } from '../../../../lib/domain/constants.js'; describe('Unit | Domain | Models | CertifiedLevel', function () { context('when 3 challenges were answered', function () { diff --git a/api/tests/unit/domain/models/CertifiedScore_test.js b/api/tests/unit/domain/models/CertifiedScore_test.js index d93c424bb59..1755bd545d8 100644 --- a/api/tests/unit/domain/models/CertifiedScore_test.js +++ b/api/tests/unit/domain/models/CertifiedScore_test.js @@ -1,8 +1,7 @@ -const { expect } = require('../../../test-helper'); -const { CertifiedScore } = require('../../../../lib/domain/models/CertifiedScore'); -const { CertifiedLevel } = require('../../../../lib/domain/models/CertifiedLevel'); - -const { PIX_COUNT_BY_LEVEL } = require('../../../../lib/domain/constants'); +import { expect } from '../../../test-helper.js'; +import { CertifiedScore } from '../../../../lib/domain/models/CertifiedScore.js'; +import { CertifiedLevel } from '../../../../lib/domain/models/CertifiedLevel.js'; +import { PIX_COUNT_BY_LEVEL } from '../../../../lib/domain/constants.js'; describe('Unit | Domain | Models | CertifiedScore', function () { it('is equal to the estimated score if the estimated level is certified', function () { diff --git a/api/tests/unit/domain/models/Challenge_test.js b/api/tests/unit/domain/models/Challenge_test.js index f41f4824500..1e088e1336b 100644 --- a/api/tests/unit/domain/models/Challenge_test.js +++ b/api/tests/unit/domain/models/Challenge_test.js @@ -1,12 +1,12 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const Challenge = require('../../../../lib/domain/models/Challenge'); -const Skill = require('../../../../lib/domain/models/Skill'); -const Validator = require('../../../../lib/domain/models/Validator'); -const ValidatorQCM = require('../../../../lib/domain/models/ValidatorQCM'); -const ValidatorQCU = require('../../../../lib/domain/models/ValidatorQCU'); -const ValidatorQROC = require('../../../../lib/domain/models/ValidatorQROC'); -const ValidatorQROCMDep = require('../../../../lib/domain/models/ValidatorQROCMDep'); -const ValidatorQROCMInd = require('../../../../lib/domain/models/ValidatorQROCMInd'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { Challenge } from '../../../../lib/domain/models/Challenge.js'; +import { Skill } from '../../../../lib/domain/models/Skill.js'; +import { Validator } from '../../../../lib/domain/models/Validator.js'; +import { ValidatorQCM } from '../../../../lib/domain/models/ValidatorQCM.js'; +import { ValidatorQCU } from '../../../../lib/domain/models/ValidatorQCU.js'; +import { ValidatorQROC } from '../../../../lib/domain/models/ValidatorQROC.js'; +import { ValidatorQROCMDep } from '../../../../lib/domain/models/ValidatorQROCMDep.js'; +import { ValidatorQROCMInd } from '../../../../lib/domain/models/ValidatorQROCMInd.js'; describe('Unit | Domain | Models | Challenge', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/CompetenceMark_test.js b/api/tests/unit/domain/models/CompetenceMark_test.js index 2928bc6d2c1..9c9f92cb20e 100644 --- a/api/tests/unit/domain/models/CompetenceMark_test.js +++ b/api/tests/unit/domain/models/CompetenceMark_test.js @@ -1,6 +1,6 @@ -const { catchErr, expect, domainBuilder } = require('../../../test-helper'); -const CompetenceMark = require('../../../../lib/domain/models/CompetenceMark'); -const { ObjectValidationError } = require('../../../../lib/domain/errors'); +import { catchErr, expect, domainBuilder } from '../../../test-helper.js'; +import { CompetenceMark } from '../../../../lib/domain/models/CompetenceMark.js'; +import { ObjectValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | Competence Mark', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/CompetenceResult_test.js b/api/tests/unit/domain/models/CompetenceResult_test.js index 9b1a13f9731..dc0ae9659df 100644 --- a/api/tests/unit/domain/models/CompetenceResult_test.js +++ b/api/tests/unit/domain/models/CompetenceResult_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const CompetenceResult = require('../../../../lib/domain/models/CompetenceResult'); +import { expect } from '../../../test-helper.js'; +import { CompetenceResult } from '../../../../lib/domain/models/CompetenceResult.js'; describe('Unit | Domain | Models | CompetenceResult', function () { describe('#masteryPercentage', function () { diff --git a/api/tests/unit/domain/models/ComplementaryCertificationCourseResult_test.js b/api/tests/unit/domain/models/ComplementaryCertificationCourseResult_test.js index dd0dd878fa8..64e3d9008c6 100644 --- a/api/tests/unit/domain/models/ComplementaryCertificationCourseResult_test.js +++ b/api/tests/unit/domain/models/ComplementaryCertificationCourseResult_test.js @@ -1,5 +1,5 @@ -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | ComplementaryCertificationCourseResult', function () { describe('#isAcquired', function () { diff --git a/api/tests/unit/domain/models/ComplementaryCertificationHabilitation_test.js b/api/tests/unit/domain/models/ComplementaryCertificationHabilitation_test.js index 77b3956c633..764981a6193 100644 --- a/api/tests/unit/domain/models/ComplementaryCertificationHabilitation_test.js +++ b/api/tests/unit/domain/models/ComplementaryCertificationHabilitation_test.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationHabilitation = require('../../../../lib/domain/models/ComplementaryCertificationHabilitation'); -const { expect, domainBuilder } = require('../../../test-helper'); -const _ = require('lodash'); +import { ComplementaryCertificationHabilitation } from '../../../../lib/domain/models/ComplementaryCertificationHabilitation.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; +import _ from 'lodash'; const COMPLEMENTARY_CERTIFICATION_HABILITATION_PROPS = ['id', 'complementaryCertificationId', 'certificationCenterId']; diff --git a/api/tests/unit/domain/models/ComplementaryCertificationScoringWithComplementaryReferential_test.js b/api/tests/unit/domain/models/ComplementaryCertificationScoringWithComplementaryReferential_test.js index 965b382c90c..75b62bb31c4 100644 --- a/api/tests/unit/domain/models/ComplementaryCertificationScoringWithComplementaryReferential_test.js +++ b/api/tests/unit/domain/models/ComplementaryCertificationScoringWithComplementaryReferential_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const ComplementaryCertificationScoringWithComplementaryReferential = require('../../../../lib/domain/models/ComplementaryCertificationScoringWithComplementaryReferential'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { ComplementaryCertificationScoringWithComplementaryReferential } from '../../../../lib/domain/models/ComplementaryCertificationScoringWithComplementaryReferential.js'; describe('Unit | Domain | Models | ComplementaryCertificationScoringWithComplementaryReferential', function () { context('#constructor', function () { diff --git a/api/tests/unit/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential_test.js b/api/tests/unit/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential_test.js index 7c2f42488bc..1b4b2a86066 100644 --- a/api/tests/unit/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential_test.js +++ b/api/tests/unit/domain/models/ComplementaryCertificationScoringWithoutComplementaryReferential_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | ComplementaryCertificationScoringWithoutComplementaryReferential', function () { context('#isAcquired', function () { diff --git a/api/tests/unit/domain/models/CorrectionBlockQROCMDep_test.js b/api/tests/unit/domain/models/CorrectionBlockQROCMDep_test.js index 3de01d20c57..0b9eccabb4a 100644 --- a/api/tests/unit/domain/models/CorrectionBlockQROCMDep_test.js +++ b/api/tests/unit/domain/models/CorrectionBlockQROCMDep_test.js @@ -1,5 +1,5 @@ -const CorrectionBlockQROCMDep = require('../../../../lib/domain/models/CorrectionBlockQROCMDep'); -const { expect } = require('../../../test-helper'); +import { CorrectionBlockQROCMDep } from '../../../../lib/domain/models/CorrectionBlockQROCMDep.js'; +import { expect } from '../../../test-helper.js'; describe('Unit | Domain | Models | CorrectionBlockQROCMDep', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/Course_test.js b/api/tests/unit/domain/models/Course_test.js index 836a265089c..36f2b489c1b 100644 --- a/api/tests/unit/domain/models/Course_test.js +++ b/api/tests/unit/domain/models/Course_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const Course = require('../../../../lib/domain/models/Course'); +import { expect } from '../../../test-helper.js'; +import { Course } from '../../../../lib/domain/models/Course.js'; describe('Unit | Domain | Models | Course', function () { describe('#nbChallenges', function () { diff --git a/api/tests/unit/domain/models/EmailingAttempt_test.js b/api/tests/unit/domain/models/EmailingAttempt_test.js index cd03944f876..affbc9c2326 100644 --- a/api/tests/unit/domain/models/EmailingAttempt_test.js +++ b/api/tests/unit/domain/models/EmailingAttempt_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../../test-helper'); - -const EmailingAttempt = require('../../../../lib/domain/models/EmailingAttempt'); +import { expect } from '../../../test-helper.js'; +import { EmailingAttempt } from '../../../../lib/domain/models/EmailingAttempt.js'; describe('Unit | Domain | Models | EmailingAttempt', function () { describe('#hasFailed', function () { diff --git a/api/tests/unit/domain/models/Examiner_test.js b/api/tests/unit/domain/models/Examiner_test.js index 7ea0c422b45..ad33e388978 100644 --- a/api/tests/unit/domain/models/Examiner_test.js +++ b/api/tests/unit/domain/models/Examiner_test.js @@ -1,8 +1,7 @@ -const Answer = require('../../../../lib/domain/models/Answer'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const Examiner = require('../../../../lib/domain/models/Examiner'); - -const { expect, domainBuilder, sinon } = require('../../../test-helper'); +import { Answer } from '../../../../lib/domain/models/Answer.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { Examiner } from '../../../../lib/domain/models/Examiner.js'; +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; describe('Unit | Domain | Models | Examiner', function () { const challengeFormat = 'nombre'; diff --git a/api/tests/unit/domain/models/FinalizedSession_test.js b/api/tests/unit/domain/models/FinalizedSession_test.js index c15c11b8203..d78829bf86b 100644 --- a/api/tests/unit/domain/models/FinalizedSession_test.js +++ b/api/tests/unit/domain/models/FinalizedSession_test.js @@ -1,10 +1,8 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const FinalizedSession = require('../../../../lib/domain/models/FinalizedSession'); -const JuryCertificationSummary = require('../../../../lib/domain/read-models/JuryCertificationSummary'); -const { status: assessmentResultStatuses } = require('../../../../lib/domain/models/AssessmentResult'); -const { - CertificationIssueReportCategories, -} = require('../../../../lib/domain/models/CertificationIssueReportCategory'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { FinalizedSession } from '../../../../lib/domain/models/FinalizedSession.js'; +import { JuryCertificationSummary } from '../../../../lib/domain/read-models/JuryCertificationSummary.js'; +import { status as assessmentResultStatuses } from '../../../../lib/domain/models/AssessmentResult.js'; +import { CertificationIssueReportCategory } from '../../../../lib/domain/models/CertificationIssueReportCategory.js'; describe('Unit | Domain | Models | FinalizedSession', function () { context('#isPublishable', function () { @@ -333,7 +331,7 @@ function _noneWithRequiredActionButSomeErrorStatus() { cleaCertificationStatus: 'not_passed', certificationIssueReports: [ domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.SIGNATURE_ISSUE, + category: CertificationIssueReportCategory.SIGNATURE_ISSUE, }), ], }), @@ -355,7 +353,7 @@ function _noneWithRequiredActionButSomeStartedStatus() { cleaCertificationStatus: 'not_passed', certificationIssueReports: [ domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.SIGNATURE_ISSUE, + category: CertificationIssueReportCategory.SIGNATURE_ISSUE, }), ], }), @@ -377,7 +375,7 @@ function _someWithUnresolvedRequiredActionButNoErrorOrStartedStatus() { cleaCertificationStatus: 'not_passed', certificationIssueReports: [ domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.FRAUD, + category: CertificationIssueReportCategory.FRAUD, resolvedAt: null, resolution: null, }), @@ -401,7 +399,7 @@ function _someWithResolvedRequiredActionButNoErrorOrStartedStatus() { cleaCertificationStatus: 'not_passed', certificationIssueReports: [ domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.FRAUD, + category: CertificationIssueReportCategory.FRAUD, resolvedAt: new Date('2020-01-01'), resolution: 'des points gratos offerts', }), @@ -425,7 +423,7 @@ function _someWhichAreUnfinishedButHaveNoAbortReason() { cleaCertificationStatus: 'not_passed', certificationIssueReports: [ domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.FRAUD, + category: CertificationIssueReportCategory.FRAUD, resolvedAt: new Date('2020-01-01'), resolution: 'des points gratos offerts', }), diff --git a/api/tests/unit/domain/models/JuryCertification_test.js b/api/tests/unit/domain/models/JuryCertification_test.js index 7df1341d08c..b5d452dae53 100644 --- a/api/tests/unit/domain/models/JuryCertification_test.js +++ b/api/tests/unit/domain/models/JuryCertification_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const JuryCertification = require('../../../../lib/domain/models/JuryCertification'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { JuryCertification } from '../../../../lib/domain/models/JuryCertification.js'; describe('Unit | Domain | Models | JuryCertification', function () { describe('#from', function () { diff --git a/api/tests/unit/domain/models/KnowledgeElement_test.js b/api/tests/unit/domain/models/KnowledgeElement_test.js index f13554c1026..60239e95890 100644 --- a/api/tests/unit/domain/models/KnowledgeElement_test.js +++ b/api/tests/unit/domain/models/KnowledgeElement_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const dayjs = require('dayjs'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import dayjs from 'dayjs'; describe('Unit | Domain | Models | KnowledgeElement', function () { describe('#isValidated', function () { diff --git a/api/tests/unit/domain/models/Membership_test.js b/api/tests/unit/domain/models/Membership_test.js index bf9ec643550..067584bdbbb 100644 --- a/api/tests/unit/domain/models/Membership_test.js +++ b/api/tests/unit/domain/models/Membership_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const Membership = require('../../../../lib/domain/models/Membership'); -const { InvalidMembershipOrganizationRoleError } = require('../../../../lib/domain/errors'); +import { expect } from '../../../test-helper.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { InvalidMembershipOrganizationRoleError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | Membership', function () { describe('#validateRole', function () { diff --git a/api/tests/unit/domain/models/OrganizationInvitation_test.js b/api/tests/unit/domain/models/OrganizationInvitation_test.js index 4a3f6ff7c5e..d350a409355 100644 --- a/api/tests/unit/domain/models/OrganizationInvitation_test.js +++ b/api/tests/unit/domain/models/OrganizationInvitation_test.js @@ -1,6 +1,6 @@ -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const { expect } = require('../../../test-helper'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import { expect } from '../../../test-helper.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | OrganizationInvitation', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/OrganizationInvitedUser_test.js b/api/tests/unit/domain/models/OrganizationInvitedUser_test.js index c7dd3a98f93..28b5c8974c4 100644 --- a/api/tests/unit/domain/models/OrganizationInvitedUser_test.js +++ b/api/tests/unit/domain/models/OrganizationInvitedUser_test.js @@ -1,10 +1,11 @@ -const OrganizationInvitedUser = require('../../../../lib/domain/models/OrganizationInvitedUser'); -const { expect, catchErr, domainBuilder } = require('../../../test-helper'); -const { +import { OrganizationInvitedUser } from '../../../../lib/domain/models/OrganizationInvitedUser.js'; +import { expect, catchErr, domainBuilder } from '../../../test-helper.js'; + +import { NotFoundError, AlreadyExistingMembershipError, AlreadyAcceptedOrCancelledInvitationError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | OrganizationInvitedUser', function () { describe('#acceptInvitation', function () { diff --git a/api/tests/unit/domain/models/OrganizationPlacesLot_test.js b/api/tests/unit/domain/models/OrganizationPlacesLot_test.js index c2f4634c0f4..e480b1acbb0 100644 --- a/api/tests/unit/domain/models/OrganizationPlacesLot_test.js +++ b/api/tests/unit/domain/models/OrganizationPlacesLot_test.js @@ -1,8 +1,7 @@ -/* eslint-disable mocha/no-setup-in-describe */ -const { expect } = require('../../../test-helper'); -const categories = require('../../../../lib/domain/constants/organization-places-categories'); -const OrganizationPlacesLot = require('../../../../lib/domain/models/OrganizationPlacesLot'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect } from '../../../test-helper.js'; +import * as categories from '../../../../lib/domain/constants/organization-places-categories.js'; +import { OrganizationPlacesLot } from '../../../../lib/domain/models/OrganizationPlacesLot.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | OrganizationPlaces', function () { describe('#constructor', function () { @@ -497,4 +496,3 @@ describe('Unit | Domain | Models | OrganizationPlaces', function () { }); }); }); -/* eslint-enable mocha/no-setup-in-describe */ diff --git a/api/tests/unit/domain/models/Organization_test.js b/api/tests/unit/domain/models/Organization_test.js index 2e0c4efc03f..791600510b5 100644 --- a/api/tests/unit/domain/models/Organization_test.js +++ b/api/tests/unit/domain/models/Organization_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const Organization = require('../../../../lib/domain/models/Organization'); -const Tag = require('../../../../lib/domain/models/Tag'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { Tag } from '../../../../lib/domain/models/Tag.js'; describe('Unit | Domain | Models | Organization', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/OrganizationsToAttachToTargetProfile_test.js b/api/tests/unit/domain/models/OrganizationsToAttachToTargetProfile_test.js index 6f9125deb80..e72beb1f01a 100644 --- a/api/tests/unit/domain/models/OrganizationsToAttachToTargetProfile_test.js +++ b/api/tests/unit/domain/models/OrganizationsToAttachToTargetProfile_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder, catchErr } = require('../../../test-helper'); +import { expect, domainBuilder, catchErr } from '../../../test-helper.js'; const id = 1; describe('Unit | Domain | Models | OrganizationsToAttachToTargetProfile', function () { diff --git a/api/tests/unit/domain/models/ParticipantResultsShared_test.js b/api/tests/unit/domain/models/ParticipantResultsShared_test.js index 9d996619451..c21a10228f9 100644 --- a/api/tests/unit/domain/models/ParticipantResultsShared_test.js +++ b/api/tests/unit/domain/models/ParticipantResultsShared_test.js @@ -1,8 +1,9 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const ParticipantResultsShared = require('../../../../lib/domain/models/ParticipantResultsShared'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const { MAX_REACHABLE_PIX_BY_COMPETENCE } = require('../../../../lib/domain/constants'); -const noop = require('lodash/noop'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { ParticipantResultsShared } from '../../../../lib/domain/models/ParticipantResultsShared.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { MAX_REACHABLE_PIX_BY_COMPETENCE } from '../../../../lib/domain/constants.js'; +import lodash from 'lodash'; +const { noop } = lodash; describe('Unit | Domain | Models | ParticipantResultsShared', function () { context('#masteryRate', function () { diff --git a/api/tests/unit/domain/models/ParticipationForCampaignManagement_test.js b/api/tests/unit/domain/models/ParticipationForCampaignManagement_test.js index 2e7f589fed6..2fc3029cfba 100644 --- a/api/tests/unit/domain/models/ParticipationForCampaignManagement_test.js +++ b/api/tests/unit/domain/models/ParticipationForCampaignManagement_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const ParticipationForCampaignManagement = require('../../../../lib/domain/models/ParticipationForCampaignManagement'); +import { expect } from '../../../test-helper.js'; +import { ParticipationForCampaignManagement } from '../../../../lib/domain/models/ParticipationForCampaignManagement.js'; describe('Unit | Domain | Models | ParticipationForCampaignManagement', function () { context('#userFullName', function () { diff --git a/api/tests/unit/domain/models/PartnerCertificationScoring_test.js b/api/tests/unit/domain/models/PartnerCertificationScoring_test.js index 9ff4874320a..2471ea6de62 100644 --- a/api/tests/unit/domain/models/PartnerCertificationScoring_test.js +++ b/api/tests/unit/domain/models/PartnerCertificationScoring_test.js @@ -1,6 +1,6 @@ -const PartnerCertificationScoring = require('../../../../lib/domain/models/PartnerCertificationScoring'); -const { expect } = require('../../../test-helper'); -const { ObjectValidationError } = require('../../../../lib/domain/errors'); +import { PartnerCertificationScoring } from '../../../../lib/domain/models/PartnerCertificationScoring.js'; +import { expect } from '../../../test-helper.js'; +import { ObjectValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | PartnerCertificationScoring', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/PlacementProfile_test.js b/api/tests/unit/domain/models/PlacementProfile_test.js index acddf577b85..d4dd979dd37 100644 --- a/api/tests/unit/domain/models/PlacementProfile_test.js +++ b/api/tests/unit/domain/models/PlacementProfile_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const PlacementProfile = require('../../../../lib/domain/models/PlacementProfile'); -const UserCompetence = require('../../../../lib/domain/models/UserCompetence'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { PlacementProfile } from '../../../../lib/domain/models/PlacementProfile.js'; +import { UserCompetence } from '../../../../lib/domain/models/UserCompetence.js'; describe('Unit | Domain | Models | PlacementProfile', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/PoleEmploiSending_test.js b/api/tests/unit/domain/models/PoleEmploiSending_test.js index b91712113a7..124ca94cd91 100644 --- a/api/tests/unit/domain/models/PoleEmploiSending_test.js +++ b/api/tests/unit/domain/models/PoleEmploiSending_test.js @@ -1,5 +1,5 @@ -const PoleEmploiSending = require('../../../../lib/domain/models/PoleEmploiSending'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { PoleEmploiSending } from '../../../../lib/domain/models/PoleEmploiSending.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | PoleEmploiSending', function () { let expectedPoleEmploiSending; diff --git a/api/tests/unit/domain/models/PrivateCertificate_test.js b/api/tests/unit/domain/models/PrivateCertificate_test.js index 3f228d0c643..5c5dde53fe7 100644 --- a/api/tests/unit/domain/models/PrivateCertificate_test.js +++ b/api/tests/unit/domain/models/PrivateCertificate_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const PrivateCertificate = require('../../../../lib/domain/models/PrivateCertificate'); -const { status: assessmentResultStatuses } = require('../../../../lib/domain/models/AssessmentResult'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { PrivateCertificate } from '../../../../lib/domain/models/PrivateCertificate.js'; +import { status as assessmentResultStatuses } from '../../../../lib/domain/models/AssessmentResult.js'; describe('Unit | Domain | Models | PrivateCertificate', function () { context('#static buildFrom', function () { diff --git a/api/tests/unit/domain/models/Progression_test.js b/api/tests/unit/domain/models/Progression_test.js index 65290dab881..7d477378737 100644 --- a/api/tests/unit/domain/models/Progression_test.js +++ b/api/tests/unit/domain/models/Progression_test.js @@ -1,5 +1,5 @@ -const Progression = require('../../../../lib/domain/models/Progression'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { Progression } from '../../../../lib/domain/models/Progression.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | Progression', function () { // TODO: Fix this the next time the file is edited. diff --git a/api/tests/unit/domain/models/ReproducibilityRate_test.js b/api/tests/unit/domain/models/ReproducibilityRate_test.js index 7d9453dea7e..d927450f3b2 100644 --- a/api/tests/unit/domain/models/ReproducibilityRate_test.js +++ b/api/tests/unit/domain/models/ReproducibilityRate_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const { ReproducibilityRate } = require('../../../../lib/domain/models/ReproducibilityRate'); -const { MINIMUM_REPRODUCIBILITY_RATE_TO_BE_CERTIFIED } = require('../../../../lib/domain/constants'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { ReproducibilityRate } from '../../../../lib/domain/models/ReproducibilityRate.js'; +import { MINIMUM_REPRODUCIBILITY_RATE_TO_BE_CERTIFIED } from '../../../../lib/domain/constants.js'; describe('Unit | Domain | Models | ReproducibilityRate', function () { context('#static from', function () { diff --git a/api/tests/unit/domain/models/ResultCompetenceTree_test.js b/api/tests/unit/domain/models/ResultCompetenceTree_test.js index be664225ad0..d72a85a6233 100644 --- a/api/tests/unit/domain/models/ResultCompetenceTree_test.js +++ b/api/tests/unit/domain/models/ResultCompetenceTree_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const ResultCompetence = require('../../../../lib/domain/models/ResultCompetence'); -const ResultCompetenceTree = require('../../../../lib/domain/models/ResultCompetenceTree'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { ResultCompetence } from '../../../../lib/domain/models/ResultCompetence.js'; +import { ResultCompetenceTree } from '../../../../lib/domain/models/ResultCompetenceTree.js'; describe('Unit | Domain | Models | ResultCompetence', function () { describe('#generateTreeFromCompetenceMarks', function () { diff --git a/api/tests/unit/domain/models/SCOCertificationCandidate_test.js b/api/tests/unit/domain/models/SCOCertificationCandidate_test.js index 9efadbee72f..05a2366d616 100644 --- a/api/tests/unit/domain/models/SCOCertificationCandidate_test.js +++ b/api/tests/unit/domain/models/SCOCertificationCandidate_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr } = require('../../../test-helper'); -const SCOCertificationCandidate = require('../../../../lib/domain/models/SCOCertificationCandidate'); -const { InvalidCertificationCandidate } = require('../../../../lib/domain/errors'); +import { expect, catchErr } from '../../../test-helper.js'; +import { SCOCertificationCandidate } from '../../../../lib/domain/models/SCOCertificationCandidate.js'; +import { InvalidCertificationCandidate } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | SCO Certification Candidate', function () { describe('validate', function () { diff --git a/api/tests/unit/domain/models/Scorecard_test.js b/api/tests/unit/domain/models/Scorecard_test.js index 9af8d2e68c2..8284ab9bd2b 100644 --- a/api/tests/unit/domain/models/Scorecard_test.js +++ b/api/tests/unit/domain/models/Scorecard_test.js @@ -1,9 +1,7 @@ -// eslint-disable-next-line eslint-comments/disable-enable-pair -/* eslint-disable mocha/no-setup-in-describe */ -const { expect, sinon } = require('../../../test-helper'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); -const { constants } = require('../../../../lib/domain/constants'); +import { expect, sinon } from '../../../test-helper.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; +import { constants } from '../../../../lib/domain/constants.js'; describe('Unit | Domain | Models | Scorecard', function () { let computeDaysSinceLastKnowledgeElementStub; @@ -272,11 +270,11 @@ describe('Unit | Domain | Models | Scorecard', function () { }); before(function () { - constants.MINIMUM_DELAY_IN_DAYS_FOR_RESET = 7; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_FOR_RESET').value(7); }); after(function () { - constants.MINIMUM_DELAY_IN_DAYS_FOR_RESET = originalConstantValue; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_FOR_RESET').value(originalConstantValue); }); [ @@ -315,11 +313,11 @@ describe('Unit | Domain | Models | Scorecard', function () { }); before(function () { - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING = 4; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING').value(4); }); after(function () { - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING = originalConstantValue; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING').value(originalConstantValue); }); [ @@ -407,8 +405,7 @@ describe('Unit | Domain | Models | Scorecard', function () { // given const level = 2; const maxReachableLevel = 1; - sinon.stub(constants, 'MAX_REACHABLE_LEVEL').value(maxReachableLevel); - const scorecard = new Scorecard({ level }); + const scorecard = new Scorecard({ level, maxReachableLevel }); // when const result = scorecard.isMaxLevel; @@ -447,8 +444,7 @@ describe('Unit | Domain | Models | Scorecard', function () { it(`should return ${testCase.expectedResult} when level is ${testCase.level} and status ${testCase.status}`, function () { // given const maxReachableLevel = 2; - sinon.stub(constants, 'MAX_REACHABLE_LEVEL').value(maxReachableLevel); - const scorecard = new Scorecard({ level: testCase.level, status: testCase.status }); + const scorecard = new Scorecard({ level: testCase.level, status: testCase.status, maxReachableLevel }); // when const result = scorecard.isFinishedWithMaxLevel; @@ -508,8 +504,7 @@ describe('Unit | Domain | Models | Scorecard', function () { it(`should return ${testCase.expectedResult} when status is ${testCase.status}, level is ${testCase.level}`, function () { // given const maxReachableLevel = 2; - sinon.stub(constants, 'MAX_REACHABLE_LEVEL').value(maxReachableLevel); - const scorecard = new Scorecard({ status: testCase.status, level: testCase.level }); + const scorecard = new Scorecard({ status: testCase.status, level: testCase.level, maxReachableLevel }); // when const result = scorecard.isProgressable; diff --git a/api/tests/unit/domain/models/SessionJuryComment_test.js b/api/tests/unit/domain/models/SessionJuryComment_test.js index a5cd599ba1b..48f97b7d365 100644 --- a/api/tests/unit/domain/models/SessionJuryComment_test.js +++ b/api/tests/unit/domain/models/SessionJuryComment_test.js @@ -1,6 +1,6 @@ -const SessionJuryComment = require('../../../../lib/domain/models/SessionJuryComment'); -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const _ = require('lodash'); +import { SessionJuryComment } from '../../../../lib/domain/models/SessionJuryComment.js'; +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import _ from 'lodash'; const SESSION_JURY_COMMENT_PROPS = ['id', 'comment', 'authorId', 'updatedAt']; diff --git a/api/tests/unit/domain/models/SessionMassImportReport_test.js b/api/tests/unit/domain/models/SessionMassImportReport_test.js index 3969e1a7b3a..ffa14bf84fc 100644 --- a/api/tests/unit/domain/models/SessionMassImportReport_test.js +++ b/api/tests/unit/domain/models/SessionMassImportReport_test.js @@ -1,5 +1,5 @@ -const SessionMassImportReport = require('../../../../lib/domain/models/SessionMassImportReport'); -const { expect } = require('../../../test-helper'); +import { SessionMassImportReport } from '../../../../lib/domain/models/SessionMassImportReport.js'; +import { expect } from '../../../test-helper.js'; describe('Unit | Domain | Models | SessionMassImportReport', function () { context('#addErrorsReports', function () { diff --git a/api/tests/unit/domain/models/Session_test.js b/api/tests/unit/domain/models/Session_test.js index 59beb6cde4b..edfeec65a71 100644 --- a/api/tests/unit/domain/models/Session_test.js +++ b/api/tests/unit/domain/models/Session_test.js @@ -1,7 +1,6 @@ -const Session = require('../../../../lib/domain/models/Session'); -const { expect, sinon } = require('../../../test-helper'); -const _ = require('lodash'); -const { domainBuilder } = require('../../../test-helper'); +import { Session } from '../../../../lib/domain/models/Session.js'; +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import _ from 'lodash'; const SESSION_PROPS = [ 'id', diff --git a/api/tests/unit/domain/models/ShareableCertificate_test.js b/api/tests/unit/domain/models/ShareableCertificate_test.js index b232c7c9412..8884510d10b 100644 --- a/api/tests/unit/domain/models/ShareableCertificate_test.js +++ b/api/tests/unit/domain/models/ShareableCertificate_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | ShareableCertificate', function () { context('#setResultCompetenceTree', function () { diff --git a/api/tests/unit/domain/models/Skill_test.js b/api/tests/unit/domain/models/Skill_test.js index 4094a4ddaa3..b80d73c646e 100644 --- a/api/tests/unit/domain/models/Skill_test.js +++ b/api/tests/unit/domain/models/Skill_test.js @@ -1,5 +1,5 @@ -const Skill = require('../../../../lib/domain/models/Skill'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { Skill } from '../../../../lib/domain/models/Skill.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | Skill', function () { describe('#Difficulty', function () { diff --git a/api/tests/unit/domain/models/Solution_test.js b/api/tests/unit/domain/models/Solution_test.js index 662ec4cb6ba..0193b0bf2c7 100644 --- a/api/tests/unit/domain/models/Solution_test.js +++ b/api/tests/unit/domain/models/Solution_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const Solution = require('../../../../lib/domain/models/Solution'); +import { expect } from '../../../test-helper.js'; +import { Solution } from '../../../../lib/domain/models/Solution.js'; describe('Unit | Domain | Models | Solution', function () { describe('#enabledTreatments', function () { diff --git a/api/tests/unit/domain/models/SupOrganizationLearnerSet_test.js b/api/tests/unit/domain/models/SupOrganizationLearnerSet_test.js index 97eb56778a2..ad7d17584df 100644 --- a/api/tests/unit/domain/models/SupOrganizationLearnerSet_test.js +++ b/api/tests/unit/domain/models/SupOrganizationLearnerSet_test.js @@ -1,7 +1,7 @@ -const SupOrganizationLearnerSet = require('../../../../lib/domain/models/SupOrganizationLearnerSet'); -const { expect, catchErr } = require('../../../test-helper'); -const { getI18n } = require('../../../tooling/i18n/i18n'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { SupOrganizationLearnerSet } from '../../../../lib/domain/models/SupOrganizationLearnerSet.js'; +import { expect, catchErr } from '../../../test-helper.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Models | SupOrganizationLearnerSet', function () { let i18n; diff --git a/api/tests/unit/domain/models/SupOrganizationLearner_test.js b/api/tests/unit/domain/models/SupOrganizationLearner_test.js index 4015c762f02..d7f8d181be0 100644 --- a/api/tests/unit/domain/models/SupOrganizationLearner_test.js +++ b/api/tests/unit/domain/models/SupOrganizationLearner_test.js @@ -1,5 +1,5 @@ -const SupOrganizationLearner = require('../../../../lib/domain/models/SupOrganizationLearner'); -const { expect, catchErr } = require('../../../test-helper'); +import { SupOrganizationLearner } from '../../../../lib/domain/models/SupOrganizationLearner.js'; +import { expect, catchErr } from '../../../test-helper.js'; describe('Unit | Domain | Models | SupOrganizationLearner', function () { describe('#validate', function () { diff --git a/api/tests/unit/domain/models/TargetProfile_test.js b/api/tests/unit/domain/models/TargetProfile_test.js index 8ab8472f207..b576361f30d 100644 --- a/api/tests/unit/domain/models/TargetProfile_test.js +++ b/api/tests/unit/domain/models/TargetProfile_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | TargetProfile', function () { describe('#hasBadges', function () { diff --git a/api/tests/unit/domain/models/Thematic_test.js b/api/tests/unit/domain/models/Thematic_test.js index f01074e665a..ea1b5072e80 100644 --- a/api/tests/unit/domain/models/Thematic_test.js +++ b/api/tests/unit/domain/models/Thematic_test.js @@ -1,5 +1,5 @@ -const Thematic = require('../../../../lib/domain/models/Thematic'); -const { expect } = require('../../../test-helper'); +import { Thematic } from '../../../../lib/domain/models/Thematic.js'; +import { expect } from '../../../test-helper.js'; describe('Unit | Domain | Models | Thematic', function () { it('should return a thematic', function () { diff --git a/api/tests/unit/domain/models/TrainingTriggerTube_test.js b/api/tests/unit/domain/models/TrainingTriggerTube_test.js index 313c5ecb092..8bee07b12c1 100644 --- a/api/tests/unit/domain/models/TrainingTriggerTube_test.js +++ b/api/tests/unit/domain/models/TrainingTriggerTube_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const TrainingTriggerTube = require('../../../../lib/domain/models/TrainingTriggerTube'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { TrainingTriggerTube } from '../../../../lib/domain/models/TrainingTriggerTube.js'; describe('Unit | Domain | Models | TrainingTriggerTube', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/TrainingTrigger_test.js b/api/tests/unit/domain/models/TrainingTrigger_test.js index b79d391613c..d8e16ffbb43 100644 --- a/api/tests/unit/domain/models/TrainingTrigger_test.js +++ b/api/tests/unit/domain/models/TrainingTrigger_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, catchErr, sinon } = require('../../../test-helper'); -const TrainingTrigger = require('../../../../lib/domain/models/TrainingTrigger'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); +import { expect, domainBuilder, catchErr, sinon } from '../../../test-helper.js'; +import { TrainingTrigger } from '../../../../lib/domain/models/TrainingTrigger.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; describe('Unit | Domain | Models | TrainingTrigger', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/Training_test.js b/api/tests/unit/domain/models/Training_test.js index ee6ca5dc7d3..9631462ff02 100644 --- a/api/tests/unit/domain/models/Training_test.js +++ b/api/tests/unit/domain/models/Training_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const Training = require('../../../../lib/domain/models/Training'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { Training } from '../../../../lib/domain/models/Training.js'; describe('Unit | Domain | Models | Training', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/Tube_test.js b/api/tests/unit/domain/models/Tube_test.js index 4a820f54034..7f7e5ce1d20 100644 --- a/api/tests/unit/domain/models/Tube_test.js +++ b/api/tests/unit/domain/models/Tube_test.js @@ -1,5 +1,5 @@ -const Tube = require('../../../../lib/domain/models/Tube'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { Tube } from '../../../../lib/domain/models/Tube.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | Tube', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/models/UserCompetence_test.js b/api/tests/unit/domain/models/UserCompetence_test.js index b29b61713b8..3c686aae7b3 100644 --- a/api/tests/unit/domain/models/UserCompetence_test.js +++ b/api/tests/unit/domain/models/UserCompetence_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | UserCompetence', function () { describe('#isCertifiable', function () { diff --git a/api/tests/unit/domain/models/UserDetailsForAdmin_test.js b/api/tests/unit/domain/models/UserDetailsForAdmin_test.js index 134897cc9fb..3bfad955f45 100644 --- a/api/tests/unit/domain/models/UserDetailsForAdmin_test.js +++ b/api/tests/unit/domain/models/UserDetailsForAdmin_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const UserDetailsForAdmin = require('../../../../lib/domain/models/UserDetailsForAdmin'); +import { expect, sinon } from '../../../test-helper.js'; +import { UserDetailsForAdmin } from '../../../../lib/domain/models/UserDetailsForAdmin.js'; describe('Unit | Domain | Models | UserDetailsForAdmin', function () { let localeService; diff --git a/api/tests/unit/domain/models/UserLogin_test.js b/api/tests/unit/domain/models/UserLogin_test.js index f3b83df7877..5002d7c2bff 100644 --- a/api/tests/unit/domain/models/UserLogin_test.js +++ b/api/tests/unit/domain/models/UserLogin_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const UserLogin = require('../../../../lib/domain/models/UserLogin'); +import { expect, sinon } from '../../../test-helper.js'; +import { UserLogin } from '../../../../lib/domain/models/UserLogin.js'; describe('Unit | Domain | Models | UserLogin', function () { let clock; const now = new Date('2022-11-28T12:00:00Z'); diff --git a/api/tests/unit/domain/models/UserToCreate_test.js b/api/tests/unit/domain/models/UserToCreate_test.js index a26f4791383..311a9ba9405 100644 --- a/api/tests/unit/domain/models/UserToCreate_test.js +++ b/api/tests/unit/domain/models/UserToCreate_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const UserToCreate = require('../../../../lib/domain/models/UserToCreate'); +import { expect, sinon } from '../../../test-helper.js'; +import { UserToCreate } from '../../../../lib/domain/models/UserToCreate.js'; describe('Unit | Domain | Models | UserToCreate', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/User_test.js b/api/tests/unit/domain/models/User_test.js index ce44be25549..d2b6ba651af 100644 --- a/api/tests/unit/domain/models/User_test.js +++ b/api/tests/unit/domain/models/User_test.js @@ -1,5 +1,5 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const User = require('../../../../lib/domain/models/User'); +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { User } from '../../../../lib/domain/models/User.js'; describe('Unit | Domain | Models | User', function () { let config; diff --git a/api/tests/unit/domain/models/ValidatorQCM_test.js b/api/tests/unit/domain/models/ValidatorQCM_test.js index 58c8612f62a..c47977d18bf 100644 --- a/api/tests/unit/domain/models/ValidatorQCM_test.js +++ b/api/tests/unit/domain/models/ValidatorQCM_test.js @@ -1,8 +1,7 @@ -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const Validation = require('../../../../lib/domain/models/Validation'); -const ValidatorQCM = require('../../../../lib/domain/models/ValidatorQCM'); - -const { expect, domainBuilder, sinon } = require('../../../test-helper'); +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { Validation } from '../../../../lib/domain/models/Validation.js'; +import { ValidatorQCM } from '../../../../lib/domain/models/ValidatorQCM.js'; +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; describe('Unit | Domain | Models | ValidatorQCM', function () { let solutionServiceQcmStub; diff --git a/api/tests/unit/domain/models/ValidatorQCU_test.js b/api/tests/unit/domain/models/ValidatorQCU_test.js index 947057c4c55..83d627f6505 100644 --- a/api/tests/unit/domain/models/ValidatorQCU_test.js +++ b/api/tests/unit/domain/models/ValidatorQCU_test.js @@ -1,8 +1,7 @@ -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const Validation = require('../../../../lib/domain/models/Validation'); -const ValidatorQCU = require('../../../../lib/domain/models/ValidatorQCU'); - -const { expect, domainBuilder, sinon } = require('../../../test-helper'); +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { Validation } from '../../../../lib/domain/models/Validation.js'; +import { ValidatorQCU } from '../../../../lib/domain/models/ValidatorQCU.js'; +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; describe('Unit | Domain | Models | ValidatorQCU', function () { let solutionServiceQCUStub; diff --git a/api/tests/unit/domain/models/ValidatorQROCMDep_test.js b/api/tests/unit/domain/models/ValidatorQROCMDep_test.js index 875e84e38a4..36a64e27803 100644 --- a/api/tests/unit/domain/models/ValidatorQROCMDep_test.js +++ b/api/tests/unit/domain/models/ValidatorQROCMDep_test.js @@ -1,8 +1,7 @@ -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const Validation = require('../../../../lib/domain/models/Validation'); -const ValidatorQROCMDep = require('../../../../lib/domain/models/ValidatorQROCMDep'); - -const { expect, domainBuilder, sinon } = require('../../../test-helper'); +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { Validation } from '../../../../lib/domain/models/Validation.js'; +import { ValidatorQROCMDep } from '../../../../lib/domain/models/ValidatorQROCMDep.js'; +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; describe('Unit | Domain | Models | ValidatorQROCMDep', function () { let solutionServiceQROCMDepStub; diff --git a/api/tests/unit/domain/models/ValidatorQROCMInd_test.js b/api/tests/unit/domain/models/ValidatorQROCMInd_test.js index 71539c6a56d..85aef9a2f08 100644 --- a/api/tests/unit/domain/models/ValidatorQROCMInd_test.js +++ b/api/tests/unit/domain/models/ValidatorQROCMInd_test.js @@ -1,8 +1,7 @@ -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const Validation = require('../../../../lib/domain/models/Validation'); -const ValidatorQROCMInd = require('../../../../lib/domain/models/ValidatorQROCMInd'); - -const { expect, domainBuilder, sinon } = require('../../../test-helper'); +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { Validation } from '../../../../lib/domain/models/Validation.js'; +import { ValidatorQROCMInd } from '../../../../lib/domain/models/ValidatorQROCMInd.js'; +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; describe('Unit | Domain | Models | ValidatorQROCMInd', function () { let solutionServiceQROCMIndStub; diff --git a/api/tests/unit/domain/models/ValidatorQROC_test.js b/api/tests/unit/domain/models/ValidatorQROC_test.js index f02d3c62e8c..51f04709ada 100644 --- a/api/tests/unit/domain/models/ValidatorQROC_test.js +++ b/api/tests/unit/domain/models/ValidatorQROC_test.js @@ -1,13 +1,14 @@ -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const solutionServiceQroc = require('../../../../lib/domain/services/solution-service-qroc'); -const Validation = require('../../../../lib/domain/models/Validation'); -const ValidatorQROC = require('../../../../lib/domain/models/ValidatorQROC'); - -const { expect, domainBuilder, sinon } = require('../../../test-helper'); +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { Validation } from '../../../../lib/domain/models/Validation.js'; +import { ValidatorQROC } from '../../../../lib/domain/models/ValidatorQROC.js'; +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; describe('Unit | Domain | Models | ValidatorQROC', function () { + let solutionServiceQROCStub; beforeEach(function () { - sinon.stub(solutionServiceQroc, 'match'); + solutionServiceQROCStub = { + match: sinon.stub().returns(AnswerStatus.OK), + }; }); describe('#assess', function () { @@ -19,11 +20,10 @@ describe('Unit | Domain | Models | ValidatorQROC', function () { beforeEach(function () { // given - solutionServiceQroc.match.returns(AnswerStatus.OK); solution = domainBuilder.buildSolution({ type: 'QROC' }); uncorrectedAnswer = domainBuilder.buildAnswer.uncorrected(); - validator = new ValidatorQROC({ solution: solution }); + validator = new ValidatorQROC({ solution: solution }, solutionServiceQROCStub); // when validation = validator.assess({ answer: uncorrectedAnswer }); @@ -31,7 +31,7 @@ describe('Unit | Domain | Models | ValidatorQROC', function () { it('should call solutionServiceQROC', function () { // then - expect(solutionServiceQroc.match).to.have.been.calledWith({ + expect(solutionServiceQROCStub.match).to.have.been.calledWith({ answer: uncorrectedAnswer.value, solution: solution, challengeFormat, diff --git a/api/tests/unit/domain/models/Validator_test.js b/api/tests/unit/domain/models/Validator_test.js index 88f16ac4d74..46c2bae78d7 100644 --- a/api/tests/unit/domain/models/Validator_test.js +++ b/api/tests/unit/domain/models/Validator_test.js @@ -1,8 +1,7 @@ -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const Validator = require('../../../../lib/domain/models/Validator'); -const Validation = require('../../../../lib/domain/models/Validation'); - -const { expect, domainBuilder } = require('../../../test-helper'); +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { Validator } from '../../../../lib/domain/models/Validator.js'; +import { Validation } from '../../../../lib/domain/models/Validation.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | Validator', function () { describe('#assess', function () { diff --git a/api/tests/unit/domain/models/competence_test.js b/api/tests/unit/domain/models/competence_test.js index 9d170abce3e..7cc358f2bbc 100644 --- a/api/tests/unit/domain/models/competence_test.js +++ b/api/tests/unit/domain/models/competence_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const Competence = require('../../../../lib/domain/models/Competence'); +import { expect } from '../../../test-helper.js'; +import { Competence } from '../../../../lib/domain/models/Competence.js'; describe('Unit | Domain | Models | Competence', function () { describe('@reference', function () { diff --git a/api/tests/unit/domain/models/organizations-administration/OrganizationForAdmin_test.js b/api/tests/unit/domain/models/organizations-administration/OrganizationForAdmin_test.js index 156626b2fe5..c4c9ffdbd36 100644 --- a/api/tests/unit/domain/models/organizations-administration/OrganizationForAdmin_test.js +++ b/api/tests/unit/domain/models/organizations-administration/OrganizationForAdmin_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper.js'); -const OrganizationForAdmin = require('../../../../../lib/domain/models/organizations-administration/Organization.js'); +import { expect } from '../../../../test-helper.js'; +import { OrganizationForAdmin } from '../../../../../lib/domain/models/organizations-administration/Organization.js'; describe('Unit | Domain | Models | OrganizationForAdmin', function () { describe('#archivistFullName', function () { diff --git a/api/tests/unit/domain/models/target-profile-management/StageCollectionUpdate_test.js b/api/tests/unit/domain/models/target-profile-management/StageCollectionUpdate_test.js index d0a8ba26a93..8541f2f8d74 100644 --- a/api/tests/unit/domain/models/target-profile-management/StageCollectionUpdate_test.js +++ b/api/tests/unit/domain/models/target-profile-management/StageCollectionUpdate_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const { InvalidStageError } = require('../../../../../lib/domain/errors'); -const StageCollectionUpdate = require('../../../../../lib/domain/models/target-profile-management/StageCollectionUpdate'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import { InvalidStageError } from '../../../../../lib/domain/errors.js'; +import { StageCollectionUpdate } from '../../../../../lib/domain/models/target-profile-management/StageCollectionUpdate.js'; describe('Unit | Domain | Models | target-profile-management/StageCollectionUpdate', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/models/user-campaign-results/StageCollection_test.js b/api/tests/unit/domain/models/user-campaign-results/StageCollection_test.js index f5e26a7fb67..86e914eb15b 100644 --- a/api/tests/unit/domain/models/user-campaign-results/StageCollection_test.js +++ b/api/tests/unit/domain/models/user-campaign-results/StageCollection_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../../../test-helper'); - -const StageCollection = require('../../../../../lib/domain/models/user-campaign-results/StageCollection'); +import { expect } from '../../../../test-helper.js'; +import { StageCollection } from '../../../../../lib/domain/models/user-campaign-results/StageCollection.js'; describe('Unit | Domain | Models | StageCollection', function () { context('getReachedStageIndex', function () { diff --git a/api/tests/unit/domain/read-models/AllowedCertificationCenterAccess_test.js b/api/tests/unit/domain/read-models/AllowedCertificationCenterAccess_test.js index 6f01832fa04..6776bc6211a 100644 --- a/api/tests/unit/domain/read-models/AllowedCertificationCenterAccess_test.js +++ b/api/tests/unit/domain/read-models/AllowedCertificationCenterAccess_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const settings = require('../../../../lib/config'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { config as settings } from '../../../../lib/config.js'; describe('Unit | Domain | Read-Models | AllowedCertificationCenterAccess', function () { context('#isInWhitelist', function () { diff --git a/api/tests/unit/domain/read-models/CampaignAnalysis_test.js b/api/tests/unit/domain/read-models/CampaignAnalysis_test.js index 17099863b59..0a29781b876 100644 --- a/api/tests/unit/domain/read-models/CampaignAnalysis_test.js +++ b/api/tests/unit/domain/read-models/CampaignAnalysis_test.js @@ -1,5 +1,5 @@ -const CampaignAnalysis = require('../../../../lib/domain/read-models/CampaignAnalysis'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { CampaignAnalysis } from '../../../../lib/domain/read-models/CampaignAnalysis.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Read-Models | CampaignAnalysis', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/read-models/CampaignAssessmentParticipationCompetenceResult_test.js b/api/tests/unit/domain/read-models/CampaignAssessmentParticipationCompetenceResult_test.js index 34c6a574e25..a56adc3a72a 100644 --- a/api/tests/unit/domain/read-models/CampaignAssessmentParticipationCompetenceResult_test.js +++ b/api/tests/unit/domain/read-models/CampaignAssessmentParticipationCompetenceResult_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CampaignAssessmentParticipationCompetenceResult = require('../../../../lib/domain/read-models/CampaignAssessmentParticipationCompetenceResult'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CampaignAssessmentParticipationCompetenceResult } from '../../../../lib/domain/read-models/CampaignAssessmentParticipationCompetenceResult.js'; describe('Unit | Domain | Models | CampaignAssessmentParticipationCompetenceResult', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/read-models/CampaignAssessmentParticipationResult_test.js b/api/tests/unit/domain/read-models/CampaignAssessmentParticipationResult_test.js index 2d5b5344749..f07f6d02c59 100644 --- a/api/tests/unit/domain/read-models/CampaignAssessmentParticipationResult_test.js +++ b/api/tests/unit/domain/read-models/CampaignAssessmentParticipationResult_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CampaignAssessmentParticipationResult = require('../../../../lib/domain/read-models/CampaignAssessmentParticipationResult'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CampaignAssessmentParticipationResult } from '../../../../lib/domain/read-models/CampaignAssessmentParticipationResult.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED, TO_SHARE } = CampaignParticipationStatuses; diff --git a/api/tests/unit/domain/read-models/CampaignAssessmentParticipation_test.js b/api/tests/unit/domain/read-models/CampaignAssessmentParticipation_test.js index 887b1d74196..4b0802d2f38 100644 --- a/api/tests/unit/domain/read-models/CampaignAssessmentParticipation_test.js +++ b/api/tests/unit/domain/read-models/CampaignAssessmentParticipation_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const CampaignAssessmentParticipation = require('../../../../lib/domain/read-models/CampaignAssessmentParticipation'); +import { expect } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { CampaignAssessmentParticipation } from '../../../../lib/domain/read-models/CampaignAssessmentParticipation.js'; describe('Unit | Domain | Models | CampaignAssessmentParticipation', function () { describe('#progression', function () { diff --git a/api/tests/unit/domain/read-models/CampaignCollectiveResult_test.js b/api/tests/unit/domain/read-models/CampaignCollectiveResult_test.js index 0c2f784099f..ad08863e3da 100644 --- a/api/tests/unit/domain/read-models/CampaignCollectiveResult_test.js +++ b/api/tests/unit/domain/read-models/CampaignCollectiveResult_test.js @@ -1,5 +1,5 @@ -const CampaignCollectiveResult = require('../../../../lib/domain/read-models/CampaignCollectiveResult'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { CampaignCollectiveResult } from '../../../../lib/domain/read-models/CampaignCollectiveResult.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Read-Models | CampaignCollectiveResult', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/read-models/CampaignParticipationInfo_test.js b/api/tests/unit/domain/read-models/CampaignParticipationInfo_test.js index 9596f8cd712..42a32f2cc19 100644 --- a/api/tests/unit/domain/read-models/CampaignParticipationInfo_test.js +++ b/api/tests/unit/domain/read-models/CampaignParticipationInfo_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const CampaignParticipationInfo = require('../../../../lib/domain/read-models/CampaignParticipationInfo'); -const { ObjectValidationError } = require('../../../../lib/domain/errors'); +import { expect } from '../../../test-helper.js'; +import { CampaignParticipationInfo } from '../../../../lib/domain/read-models/CampaignParticipationInfo.js'; +import { ObjectValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Read-models | CampaignParticipationInfo', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/read-models/CampaignParticipationOverview_test.js b/api/tests/unit/domain/read-models/CampaignParticipationOverview_test.js index dc951ccc626..1795844ec4f 100644 --- a/api/tests/unit/domain/read-models/CampaignParticipationOverview_test.js +++ b/api/tests/unit/domain/read-models/CampaignParticipationOverview_test.js @@ -1,6 +1,6 @@ -const CampaignParticipationOverview = require('../../../../lib/domain/read-models/CampaignParticipationOverview'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { CampaignParticipationOverview } from '../../../../lib/domain/read-models/CampaignParticipationOverview.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; const { SHARED, STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/unit/domain/read-models/CampaignProfile_test.js b/api/tests/unit/domain/read-models/CampaignProfile_test.js index 556668a87bb..9c7b08433b2 100644 --- a/api/tests/unit/domain/read-models/CampaignProfile_test.js +++ b/api/tests/unit/domain/read-models/CampaignProfile_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CampaignProfile = require('../../../../lib/domain/read-models/CampaignProfile'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CampaignProfile } from '../../../../lib/domain/read-models/CampaignProfile.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED, TO_SHARE } = CampaignParticipationStatuses; diff --git a/api/tests/unit/domain/read-models/CampaignReport_test.js b/api/tests/unit/domain/read-models/CampaignReport_test.js index 9f7c900a4bd..b70c3304372 100644 --- a/api/tests/unit/domain/read-models/CampaignReport_test.js +++ b/api/tests/unit/domain/read-models/CampaignReport_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; describe('Unit | Domain | Models | CampaignReport', function () { it('should define target profile informations', function () { diff --git a/api/tests/unit/domain/read-models/CampaignToJoin_test.js b/api/tests/unit/domain/read-models/CampaignToJoin_test.js index 5aed621c53e..2a26a630793 100644 --- a/api/tests/unit/domain/read-models/CampaignToJoin_test.js +++ b/api/tests/unit/domain/read-models/CampaignToJoin_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; describe('Unit | Domain | Models | CampaignToJoin', function () { describe('#isAssessment', function () { diff --git a/api/tests/unit/domain/read-models/CertificationDetails_test.js b/api/tests/unit/domain/read-models/CertificationDetails_test.js index b28b4efac12..ee2f2ed5ece 100644 --- a/api/tests/unit/domain/read-models/CertificationDetails_test.js +++ b/api/tests/unit/domain/read-models/CertificationDetails_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CertificationDetails = require('../../../../lib/domain/read-models/CertificationDetails'); -const { states } = require('../../../../lib/domain/models/CertificationAssessment'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CertificationDetails } from '../../../../lib/domain/read-models/CertificationDetails.js'; +import { states } from '../../../../lib/domain/models/CertificationAssessment.js'; describe('Unit | Domain | Read-models | CertificationDetails', function () { describe('static #from', function () { diff --git a/api/tests/unit/domain/read-models/CertificationEligibility_test.js b/api/tests/unit/domain/read-models/CertificationEligibility_test.js index 8a6c399c8f0..34e37351921 100644 --- a/api/tests/unit/domain/read-models/CertificationEligibility_test.js +++ b/api/tests/unit/domain/read-models/CertificationEligibility_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CertificationEligibility = require('../../../../lib/domain/read-models/CertificationEligibility'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CertificationEligibility } from '../../../../lib/domain/read-models/CertificationEligibility.js'; describe('Unit | Domain | Read-models | CertificationEligibility', function () { describe('static #notCertifiable', function () { diff --git a/api/tests/unit/domain/read-models/CertifiedBadge_test.js b/api/tests/unit/domain/read-models/CertifiedBadge_test.js index 8a099c8d428..78aa3e8e3b2 100644 --- a/api/tests/unit/domain/read-models/CertifiedBadge_test.js +++ b/api/tests/unit/domain/read-models/CertifiedBadge_test.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); -const CertifiedBadge = require('../../../../lib/domain/read-models/CertifiedBadge'); -const { expect } = require('../../../test-helper'); +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; +import { CertifiedBadge } from '../../../../lib/domain/read-models/CertifiedBadge.js'; +import { expect } from '../../../test-helper.js'; describe('Unit | Domain | Read-models | CertifiedBadge', function () { describe('#getAcquiredCertifiedBadgesDTO', function () { diff --git a/api/tests/unit/domain/read-models/CleaCertifiedCandidate_test.js b/api/tests/unit/domain/read-models/CleaCertifiedCandidate_test.js index 1ba22f60d66..285c2ef67ea 100644 --- a/api/tests/unit/domain/read-models/CleaCertifiedCandidate_test.js +++ b/api/tests/unit/domain/read-models/CleaCertifiedCandidate_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const CleaCertifiedCandidate = require('../../../../lib/domain/read-models/CleaCertifiedCandidate'); +import { expect } from '../../../test-helper.js'; +import { CleaCertifiedCandidate } from '../../../../lib/domain/read-models/CleaCertifiedCandidate.js'; describe('Unit | Domain | Models | CleaCertifiedCandidate', function () { describe('#isBornInAForeignCountry', function () { diff --git a/api/tests/unit/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal_test.js b/api/tests/unit/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal_test.js index d0ea9c3e6cf..8d6ae9cad58 100644 --- a/api/tests/unit/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal_test.js +++ b/api/tests/unit/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal_test.js @@ -1,6 +1,6 @@ -const ComplementaryCertificationCourseResultsForJuryCertificationWithExternal = require('../../../../lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); -const { expect, domainBuilder } = require('../../../test-helper'); +import { ComplementaryCertificationCourseResultsForJuryCertificationWithExternal } from '../../../../lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertificationWithExternal.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Models | ComplementaryCertificationCourseResultsForJuryCertificationWithExternal', function () { describe('#finalResult', function () { diff --git a/api/tests/unit/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification_test.js b/api/tests/unit/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification_test.js index 4fe1b071a8a..54c37533a36 100644 --- a/api/tests/unit/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification_test.js +++ b/api/tests/unit/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const ComplementaryCertificationCourseResultsForJuryCertification = require('../../../../lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { ComplementaryCertificationCourseResultsForJuryCertification } from '../../../../lib/domain/read-models/ComplementaryCertificationCourseResultsForJuryCertification.js'; describe('Unit | Domain | Models | ComplementaryCertificationCourseResultsForJuryCertification', function () { describe('#status', function () { diff --git a/api/tests/unit/domain/read-models/CpfCertificationResult_test.js b/api/tests/unit/domain/read-models/CpfCertificationResult_test.js index 943ccb01198..489a0228092 100644 --- a/api/tests/unit/domain/read-models/CpfCertificationResult_test.js +++ b/api/tests/unit/domain/read-models/CpfCertificationResult_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Read-Models | CpfCertificationResult', function () { context('#inseeCode', function () { diff --git a/api/tests/unit/domain/read-models/EuropeanNumericLevelFactory_test.js b/api/tests/unit/domain/read-models/EuropeanNumericLevelFactory_test.js index b049df20569..101c06452a7 100644 --- a/api/tests/unit/domain/read-models/EuropeanNumericLevelFactory_test.js +++ b/api/tests/unit/domain/read-models/EuropeanNumericLevelFactory_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const EuropeanNumericLevelFactory = require('../../../../lib/domain/read-models/EuropeanNumericLevelFactory'); -const EuropeanNumericLevel = require('../../../../lib/domain/read-models/EuropeanNumericLevel'); +import { expect } from '../../../test-helper.js'; +import { EuropeanNumericLevelFactory } from '../../../../lib/domain/read-models/EuropeanNumericLevelFactory.js'; +import { EuropeanNumericLevel } from '../../../../lib/domain/read-models/EuropeanNumericLevel.js'; describe('Unit | Domain | Read-models | EuropeanNumericLevelFactory', function () { describe('static #buildFromCompetenceMarks', function () { diff --git a/api/tests/unit/domain/read-models/JuryCertificationSummary_test.js b/api/tests/unit/domain/read-models/JuryCertificationSummary_test.js index 22ac39234f2..fbcf0fa67c9 100644 --- a/api/tests/unit/domain/read-models/JuryCertificationSummary_test.js +++ b/api/tests/unit/domain/read-models/JuryCertificationSummary_test.js @@ -1,7 +1,8 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const JuryCertificationSummary = require('../../../../lib/domain/read-models/JuryCertificationSummary'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const forIn = require('lodash/forIn'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { JuryCertificationSummary } from '../../../../lib/domain/read-models/JuryCertificationSummary.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import lodash from 'lodash'; +const { forIn } = lodash; describe('Unit | Domain | Models | JuryCertificationSummary', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/read-models/OrganizationLearnerActivity_test.js b/api/tests/unit/domain/read-models/OrganizationLearnerActivity_test.js index 71bc3101ceb..697ba393837 100644 --- a/api/tests/unit/domain/read-models/OrganizationLearnerActivity_test.js +++ b/api/tests/unit/domain/read-models/OrganizationLearnerActivity_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const OrganizationLearnerActivity = require('../../../../lib/domain/read-models/OrganizationLearnerActivity'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { OrganizationLearnerActivity } from '../../../../lib/domain/read-models/OrganizationLearnerActivity.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; describe('Unit | Domain | Read-Models | OrganizationLearnerActivity', function () { it('computes the activity statistics for every status of every campaign types', function () { diff --git a/api/tests/unit/domain/read-models/OrganizationLearnerForAdmin_test.js b/api/tests/unit/domain/read-models/OrganizationLearnerForAdmin_test.js index 16d175aaae0..731151fafcb 100644 --- a/api/tests/unit/domain/read-models/OrganizationLearnerForAdmin_test.js +++ b/api/tests/unit/domain/read-models/OrganizationLearnerForAdmin_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const OrganizationLearnerForAdmin = require('../../../../lib/domain/read-models/OrganizationLearnerForAdmin'); -const { ObjectValidationError } = require('../../../../lib/domain/errors'); +import { expect } from '../../../test-helper.js'; +import { OrganizationLearnerForAdmin } from '../../../../lib/domain/read-models/OrganizationLearnerForAdmin.js'; +import { ObjectValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Read-models | OrganizationLearnerForAdmin', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/read-models/OrganizationPlacesLotManagement_test.js b/api/tests/unit/domain/read-models/OrganizationPlacesLotManagement_test.js index 3533dfd348b..ec86a8e123a 100644 --- a/api/tests/unit/domain/read-models/OrganizationPlacesLotManagement_test.js +++ b/api/tests/unit/domain/read-models/OrganizationPlacesLotManagement_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const OrganizationPlacesLotManagement = require('../../../../lib/domain/read-models/OrganizationPlacesLotManagement'); +import { expect, sinon } from '../../../test-helper.js'; +import { OrganizationPlacesLotManagement } from '../../../../lib/domain/read-models/OrganizationPlacesLotManagement.js'; describe('Unit | Domain | ReadModels | organizationPlacesLotManagement', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/read-models/SessionSummary_test.js b/api/tests/unit/domain/read-models/SessionSummary_test.js index 0e674682de6..a9fe97ace6e 100644 --- a/api/tests/unit/domain/read-models/SessionSummary_test.js +++ b/api/tests/unit/domain/read-models/SessionSummary_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const SessionSummary = require('../../../../lib/domain/read-models/SessionSummary'); +import { expect } from '../../../test-helper.js'; +import { SessionSummary } from '../../../../lib/domain/read-models/SessionSummary.js'; describe('Unit | Domain | Read-Models | SessionSummary', function () { describe('#static from', function () { diff --git a/api/tests/unit/domain/read-models/SharedProfileForCampaign_test.js b/api/tests/unit/domain/read-models/SharedProfileForCampaign_test.js index 4a2cb894811..024954b9a2f 100644 --- a/api/tests/unit/domain/read-models/SharedProfileForCampaign_test.js +++ b/api/tests/unit/domain/read-models/SharedProfileForCampaign_test.js @@ -1,7 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); - -const SharedProfileForCampaign = require('../../../../lib/domain/read-models/SharedProfileForCampaign'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { SharedProfileForCampaign } from '../../../../lib/domain/read-models/SharedProfileForCampaign.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; describe('Unit | Domain | Models | SharedProfileForCampaign', function () { describe('#scorecards', function () { diff --git a/api/tests/unit/domain/read-models/TrainingForAdmin_test.js b/api/tests/unit/domain/read-models/TrainingForAdmin_test.js index 7a8c7838689..0b6e53e4d79 100644 --- a/api/tests/unit/domain/read-models/TrainingForAdmin_test.js +++ b/api/tests/unit/domain/read-models/TrainingForAdmin_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | Domain | Read-Models | TrainingForAdmin', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/read-models/TrainingTriggerForAdmin_test.js b/api/tests/unit/domain/read-models/TrainingTriggerForAdmin_test.js index cfa30a5ba5f..e0e07a9e161 100644 --- a/api/tests/unit/domain/read-models/TrainingTriggerForAdmin_test.js +++ b/api/tests/unit/domain/read-models/TrainingTriggerForAdmin_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder, catchErr } = require('../../../test-helper'); -const TrainingTriggerForAdmin = require('../../../../lib/domain/read-models/TrainingTriggerForAdmin'); +import { expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { TrainingTriggerForAdmin } from '../../../../lib/domain/read-models/TrainingTriggerForAdmin.js'; describe('Unit | Domain | Read-Models | TrainingTriggerForAdmin', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal_test.js b/api/tests/unit/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal_test.js index e3c8ad28ec0..d0acc5a8c85 100644 --- a/api/tests/unit/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal_test.js +++ b/api/tests/unit/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const CampaignAssessmentParticipationResultMinimal = require('../../../../../lib/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal'); +import { expect } from '../../../../test-helper.js'; +import { CampaignAssessmentParticipationResultMinimal } from '../../../../../lib/domain/read-models/campaign-results/CampaignAssessmentParticipationResultMinimal.js'; describe('Unit | Domain | Read-Models | CampaignResults | CampaignAssessmentParticipationResultMinimal', function () { describe('constructor', function () { diff --git a/api/tests/unit/domain/read-models/campaign/TargetProfileForSpecifier_test.js b/api/tests/unit/domain/read-models/campaign/TargetProfileForSpecifier_test.js index be1e0649fad..266fc816d21 100644 --- a/api/tests/unit/domain/read-models/campaign/TargetProfileForSpecifier_test.js +++ b/api/tests/unit/domain/read-models/campaign/TargetProfileForSpecifier_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const TargetProfileForSpecifier = require('../../../../../lib/domain/read-models/campaign/TargetProfileForSpecifier'); +import { expect } from '../../../../test-helper.js'; +import { TargetProfileForSpecifier } from '../../../../../lib/domain/read-models/campaign/TargetProfileForSpecifier.js'; describe('TargetProfileForSpecifier', function () { describe('#constructor', function () { diff --git a/api/tests/unit/domain/read-models/campaign/campaignManagment_test.js b/api/tests/unit/domain/read-models/campaign/campaignManagment_test.js index 0db7d282329..6e6b91192d3 100644 --- a/api/tests/unit/domain/read-models/campaign/campaignManagment_test.js +++ b/api/tests/unit/domain/read-models/campaign/campaignManagment_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const CampaignManagement = require('../../../../../lib/domain/read-models/CampaignManagement'); +import { expect } from '../../../../test-helper.js'; +import { CampaignManagement } from '../../../../../lib/domain/read-models/CampaignManagement.js'; describe('campaignManagement', function () { describe('#totalParticipationsCount', function () { diff --git a/api/tests/unit/domain/read-models/participant-results/AssessmentResult_test.js b/api/tests/unit/domain/read-models/participant-results/AssessmentResult_test.js index c9653bb1e7e..ecae65e32bd 100644 --- a/api/tests/unit/domain/read-models/participant-results/AssessmentResult_test.js +++ b/api/tests/unit/domain/read-models/participant-results/AssessmentResult_test.js @@ -1,8 +1,8 @@ -const { domainBuilder, expect, sinon } = require('../../../../test-helper'); -const { constants } = require('../../../../../lib/domain/constants'); -const AssessmentResult = require('../../../../../lib/domain/read-models/participant-results/AssessmentResult'); -const KnowledgeElement = require('../../../../../lib/domain/models/KnowledgeElement'); -const StageCollection = require('../../../../../lib/domain/models/user-campaign-results/StageCollection'); +import { domainBuilder, expect, sinon } from '../../../../test-helper.js'; +import { constants } from '../../../../../lib/domain/constants.js'; +import { AssessmentResult } from '../../../../../lib/domain/read-models/participant-results/AssessmentResult.js'; +import { KnowledgeElement } from '../../../../../lib/domain/models/KnowledgeElement.js'; +import { StageCollection } from '../../../../../lib/domain/models/user-campaign-results/StageCollection.js'; describe('Unit | Domain | Read-Models | ParticipantResult | AssessmentResult', function () { it('computes the number of skills, the number of skill tested and the number of skill validated', function () { @@ -417,12 +417,12 @@ describe('Unit | Domain | Read-Models | ParticipantResult | AssessmentResult', f originalConstantValue = constants.MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING; now = new Date('2020-01-05T05:06:07Z'); clock = sinon.useFakeTimers(now); - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING = 4; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING').value(4); }); afterEach(function () { clock.restore(); - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING = originalConstantValue; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING').value(originalConstantValue); }); context('when the campaign does not allow multiple sendings', function () { @@ -680,11 +680,11 @@ describe('Unit | Domain | Read-Models | ParticipantResult | AssessmentResult', f let clock; before(function () { - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING = 4; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING').value(4); }); after(function () { - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING = originalConstantValue; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_BEFORE_IMPROVING').value(originalConstantValue); }); beforeEach(function () { diff --git a/api/tests/unit/domain/read-models/participant-results/BadgeResult_test.js b/api/tests/unit/domain/read-models/participant-results/BadgeResult_test.js index 11acaa177de..78b526232b0 100644 --- a/api/tests/unit/domain/read-models/participant-results/BadgeResult_test.js +++ b/api/tests/unit/domain/read-models/participant-results/BadgeResult_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const BadgeResult = require('../../../../../lib/domain/read-models/participant-results/BadgeResult'); -const KnowledgeElement = require('../../../../../lib/domain/models/KnowledgeElement'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import { BadgeResult } from '../../../../../lib/domain/read-models/participant-results/BadgeResult.js'; +import { KnowledgeElement } from '../../../../../lib/domain/models/KnowledgeElement.js'; describe('Unit | Domain | Read-Models | ParticipantResult | BadgeResult', function () { it('computes the badges results', function () { diff --git a/api/tests/unit/domain/read-models/participant-results/CompetenceResult_test.js b/api/tests/unit/domain/read-models/participant-results/CompetenceResult_test.js index c0add47abf3..13b157d91b4 100644 --- a/api/tests/unit/domain/read-models/participant-results/CompetenceResult_test.js +++ b/api/tests/unit/domain/read-models/participant-results/CompetenceResult_test.js @@ -1,6 +1,6 @@ -const { domainBuilder, expect } = require('../../../../test-helper'); -const CompetenceResult = require('../../../../../lib/domain/read-models/participant-results/CompetenceResult'); -const KnowledgeElement = require('../../../../../lib/domain/models/KnowledgeElement'); +import { domainBuilder, expect } from '../../../../test-helper.js'; +import { CompetenceResult } from '../../../../../lib/domain/read-models/participant-results/CompetenceResult.js'; +import { KnowledgeElement } from '../../../../../lib/domain/models/KnowledgeElement.js'; describe('Unit | Domain | Read-Models | ParticipantResult | CompetenceResult', function () { it('computes the result for the given competence', function () { diff --git a/api/tests/unit/domain/read-models/participant-results/SkillSetResult_test.js b/api/tests/unit/domain/read-models/participant-results/SkillSetResult_test.js index db003842caa..4b448b85e85 100644 --- a/api/tests/unit/domain/read-models/participant-results/SkillSetResult_test.js +++ b/api/tests/unit/domain/read-models/participant-results/SkillSetResult_test.js @@ -1,6 +1,6 @@ -const { domainBuilder, expect } = require('../../../../test-helper'); -const SkillSetResult = require('../../../../../lib/domain/read-models/participant-results/SkillSetResult'); -const KnowledgeElement = require('../../../../../lib/domain/models/KnowledgeElement'); +import { domainBuilder, expect } from '../../../../test-helper.js'; +import { SkillSetResult } from '../../../../../lib/domain/read-models/participant-results/SkillSetResult.js'; +import { KnowledgeElement } from '../../../../../lib/domain/models/KnowledgeElement.js'; describe('Unit | Domain | Read-Models | ParticipantResults | SkillSetResult', function () { it('computes the result for the given competence', function () { diff --git a/api/tests/unit/domain/services/assessment-result-service_test.js b/api/tests/unit/domain/services/assessment-result-service_test.js index 1d8e5feb5c5..0e79d3b25a0 100644 --- a/api/tests/unit/domain/services/assessment-result-service_test.js +++ b/api/tests/unit/domain/services/assessment-result-service_test.js @@ -1,8 +1,8 @@ -const { expect, sinon } = require('../../../test-helper'); +import { expect, sinon } from '../../../test-helper.js'; -const service = require('../../../../lib/domain/services/assessment-result-service'); -const AssessmentResult = require('../../../../lib/domain/models/AssessmentResult'); -const CompetenceMark = require('../../../../lib/domain/models/CompetenceMark'); +import * as service from '../../../../lib/domain/services/assessment-result-service.js'; +import { AssessmentResult } from '../../../../lib/domain/models/AssessmentResult.js'; +import { CompetenceMark } from '../../../../lib/domain/models/CompetenceMark.js'; describe('Unit | Domain | Services | assessment-results', function () { describe('#save', function () { diff --git a/api/tests/unit/domain/services/authentication/authentication-service-registry_test.js b/api/tests/unit/domain/services/authentication/authentication-service-registry_test.js index 2f28af96235..c5db92679f4 100644 --- a/api/tests/unit/domain/services/authentication/authentication-service-registry_test.js +++ b/api/tests/unit/domain/services/authentication/authentication-service-registry_test.js @@ -1,8 +1,6 @@ -const { expect, catchErr } = require('../../../../test-helper'); -const authenticationRegistry = require('../../../../../lib/domain/services/authentication/authentication-service-registry'); -const PoleEmploiOidcAuthenticationService = require('../../../../../lib/domain/services/authentication/pole-emploi-oidc-authentication-service'); -const FwbOidcAuthenticationService = require('../../../../../lib/domain/services/authentication/fwb-oidc-authentication-service'); -const { InvalidIdentityProviderError } = require('../../../../../lib/domain/errors'); +import { expect, catchErr } from '../../../../test-helper.js'; +import * as authenticationRegistry from '../../../../../lib/domain/services/authentication/authentication-service-registry.js'; +import { InvalidIdentityProviderError } from '../../../../../lib/domain/errors.js'; describe('Unit | Domain | Services | authentication registry', function () { describe('#lookupAuthenticationService', function () { @@ -14,7 +12,7 @@ describe('Unit | Domain | Services | authentication registry', function () { const service = await authenticationRegistry.lookupAuthenticationService(identityProvider); // then - expect(service).to.be.an.instanceOf(PoleEmploiOidcAuthenticationService); + expect(service.identityProvider).to.equal('POLE_EMPLOI'); }); it('finds the identity provider service with hasLogoutUrl', async function () { @@ -25,7 +23,7 @@ describe('Unit | Domain | Services | authentication registry', function () { const service = await authenticationRegistry.lookupAuthenticationService(identityProvider); // then - expect(service).to.be.an.instanceOf(FwbOidcAuthenticationService); + expect(service.identityProvider).to.equal('FWB'); expect(service.hasLogoutUrl).to.be.true; }); diff --git a/api/tests/unit/domain/services/authentication/authentication-session-service_test.js b/api/tests/unit/domain/services/authentication/authentication-session-service_test.js index 081f76f930b..155677fc365 100644 --- a/api/tests/unit/domain/services/authentication/authentication-session-service_test.js +++ b/api/tests/unit/domain/services/authentication/authentication-session-service_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const authenticationSessionService = require('../../../../../lib/domain/services/authentication/authentication-session-service'); +import { expect } from '../../../../test-helper.js'; +import * as authenticationSessionService from '../../../../../lib/domain/services/authentication/authentication-session-service.js'; describe('Unit | Domain | Services | authentication session', function () { describe('#getByKey', function () { diff --git a/api/tests/unit/domain/services/authentication/oidc-authentication-service_test.js b/api/tests/unit/domain/services/authentication/oidc-authentication-service_test.js index 31cc0904bf0..69ba7e81449 100644 --- a/api/tests/unit/domain/services/authentication/oidc-authentication-service_test.js +++ b/api/tests/unit/domain/services/authentication/oidc-authentication-service_test.js @@ -1,22 +1,24 @@ -const { expect, sinon, catchErr } = require('../../../../test-helper'); -const settings = require('../../../../../lib/config'); - -const OidcAuthenticationService = require('../../../../../lib/domain/services/authentication/oidc-authentication-service'); -const jsonwebtoken = require('jsonwebtoken'); -const httpAgent = require('../../../../../lib/infrastructure/http/http-agent'); -const AuthenticationSessionContent = require('../../../../../lib/domain/models/AuthenticationSessionContent'); -const { +import { expect, sinon, catchErr } from '../../../../test-helper.js'; +import { config as settings } from '../../../../../lib/config.js'; + +import { OidcAuthenticationService } from '../../../../../lib/domain/services/authentication/oidc-authentication-service.js'; +import jsonwebtoken from 'jsonwebtoken'; +import { httpAgent } from '../../../../../lib/infrastructure/http/http-agent.js'; +import { AuthenticationSessionContent } from '../../../../../lib/domain/models/AuthenticationSessionContent.js'; + +import { InvalidExternalAPIResponseError, OidcInvokingTokenEndpointError, OidcMissingFieldsError, OidcUserInfoFormatError, -} = require('../../../../../lib/domain/errors'); -const DomainTransaction = require('../../../../../lib/infrastructure/DomainTransaction'); -const UserToCreate = require('../../../../../lib/domain/models/UserToCreate'); -const AuthenticationMethod = require('../../../../../lib/domain/models/AuthenticationMethod'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); -const monitoringTools = require('../../../../../lib/infrastructure/monitoring-tools'); -const { OIDC_ERRORS } = require('../../../../../lib/domain/constants'); +} from '../../../../../lib/domain/errors.js'; + +import { DomainTransaction } from '../../../../../lib/infrastructure/DomainTransaction.js'; +import { UserToCreate } from '../../../../../lib/domain/models/UserToCreate.js'; +import { AuthenticationMethod } from '../../../../../lib/domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; +import { monitoringTools } from '../../../../../lib/infrastructure/monitoring-tools.js'; +import { OIDC_ERRORS } from '../../../../../lib/domain/constants.js'; describe('Unit | Domain | Services | oidc-authentication-service', function () { describe('#createAccessToken', function () { diff --git a/api/tests/unit/domain/services/authentication/pix-authentication-service_test.js b/api/tests/unit/domain/services/authentication/pix-authentication-service_test.js index 196a15dfcea..a09c26f0aad 100644 --- a/api/tests/unit/domain/services/authentication/pix-authentication-service_test.js +++ b/api/tests/unit/domain/services/authentication/pix-authentication-service_test.js @@ -1,9 +1,8 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../../test-helper'); -const { PasswordNotMatching, UserNotFoundError } = require('../../../../../lib/domain/errors'); - -const User = require('../../../../../lib/domain/models/User'); -const UserLogin = require('../../../../../lib/domain/models/UserLogin'); -const pixAuthenticationService = require('../../../../../lib/domain/services/authentication/pix-authentication-service'); +import { expect, sinon, domainBuilder, catchErr } from '../../../../test-helper.js'; +import { PasswordNotMatching, UserNotFoundError } from '../../../../../lib/domain/errors.js'; +import { User } from '../../../../../lib/domain/models/User.js'; +import { UserLogin } from '../../../../../lib/domain/models/UserLogin.js'; +import * as pixAuthenticationService from '../../../../../lib/domain/services/authentication/pix-authentication-service.js'; describe('Unit | Domain | Services | pix-authentication-service', function () { describe('#getUserByUsernameAndPassword', function () { diff --git a/api/tests/unit/domain/services/authentication/pole-emploi-oidc-authentication-service_test.js b/api/tests/unit/domain/services/authentication/pole-emploi-oidc-authentication-service_test.js index 015209f0f11..ba71257539e 100644 --- a/api/tests/unit/domain/services/authentication/pole-emploi-oidc-authentication-service_test.js +++ b/api/tests/unit/domain/services/authentication/pole-emploi-oidc-authentication-service_test.js @@ -1,7 +1,8 @@ -const { expect } = require('../../../../test-helper'); -const AuthenticationMethod = require('../../../../../lib/domain/models/AuthenticationMethod'); -const PoleEmploiOidcAuthenticationService = require('../../../../../lib/domain/services/authentication/pole-emploi-oidc-authentication-service'); -const { temporaryStorage } = require('../../../../../lib/infrastructure/temporary-storage/index.js'); +import { expect } from '../../../../test-helper.js'; +import { AuthenticationMethod } from '../../../../../lib/domain/models/AuthenticationMethod.js'; +import { PoleEmploiOidcAuthenticationService } from '../../../../../lib/domain/services/authentication/pole-emploi-oidc-authentication-service.js'; +import { temporaryStorage } from '../../../../../lib/infrastructure/temporary-storage/index.js'; + const logoutUrlTemporaryStorage = temporaryStorage.withPrefix('logout-url:'); describe('Unit | Domain | Services | pole-emploi-oidc-authentication-service', function () { diff --git a/api/tests/unit/domain/services/campaign-participation-service_test.js b/api/tests/unit/domain/services/campaign-participation-service_test.js index 5023c48748b..e5f29784173 100644 --- a/api/tests/unit/domain/services/campaign-participation-service_test.js +++ b/api/tests/unit/domain/services/campaign-participation-service_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); +import { expect } from '../../../test-helper.js'; -const campaignParticipationService = require('./../../../../lib/domain/services/campaign-participation-service'); +import * as campaignParticipationService from './../../../../lib/domain/services/campaign-participation-service.js'; describe('Unit | Service | Campaign Participation Service', function () { describe('progress', function () { diff --git a/api/tests/unit/domain/services/campaigns/campaign-code-generator_test.js b/api/tests/unit/domain/services/campaigns/campaign-code-generator_test.js index 9025a304cc9..d2265e11cd9 100644 --- a/api/tests/unit/domain/services/campaigns/campaign-code-generator_test.js +++ b/api/tests/unit/domain/services/campaigns/campaign-code-generator_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../../test-helper'); -const randomString = require('randomstring'); -const campaignCodeGenerator = require('../../../../../lib/domain/services/campaigns/campaign-code-generator'); +import { expect, sinon } from '../../../../test-helper.js'; +import randomString from 'randomstring'; +import * as campaignCodeGenerator from '../../../../../lib/domain/services/campaigns/campaign-code-generator.js'; describe('Unit | Domain | Services | campaign code generator', function () { describe('#createCampaignCode', function () { diff --git a/api/tests/unit/domain/services/certification-badges-service_test.js b/api/tests/unit/domain/services/certification-badges-service_test.js index 503c14d4ec9..5e39b969977 100644 --- a/api/tests/unit/domain/services/certification-badges-service_test.js +++ b/api/tests/unit/domain/services/certification-badges-service_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const certificationBadgesService = require('../../../../lib/domain/services/certification-badges-service'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as certificationBadgesService from '../../../../lib/domain/services/certification-badges-service.js'; describe('Unit | Service | certification-badges-service', function () { describe('#findStillValidBadgeAcquisitions', function () { diff --git a/api/tests/unit/domain/services/certification-challenges-service_test.js b/api/tests/unit/domain/services/certification-challenges-service_test.js index d2f1aebb4b2..254856ab2ab 100644 --- a/api/tests/unit/domain/services/certification-challenges-service_test.js +++ b/api/tests/unit/domain/services/certification-challenges-service_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const { PIX_ORIGIN } = require('../../../../lib/domain/constants'); -const PlacementProfile = require('../../../../lib/domain/models/PlacementProfile'); -const certificationChallengesService = require('../../../../lib/domain/services/certification-challenges-service'); +import _ from 'lodash'; +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { PIX_ORIGIN } from '../../../../lib/domain/constants.js'; +import { PlacementProfile } from '../../../../lib/domain/models/PlacementProfile.js'; +import * as certificationChallengesService from '../../../../lib/domain/services/certification-challenges-service.js'; describe('Unit | Service | Certification Challenge Service', function () { const userId = 63731; diff --git a/api/tests/unit/domain/services/certification-cpf-service_test.js b/api/tests/unit/domain/services/certification-cpf-service_test.js index 8c58baf8760..a2e0921ef4f 100644 --- a/api/tests/unit/domain/services/certification-cpf-service_test.js +++ b/api/tests/unit/domain/services/certification-cpf-service_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const { +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { CpfBirthInformationValidation, getBirthInformation, -} = require('../../../../lib/domain/services/certification-cpf-service'); -const { CERTIFICATION_CANDIDATES_ERRORS } = require('../../../../lib/domain/constants/certification-candidates-errors'); +} from '../../../../lib/domain/services/certification-cpf-service.js'; +import { CERTIFICATION_CANDIDATES_ERRORS } from '../../../../lib/domain/constants/certification-candidates-errors.js'; describe('Unit | Service | Certification CPF service', function () { let certificationCpfCountryRepository; diff --git a/api/tests/unit/domain/services/course-service_test.js b/api/tests/unit/domain/services/course-service_test.js index fabdfb2ab67..94dbcf62b1c 100644 --- a/api/tests/unit/domain/services/course-service_test.js +++ b/api/tests/unit/domain/services/course-service_test.js @@ -1,6 +1,6 @@ -const courseService = require('../../../../lib/domain/services/course-service'); -const logger = require('../../../../lib/infrastructure/logger'); -const { expect, sinon } = require('../../../test-helper'); +import * as courseService from '../../../../lib/domain/services/course-service.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; +import { expect, sinon } from '../../../test-helper.js'; describe('Unit | Service | Course Service', function () { describe('#getCourse', function () { diff --git a/api/tests/unit/domain/services/cpf-certification-xml-export-service_test.js b/api/tests/unit/domain/services/cpf-certification-xml-export-service_test.js index 00cdf197d4d..1a7cba283db 100644 --- a/api/tests/unit/domain/services/cpf-certification-xml-export-service_test.js +++ b/api/tests/unit/domain/services/cpf-certification-xml-export-service_test.js @@ -1,29 +1,25 @@ -const { expect, domainBuilder, sinon, streamToPromise } = require('../../../test-helper'); -const { PassThrough } = require('stream'); -const proxyquire = require('proxyquire'); -const dayjs = require('dayjs'); -const utc = require('dayjs/plugin/utc'); -const timezone = require('dayjs/plugin/timezone'); +import { expect, domainBuilder, sinon, streamToPromise } from '../../../test-helper.js'; +import stream from 'stream'; + +const { PassThrough } = stream; + +import dayjs from 'dayjs'; +import utc from 'dayjs/plugin/utc.js'; +import timezone from 'dayjs/plugin/timezone.js'; + dayjs.extend(utc); dayjs.extend(timezone); -const cpfCertificationXmlExportService = proxyquire( - '../../../../lib/domain/services/cpf-certification-xml-export-service', - { - uuid: { - v4: () => { - return '5d079a5d-0a4d-45ac-854d-256b01cacdfe'; - }, - }, - } -); +import * as cpfCertificationXmlExportService from '../../../../lib/domain/services/cpf-certification-xml-export-service.js'; describe('Unit | Services | cpf-certification-xml-export-service', function () { let clock; + let uuidService; beforeEach(function () { const now = dayjs('2022-02-01T10:43:27Z').tz('Europe/Paris').toDate(); clock = sinon.useFakeTimers(now); + uuidService = { v4: sinon.stub() }; }); afterEach(function () { @@ -33,6 +29,9 @@ describe('Unit | Services | cpf-certification-xml-export-service', function () { describe('getXmlExport', function () { it('should return a writable stream with cpf certification results', async function () { // given + + uuidService.v4.returns('5d079a5d-0a4d-45ac-854d-256b01cacdfe'); + const firstCpfCertificationResult = domainBuilder.buildCpfCertificationResult({ id: 1234, firstName: 'Bart', @@ -74,6 +73,7 @@ describe('Unit | Services | cpf-certification-xml-export-service', function () { cpfCertificationXmlExportService.buildXmlExport({ cpfCertificationResults: [firstCpfCertificationResult, secondCpfCertificationResult], writableStream, + uuidService, }); //then diff --git a/api/tests/unit/domain/services/email-validator_test.js b/api/tests/unit/domain/services/email-validator_test.js index b1da2aec77c..d2baa6be631 100644 --- a/api/tests/unit/domain/services/email-validator_test.js +++ b/api/tests/unit/domain/services/email-validator_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const service = require('../../../../lib/domain/services/email-validator'); +import { expect } from '../../../test-helper.js'; +import * as service from '../../../../lib/domain/services/email-validator.js'; describe('Unit | Service | email-validator', function () { it('should return false when email is not provided', function () { diff --git a/api/tests/unit/domain/services/encryption-service_test.js b/api/tests/unit/domain/services/encryption-service_test.js index ab8cd4010dc..e1e7a004108 100644 --- a/api/tests/unit/domain/services/encryption-service_test.js +++ b/api/tests/unit/domain/services/encryption-service_test.js @@ -1,8 +1,8 @@ -const { catchErr, expect } = require('../../../test-helper'); +import { catchErr, expect } from '../../../test-helper.js'; -const bcrypt = require('bcrypt'); -const encryptionService = require('../../../../lib/domain/services/encryption-service'); -const PasswordNotMatching = require('../../../../lib/domain/errors').PasswordNotMatching; +import bcrypt from 'bcrypt'; +import * as encryptionService from '../../../../lib/domain/services/encryption-service.js'; +import { PasswordNotMatching } from '../../../../lib/domain/errors.js'; describe('Unit | Service | Encryption', function () { describe('#checkPassword', function () { diff --git a/api/tests/unit/domain/services/get-competence-level_test.js b/api/tests/unit/domain/services/get-competence-level_test.js index 41afd832a15..b65d50369d7 100644 --- a/api/tests/unit/domain/services/get-competence-level_test.js +++ b/api/tests/unit/domain/services/get-competence-level_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const getCompetenceLevel = require('../../../../lib/domain/services/get-competence-level'); +import { expect, sinon } from '../../../test-helper.js'; +import { getCompetenceLevel } from '../../../../lib/domain/services/get-competence-level.js'; describe('Unit | Domain | Service | Get Competence Level', function () { describe('#getCompetenceLevel', function () { diff --git a/api/tests/unit/domain/services/get-translated-text_test.js b/api/tests/unit/domain/services/get-translated-text_test.js index c902ee1003a..a7124bd0264 100644 --- a/api/tests/unit/domain/services/get-translated-text_test.js +++ b/api/tests/unit/domain/services/get-translated-text_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../../test-helper'); - -const service = require('../../../../lib/domain/services/get-translated-text'); +import { expect } from '../../../test-helper.js'; +import * as service from '../../../../lib/domain/services/get-translated-text.js'; describe('Unit | Domain | Services | get-translated-text', function () { describe('#getTranslatedKey', function () { const translatedKey = { diff --git a/api/tests/unit/domain/services/improvement-service_test.js b/api/tests/unit/domain/services/improvement-service_test.js index 0048a64f005..4460028f065 100644 --- a/api/tests/unit/domain/services/improvement-service_test.js +++ b/api/tests/unit/domain/services/improvement-service_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const _ = require('lodash'); -const improvementService = require('../../../../lib/domain/services/improvement-service'); -const { constants } = require('../../../../lib/domain/constants'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import _ from 'lodash'; +import * as improvementService from '../../../../lib/domain/services/improvement-service.js'; +import { constants } from '../../../../lib/domain/constants.js'; describe('Unit | Service | ImprovementService', function () { describe('#filterKnowledgeElementsIfImproving', function () { @@ -29,7 +29,7 @@ describe('Unit | Service | ImprovementService', function () { beforeEach(function () { originalConstantValue = constants.MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING; - constants['MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING'] = 3; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING').value(3); const assessmentDate = '2020-07-30'; assessment = domainBuilder.buildAssessment.ofTypeCampaign({ @@ -46,7 +46,7 @@ describe('Unit | Service | ImprovementService', function () { }); afterEach(function () { - constants.MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING = originalConstantValue; + sinon.stub(constants, 'MINIMUM_DELAY_IN_DAYS_BEFORE_RETRYING').value(originalConstantValue); }); it('should return the same list of knowledge-elements if assessment is not improving', function () { diff --git a/api/tests/unit/domain/services/learning-content/learning-content-conversion-service_test.js b/api/tests/unit/domain/services/learning-content/learning-content-conversion-service_test.js index 4f423d032f1..69fcdebda00 100644 --- a/api/tests/unit/domain/services/learning-content/learning-content-conversion-service_test.js +++ b/api/tests/unit/domain/services/learning-content/learning-content-conversion-service_test.js @@ -1,7 +1,5 @@ -const { expect, domainBuilder, sinon } = require('../../../../test-helper'); -const { - findActiveSkillsForCappedTubes, -} = require('../../../../../lib/domain/services/learning-content/learning-content-conversion-service'); +import { expect, domainBuilder, sinon } from '../../../../test-helper.js'; +import { findActiveSkillsForCappedTubes } from '../../../../../lib/domain/services/learning-content/learning-content-conversion-service.js'; describe('Unit | Service | learning-content-conversion-service', function () { describe('#findActiveSkillsForCappedTubes', function () { diff --git a/api/tests/unit/domain/services/locale-service_test.js b/api/tests/unit/domain/services/locale-service_test.js index 2f367ecd911..b80ab30c46e 100644 --- a/api/tests/unit/domain/services/locale-service_test.js +++ b/api/tests/unit/domain/services/locale-service_test.js @@ -1,6 +1,6 @@ -const { expect, catchErrSync } = require('../../../test-helper'); -const { LocaleFormatError, LocaleNotSupportedError } = require('../../../../lib/domain/errors'); -const { getCanonicalLocale } = require('../../../../lib/domain/services/locale-service'); +import { expect, catchErrSync } from '../../../test-helper.js'; +import { LocaleFormatError, LocaleNotSupportedError } from '../../../../lib/domain/errors.js'; +import { getCanonicalLocale } from '../../../../lib/domain/services/locale-service.js'; describe('#getCanonicalLocale', function () { it('throws a LocaleFormatError error', function () { diff --git a/api/tests/unit/domain/services/mail-service_test.js b/api/tests/unit/domain/services/mail-service_test.js index 93b54eefd49..9776c1165dd 100644 --- a/api/tests/unit/domain/services/mail-service_test.js +++ b/api/tests/unit/domain/services/mail-service_test.js @@ -1,17 +1,21 @@ -const { sinon, expect } = require('../../../test-helper'); +import { sinon, expect } from '../../../test-helper.js'; -const mailService = require('../../../../lib/domain/services/mail-service'); -const { mailer } = require('../../../../lib/infrastructure/mailers/mailer'); -const tokenService = require('../../../../lib/domain/services/token-service'); -const settings = require('../../../../lib/config'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import * as mailService from '../../../../lib/domain/services/mail-service.js'; +import { mailer } from '../../../../lib/infrastructure/mailers/mailer.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import { config as settings } from '../../../../lib/config.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; +import fr from '../../../../translations/fr.json' assert { type: 'json' }; +import en from '../../../../translations/en.json' assert { type: 'json' }; const mainTranslationsMapping = { - fr: require('../../../../translations/fr'), - en: require('../../../../translations/en'), + fr, + en, }; -const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = LOCALE; describe('Unit | Service | MailService', function () { const senderEmailAddress = 'ne-pas-repondre@pix.fr'; diff --git a/api/tests/unit/domain/services/obfuscation-service_test.js b/api/tests/unit/domain/services/obfuscation-service_test.js index f5a9bb540c9..5d11925bc12 100644 --- a/api/tests/unit/domain/services/obfuscation-service_test.js +++ b/api/tests/unit/domain/services/obfuscation-service_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const obfuscationService = require('../../../../lib/domain/services/obfuscation-service'); -const User = require('../../../../lib/domain/models/User'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import * as obfuscationService from '../../../../lib/domain/services/obfuscation-service.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | Service | user-authentication-method-obfuscation-service', function () { let authenticationMethodRepository; diff --git a/api/tests/unit/domain/services/organization-invitation-service_test.js b/api/tests/unit/domain/services/organization-invitation-service_test.js index fe3659d596a..91887bb387d 100644 --- a/api/tests/unit/domain/services/organization-invitation-service_test.js +++ b/api/tests/unit/domain/services/organization-invitation-service_test.js @@ -1,16 +1,18 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const Membership = require('../../../../lib/domain/models/Membership'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const { +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; + +import { createOrUpdateOrganizationInvitation, createScoOrganizationInvitation, createProOrganizationInvitation, -} = require('../../../../lib/domain/services/organization-invitation-service'); -const { +} from '../../../../lib/domain/services/organization-invitation-service.js'; + +import { SendingEmailToInvalidDomainError, SendingEmailToInvalidEmailAddressError, -} = require('../../../../lib/domain/errors'); -const EmailingAttempt = require('../../../../lib/domain/models/EmailingAttempt'); +} from '../../../../lib/domain/errors.js'; +import { EmailingAttempt } from '../../../../lib/domain/models/EmailingAttempt.js'; describe('Unit | Service | Organization-Invitation Service', function () { const userEmailAddress = 'user@example.net'; diff --git a/api/tests/unit/domain/services/password-generator_test.js b/api/tests/unit/domain/services/password-generator_test.js index 83fc2fb14af..0d0a044bf62 100644 --- a/api/tests/unit/domain/services/password-generator_test.js +++ b/api/tests/unit/domain/services/password-generator_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const service = require('../../../../lib/domain/services/password-generator'); -const randomString = require('randomstring'); +import { expect, sinon } from '../../../test-helper.js'; +import * as service from '../../../../lib/domain/services/password-generator.js'; +import randomString from 'randomstring'; describe('Unit | Service | password-generator', function () { let generatedPassword; diff --git a/api/tests/unit/domain/services/pick-challenge-service_test.js b/api/tests/unit/domain/services/pick-challenge-service_test.js index 36f5a5b5bda..d62c29bc0b8 100644 --- a/api/tests/unit/domain/services/pick-challenge-service_test.js +++ b/api/tests/unit/domain/services/pick-challenge-service_test.js @@ -1,7 +1,10 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const pickChallengeService = require('../../../../lib/domain/services/pick-challenge-service'); -const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; -const _ = require('lodash'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import * as pickChallengeService from '../../../../lib/domain/services/pick-challenge-service.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = LOCALE; + +import _ from 'lodash'; describe('Unit | Service | PickChallengeService', function () { describe('#pickChallenge', function () { diff --git a/api/tests/unit/domain/services/pole-emploi-service_test.js b/api/tests/unit/domain/services/pole-emploi-service_test.js index 09a4f9d0db2..04b82ee966c 100644 --- a/api/tests/unit/domain/services/pole-emploi-service_test.js +++ b/api/tests/unit/domain/services/pole-emploi-service_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const poleEmploiService = require('../../../../lib/domain/services/pole-emploi-service'); -const settings = require('../../../../lib/config'); +import { expect } from '../../../test-helper.js'; +import * as poleEmploiService from '../../../../lib/domain/services/pole-emploi-service.js'; +import { config as settings } from '../../../../lib/config.js'; describe('Unit | Service | Pole Emploi Service', function () { describe('#generateLink', function () { diff --git a/api/tests/unit/domain/services/recommendation-service_test.js b/api/tests/unit/domain/services/recommendation-service_test.js index db1e2b37694..6d19af86e96 100644 --- a/api/tests/unit/domain/services/recommendation-service_test.js +++ b/api/tests/unit/domain/services/recommendation-service_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); +import { expect } from '../../../test-helper.js'; -const recommendationService = require('./../../../../lib/domain/services/recommendation-service'); +import * as recommendationService from './../../../../lib/domain/services/recommendation-service.js'; describe('Unit | Service | Campaign Recommendation Service', function () { describe('computeRecommendationScore', function () { diff --git a/api/tests/unit/domain/services/refresh-token-service_test.js b/api/tests/unit/domain/services/refresh-token-service_test.js index 3a5c2f3b539..d5ebf12e552 100644 --- a/api/tests/unit/domain/services/refresh-token-service_test.js +++ b/api/tests/unit/domain/services/refresh-token-service_test.js @@ -1,10 +1,10 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const settings = require('../../../../lib/config'); -const tokenService = require('../../../../lib/domain/services/token-service'); -const refreshTokenService = require('../../../../lib/domain/services/refresh-token-service'); -const { UnauthorizedError } = require('../../../../lib/application/http-errors'); -const refreshTokenTemporaryStorage = refreshTokenService.refreshTokenTemporaryStorageForTests; -const userRefreshTokensTemporaryStorage = refreshTokenService.userRefreshTokensTemporaryStorageForTests; +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import { config as settings } from '../../../../lib/config.js'; +import * as refreshTokenService from '../../../../lib/domain/services/refresh-token-service.js'; +import { UnauthorizedError } from '../../../../lib/application/http-errors.js'; +const refreshTokenTemporaryStorage = refreshTokenService.refreshTokenTemporaryStorage; +const userRefreshTokensTemporaryStorage = refreshTokenService.userRefreshTokensTemporaryStorage; describe('Unit | Domain | Service | Refresh Token Service', function () { describe('#createRefreshTokenFromUserId', function () { diff --git a/api/tests/unit/domain/services/reset-password-service_test.js b/api/tests/unit/domain/services/reset-password-service_test.js index 5e0ce094d4e..6ad90d08fb9 100644 --- a/api/tests/unit/domain/services/reset-password-service_test.js +++ b/api/tests/unit/domain/services/reset-password-service_test.js @@ -1,8 +1,8 @@ -const jsonwebtoken = require('jsonwebtoken'); -const crypto = require('crypto'); -const { sinon, expect } = require('../../../test-helper'); -const settings = require('../../../../lib/config'); -const resetPasswordService = require('../../../../lib/domain/services/reset-password-service'); +import jsonwebtoken from 'jsonwebtoken'; +import crypto from 'crypto'; +import { sinon, expect } from '../../../test-helper.js'; +import { config as settings } from '../../../../lib/config.js'; +import * as resetPasswordService from '../../../../lib/domain/services/reset-password-service.js'; describe('Unit | Service | Password Service', function () { describe('#generateTemporaryKey', function () { diff --git a/api/tests/unit/domain/services/sco-account-recovery-service_test.js b/api/tests/unit/domain/services/sco-account-recovery-service_test.js index 7522dfaba05..6f2c35d4fc0 100644 --- a/api/tests/unit/domain/services/sco-account-recovery-service_test.js +++ b/api/tests/unit/domain/services/sco-account-recovery-service_test.js @@ -1,17 +1,21 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const { +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { retrieveOrganizationLearner, retrieveAndValidateAccountRecoveryDemand, -} = require('../../../../lib/domain/services/sco-account-recovery-service'); -const { +} from '../../../../lib/domain/services/sco-account-recovery-service.js'; + +import { AccountRecoveryDemandExpired, AlreadyRegisteredEmailError, MultipleOrganizationLearnersWithDifferentNationalStudentIdError, UserNotFoundError, UserHasAlreadyLeftSCO, -} = require('../../../../lib/domain/errors'); -const { features } = require('../../../../lib/config'); -const dayjs = require('dayjs'); +} from '../../../../lib/domain/errors.js'; + +import { config } from '../../../../lib/config.js'; +import dayjs from 'dayjs'; + +const { features } = config; describe('Unit | Service | sco-account-recovery-service', function () { describe('#retrieveOrganizationLearner', function () { diff --git a/api/tests/unit/domain/services/scorecard-service_test.js b/api/tests/unit/domain/services/scorecard-service_test.js index 5310f04a23c..0b9820b8029 100644 --- a/api/tests/unit/domain/services/scorecard-service_test.js +++ b/api/tests/unit/domain/services/scorecard-service_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); -const CompetenceEvaluation = require('../../../../lib/domain/models/CompetenceEvaluation'); -const scorecardService = require('../../../../lib/domain/services/scorecard-service'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; +import { CompetenceEvaluation } from '../../../../lib/domain/models/CompetenceEvaluation.js'; +import * as scorecardService from '../../../../lib/domain/services/scorecard-service.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { STARTED, SHARED } = CampaignParticipationStatuses; diff --git a/api/tests/unit/domain/services/scoring/scoring-certification-service_test.js b/api/tests/unit/domain/services/scoring/scoring-certification-service_test.js index 85bc1d178a7..31ed1886820 100644 --- a/api/tests/unit/domain/services/scoring/scoring-certification-service_test.js +++ b/api/tests/unit/domain/services/scoring/scoring-certification-service_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, sinon, domainBuilder, catchErr } = require('../../../../test-helper'); -const scoringCertificationService = require('../../../../../lib/domain/services/scoring/scoring-certification-service'); -const { states } = require('../../../../../lib/domain/models/CertificationAssessment'); -const { CertificationComputeError } = require('../../../../../lib/domain/errors'); +import _ from 'lodash'; +import { expect, sinon, domainBuilder, catchErr } from '../../../../test-helper.js'; +import * as scoringCertificationService from '../../../../../lib/domain/services/scoring/scoring-certification-service.js'; +import { states } from '../../../../../lib/domain/models/CertificationAssessment.js'; +import { CertificationComputeError } from '../../../../../lib/domain/errors.js'; function _buildUserCompetence(competence, pixScore, estimatedLevel) { return domainBuilder.buildUserCompetence({ ...competence, estimatedLevel, pixScore }); diff --git a/api/tests/unit/domain/services/scoring/scoring-service_test.js b/api/tests/unit/domain/services/scoring/scoring-service_test.js index 723354c656a..8dbce7bc7db 100644 --- a/api/tests/unit/domain/services/scoring/scoring-service_test.js +++ b/api/tests/unit/domain/services/scoring/scoring-service_test.js @@ -1,11 +1,10 @@ -const scoringService = require('../../../../../lib/domain/services/scoring/scoring-service'); -const { +import * as scoringService from '../../../../../lib/domain/services/scoring/scoring-service.js'; +import { PIX_COUNT_BY_LEVEL, MAX_REACHABLE_LEVEL, MAX_REACHABLE_PIX_BY_COMPETENCE, -} = require('../../../../../lib/domain/constants'); - -const { expect, domainBuilder } = require('../../../../test-helper'); +} from '../../../../../lib/domain/constants.js'; +import { expect, domainBuilder } from '../../../../test-helper.js'; describe('Unit | Service | Scoring Service', function () { describe('#calculateScoringInformationForCompetence', function () { diff --git a/api/tests/unit/domain/services/session-code-service_test.js b/api/tests/unit/domain/services/session-code-service_test.js index fed03b6e024..a185c9a1b53 100644 --- a/api/tests/unit/domain/services/session-code-service_test.js +++ b/api/tests/unit/domain/services/session-code-service_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const sessionCodeService = require('../../../../lib/domain/services/session-code-service'); +import { expect } from '../../../test-helper.js'; +import * as sessionCodeService from '../../../../lib/domain/services/session-code-service.js'; describe('Unit | Service | CodeSession', function () { describe('#getNewSessionCode', function () { diff --git a/api/tests/unit/domain/services/session-publication-service_test.js b/api/tests/unit/domain/services/session-publication-service_test.js index ef9a1727161..36d3cb246a2 100644 --- a/api/tests/unit/domain/services/session-publication-service_test.js +++ b/api/tests/unit/domain/services/session-publication-service_test.js @@ -1,14 +1,15 @@ -const { domainBuilder, sinon, expect, catchErr } = require('../../../test-helper'); +import { domainBuilder, sinon, expect, catchErr } from '../../../test-helper.js'; +import { publishSession } from '../../../../lib/domain/services/session-publication-service.js'; +import { FinalizedSession } from '../../../../lib/domain/models/FinalizedSession.js'; -const { publishSession } = require('../../../../lib/domain/services/session-publication-service'); -const FinalizedSession = require('../../../../lib/domain/models/FinalizedSession'); -const { +import { SendingEmailToResultRecipientError, SessionAlreadyPublishedError, SendingEmailToRefererError, -} = require('../../../../lib/domain/errors'); -const EmailingAttempt = require('../../../../lib/domain/models/EmailingAttempt'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +} from '../../../../lib/domain/errors.js'; + +import { EmailingAttempt } from '../../../../lib/domain/models/EmailingAttempt.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; describe('Unit | UseCase | session-publication-service', function () { const sessionId = 123; diff --git a/api/tests/unit/domain/services/session-results-link-service_test.js b/api/tests/unit/domain/services/session-results-link-service_test.js index 24e57d4a55b..30239205b38 100644 --- a/api/tests/unit/domain/services/session-results-link-service_test.js +++ b/api/tests/unit/domain/services/session-results-link-service_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const sessionResultsLinkService = require('../../../../lib/domain/services/session-results-link-service'); -const tokenService = require('../../../../lib/domain/services/token-service'); +import { expect, sinon } from '../../../test-helper.js'; +import * as sessionResultsLinkService from '../../../../lib/domain/services/session-results-link-service.js'; +import { tokenService } from '../../../../lib/domain/services/token-service.js'; describe('Unit | Domain | Service | Session Results Link Service', function () { describe('#generateResultsLink', function () { diff --git a/api/tests/unit/domain/services/sessions-mass-import/sessions-import-validation-service_test.js b/api/tests/unit/domain/services/sessions-mass-import/sessions-import-validation-service_test.js index 4dedd23aab7..736b497f88f 100644 --- a/api/tests/unit/domain/services/sessions-mass-import/sessions-import-validation-service_test.js +++ b/api/tests/unit/domain/services/sessions-mass-import/sessions-import-validation-service_test.js @@ -1,10 +1,9 @@ -const { expect, sinon, domainBuilder } = require('../../../../test-helper'); -const sessionsImportValidationService = require('../../../../../lib/domain/services/sessions-mass-import/sessions-import-validation-service'); -const { CpfBirthInformationValidation } = require('../../../../../lib/domain/services/certification-cpf-service'); -const { - CERTIFICATION_CANDIDATES_ERRORS, -} = require('../../../../../lib/domain/constants/certification-candidates-errors'); -const noop = require('lodash/noop'); +import { expect, sinon, domainBuilder } from '../../../../test-helper.js'; +import * as sessionsImportValidationService from '../../../../../lib/domain/services/sessions-mass-import/sessions-import-validation-service.js'; +import { CpfBirthInformationValidation } from '../../../../../lib/domain/services/certification-cpf-service.js'; +import { CERTIFICATION_CANDIDATES_ERRORS } from '../../../../../lib/domain/constants/certification-candidates-errors.js'; +import lodash from 'lodash'; +const { noop } = lodash; describe('Unit | Service | sessions import validation Service', function () { describe('#validateSession', function () { diff --git a/api/tests/unit/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service_test.js b/api/tests/unit/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service_test.js index 71df9b39637..58e07a49607 100644 --- a/api/tests/unit/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service_test.js +++ b/api/tests/unit/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service_test.js @@ -1,7 +1,8 @@ -const { expect } = require('../../../../test-helper'); -const temporarySessionsStorageForMassImportService = require('../../../../../lib/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service'); -const { temporaryStorage } = require('../../../../../lib/infrastructure/temporary-storage'); +import { expect } from '../../../../test-helper.js'; +import * as temporarySessionsStorageForMassImportService from '../../../../../lib/domain/services/sessions-mass-import/temporary-sessions-storage-for-mass-import-service.js'; +import { temporaryStorage } from '../../../../../lib/infrastructure/temporary-storage/index.js'; const sessionMassImportTemporaryStorage = temporaryStorage.withPrefix('sessions-mass-import:'); + describe('Unit | Domain | Services | sessions mass import', function () { describe('#save', function () { it('should save sessions accessible with returned uuid', async function () { @@ -63,7 +64,7 @@ describe('Unit | Domain | Services | sessions mass import', function () { const key = await temporarySessionsStorageForMassImportService.save({ sessions, userId }); // when - await temporarySessionsStorageForMassImportService.delete({ + await temporarySessionsStorageForMassImportService.remove({ cachedValidatedSessionsKey: key, userId, }); diff --git a/api/tests/unit/domain/services/smart-random/data-fetcher_test.js b/api/tests/unit/domain/services/smart-random/data-fetcher_test.js index 2b8b0d52bdf..9a4a523e3e7 100644 --- a/api/tests/unit/domain/services/smart-random/data-fetcher_test.js +++ b/api/tests/unit/domain/services/smart-random/data-fetcher_test.js @@ -1,5 +1,5 @@ -const { sinon, expect, domainBuilder } = require('../../../../test-helper'); -const dataFetcher = require('../../../../../lib/domain/services/algorithm-methods/data-fetcher'); +import { sinon, expect, domainBuilder } from '../../../../test-helper.js'; +import * as dataFetcher from '../../../../../lib/domain/services/algorithm-methods/data-fetcher.js'; describe('Unit | Domain | services | smart-random | dataFetcher', function () { describe('#fetchForCampaigns', function () { diff --git a/api/tests/unit/domain/services/smart-random/skills-filter_test.js b/api/tests/unit/domain/services/smart-random/skills-filter_test.js index dc786b52ad8..5eb47c8a7ac 100644 --- a/api/tests/unit/domain/services/smart-random/skills-filter_test.js +++ b/api/tests/unit/domain/services/smart-random/skills-filter_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const skillsFilter = require('../../../../../lib/domain/services/algorithm-methods/skills-filter'); -const Tube = require('../../../../../lib/domain/models/Tube'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as skillsFilter from '../../../../../lib/domain/services/algorithm-methods/skills-filter.js'; +import { Tube } from '../../../../../lib/domain/models/Tube.js'; const KNOWLEDGE_ELEMENT_STATUS = { VALIDATED: 'validated', diff --git a/api/tests/unit/domain/services/solution-service-qcm_test.js b/api/tests/unit/domain/services/solution-service-qcm_test.js index a03884dadcc..6b557d05b01 100644 --- a/api/tests/unit/domain/services/solution-service-qcm_test.js +++ b/api/tests/unit/domain/services/solution-service-qcm_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const service = require('../../../../lib/domain/services/solution-service-qcm'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); +import { expect } from '../../../test-helper.js'; +import * as service from '../../../../lib/domain/services/solution-service-qcm.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; describe('Unit | Service | SolutionServiceQCM ', function () { describe('if solution type is QCM', function () { diff --git a/api/tests/unit/domain/services/solution-service-qcu_test.js b/api/tests/unit/domain/services/solution-service-qcu_test.js index 2b83dcbac05..23459547d96 100644 --- a/api/tests/unit/domain/services/solution-service-qcu_test.js +++ b/api/tests/unit/domain/services/solution-service-qcu_test.js @@ -1,7 +1,6 @@ -const { expect } = require('../../../test-helper'); - -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const service = require('../../../../lib/domain/services/solution-service-qcu'); +import { expect } from '../../../test-helper.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import * as service from '../../../../lib/domain/services/solution-service-qcu.js'; describe('Unit | Service | SolutionServiceQCU ', function () { describe('if solution type is QCU', function () { diff --git a/api/tests/unit/domain/services/solution-service-qroc_test.js b/api/tests/unit/domain/services/solution-service-qroc_test.js index 22dacaccf06..d4db7806446 100644 --- a/api/tests/unit/domain/services/solution-service-qroc_test.js +++ b/api/tests/unit/domain/services/solution-service-qroc_test.js @@ -1,7 +1,6 @@ -const { expect } = require('../../../test-helper'); - -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const service = require('../../../../lib/domain/services/solution-service-qroc'); +import { expect } from '../../../test-helper.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import * as service from '../../../../lib/domain/services/solution-service-qroc.js'; const ANSWER_KO = AnswerStatus.KO; const ANSWER_OK = AnswerStatus.OK; diff --git a/api/tests/unit/domain/services/solution-service-qrocm-dep_test.js b/api/tests/unit/domain/services/solution-service-qrocm-dep_test.js index 70e77df8df9..d20b195fe6f 100644 --- a/api/tests/unit/domain/services/solution-service-qrocm-dep_test.js +++ b/api/tests/unit/domain/services/solution-service-qrocm-dep_test.js @@ -1,10 +1,8 @@ -const { expect, catchErr, sinon } = require('../../../test-helper'); - -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const service = require('../../../../lib/domain/services/solution-service-qrocm-dep'); - -const { YamlParsingError } = require('../../../../lib/domain/errors'); -const CorrectionBlockQROCMDep = require('../../../../lib/domain/models/CorrectionBlockQROCMDep'); +import { expect, catchErr, sinon } from '../../../test-helper.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import * as service from '../../../../lib/domain/services/solution-service-qrocm-dep.js'; +import { YamlParsingError } from '../../../../lib/domain/errors.js'; +import { CorrectionBlockQROCMDep } from '../../../../lib/domain/models/CorrectionBlockQROCMDep.js'; const ANSWER_PARTIALLY = AnswerStatus.PARTIALLY; const ANSWER_OK = AnswerStatus.OK; diff --git a/api/tests/unit/domain/services/solution-service-qrocm-ind_test.js b/api/tests/unit/domain/services/solution-service-qrocm-ind_test.js index e1c4b3007db..98e00f6646a 100644 --- a/api/tests/unit/domain/services/solution-service-qrocm-ind_test.js +++ b/api/tests/unit/domain/services/solution-service-qrocm-ind_test.js @@ -1,8 +1,7 @@ -const { expect, catchErr } = require('../../../test-helper'); - -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const service = require('../../../../lib/domain/services/solution-service-qrocm-ind'); -const { YamlParsingError } = require('../../../../lib/domain/errors'); +import { expect, catchErr } from '../../../test-helper.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import * as service from '../../../../lib/domain/services/solution-service-qrocm-ind.js'; +import { YamlParsingError } from '../../../../lib/domain/errors.js'; const ANSWER_OK = AnswerStatus.OK; const ANSWER_KO = AnswerStatus.KO; diff --git a/api/tests/unit/domain/services/string-comparison-service_test.js b/api/tests/unit/domain/services/string-comparison-service_test.js index ab637787166..35bc15f85ec 100644 --- a/api/tests/unit/domain/services/string-comparison-service_test.js +++ b/api/tests/unit/domain/services/string-comparison-service_test.js @@ -1,11 +1,12 @@ -const { expect } = require('../../../test-helper'); -const { +import { expect } from '../../../test-helper.js'; + +import { areTwoStringsCloseEnough, getSmallestLevenshteinDistance, getSmallestLevenshteinRatio, getLevenshteinRatio, isOneStringCloseEnoughFromMultipleStrings, -} = require('../../../../lib/domain/services/string-comparison-service'); +} from '../../../../lib/domain/services/string-comparison-service.js'; describe('Unit | Service | Validation Comparison', function () { describe('getSmallestLevenshteinDistance', function () { diff --git a/api/tests/unit/domain/services/token-service_test.js b/api/tests/unit/domain/services/token-service_test.js index 785d2f86dbb..07b9bc598ea 100644 --- a/api/tests/unit/domain/services/token-service_test.js +++ b/api/tests/unit/domain/services/token-service_test.js @@ -1,17 +1,19 @@ -const omit = require('lodash/omit'); -const jsonwebtoken = require('jsonwebtoken'); +import lodash from 'lodash'; +const { omit } = lodash; +import jsonwebtoken from 'jsonwebtoken'; -const { catchErr, expect, sinon } = require('../../../test-helper'); +import { catchErr, expect, sinon } from '../../../test-helper.js'; -const { +import { InvalidTemporaryKeyError, InvalidExternalUserTokenError, InvalidResultRecipientTokenError, InvalidSessionResultError, ForbiddenAccess, -} = require('../../../../lib/domain/errors'); -const settings = require('../../../../lib/config'); -const tokenService = require('../../../../lib/domain/services/token-service'); +} from '../../../../lib/domain/errors.js'; + +import { tokenService } from '../../../../lib/domain/services/token-service.js'; +import { config as settings } from '../../../../lib/config.js'; describe('Unit | Domain | Service | Token Service', function () { describe('#createTokenForCampaignResults', function () { diff --git a/api/tests/unit/domain/services/user-reconciliation-service_test.js b/api/tests/unit/domain/services/user-reconciliation-service_test.js index d02dffc79e4..5ad360b4b26 100644 --- a/api/tests/unit/domain/services/user-reconciliation-service_test.js +++ b/api/tests/unit/domain/services/user-reconciliation-service_test.js @@ -1,11 +1,12 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const userReconciliationService = require('../../../../lib/domain/services/user-reconciliation-service'); -const { +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import * as userReconciliationService from '../../../../lib/domain/services/user-reconciliation-service.js'; + +import { AlreadyRegisteredUsernameError, NotFoundError, OrganizationLearnerAlreadyLinkedToUserError, OrganizationLearnerAlreadyLinkedToInvalidUserError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | Service | user-reconciliation-service', function () { let organizationLearners; diff --git a/api/tests/unit/domain/services/user-service_test.js b/api/tests/unit/domain/services/user-service_test.js index 10ec0be3b77..47033fdd4a2 100644 --- a/api/tests/unit/domain/services/user-service_test.js +++ b/api/tests/unit/domain/services/user-service_test.js @@ -1,10 +1,10 @@ -const omit = require('lodash/omit'); +import lodash from 'lodash'; +const { omit } = lodash; -const { expect, sinon, domainBuilder } = require('../../../test-helper'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); - -const userService = require('../../../../lib/domain/services/user-service'); +import * as userService from '../../../../lib/domain/services/user-service.js'; describe('Unit | Service | user-service', function () { let domainTransaction; diff --git a/api/tests/unit/domain/services/validation-treatments_test.js b/api/tests/unit/domain/services/validation-treatments_test.js index 12d3385efa7..14927d73fb8 100644 --- a/api/tests/unit/domain/services/validation-treatments_test.js +++ b/api/tests/unit/domain/services/validation-treatments_test.js @@ -1,10 +1,11 @@ -const { expect } = require('../../../test-helper'); -const { +import { expect } from '../../../test-helper.js'; + +import { normalizeAndRemoveAccents, removeSpecialCharacters, applyPreTreatments, applyTreatments, -} = require('../../../../lib/domain/services/validation-treatments'); +} from '../../../../lib/domain/services/validation-treatments.js'; describe('Unit | Service | Validation Treatments', function () { describe('#normalizeAndRemoveAccents', function () { diff --git a/api/tests/unit/domain/services/verify-certificate-code-service_test.js b/api/tests/unit/domain/services/verify-certificate-code-service_test.js index 6bb4eee0383..6c63537522a 100644 --- a/api/tests/unit/domain/services/verify-certificate-code-service_test.js +++ b/api/tests/unit/domain/services/verify-certificate-code-service_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const _ = require('lodash'); -const verifyCertificateCodeService = require('../../../../lib/domain/services/verify-certificate-code-service'); -const { CertificateVerificationCodeGenerationTooManyTrials } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import _ from 'lodash'; +import * as verifyCertificateCodeService from '../../../../lib/domain/services/verify-certificate-code-service.js'; +import { CertificateVerificationCodeGenerationTooManyTrials } from '../../../../lib/domain/errors.js'; describe('Unit | Service | VerifyCertificateCode', function () { describe('#generateCertificateVerificationCode', function () { diff --git a/api/tests/unit/domain/types/identifiers-type_test.js b/api/tests/unit/domain/types/identifiers-type_test.js index fc80e89f579..eb9b4942e10 100644 --- a/api/tests/unit/domain/types/identifiers-type_test.js +++ b/api/tests/unit/domain/types/identifiers-type_test.js @@ -1,5 +1,6 @@ -const { expect } = require('../../../test-helper'); -const { userId, competenceId } = require('../../../../lib/domain/types/identifiers-type'); +import { expect } from '../../../test-helper.js'; +import { identifiersType } from '../../../../lib/domain/types/identifiers-type.js'; +const { userId, competenceId } = identifiersType; describe('Unit | Domain | Type | identifier-types', function () { describe('#userId', function () { diff --git a/api/tests/unit/domain/usecases/abort-certification-course_test.js b/api/tests/unit/domain/usecases/abort-certification-course_test.js index fb295c2bc9d..4f6df4560a4 100644 --- a/api/tests/unit/domain/usecases/abort-certification-course_test.js +++ b/api/tests/unit/domain/usecases/abort-certification-course_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const abortCertificationCourse = require('../../../../lib/domain/usecases/abort-certification-course'); -const CertificationCourse = require('../../../../lib/domain/models/CertificationCourse'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { abortCertificationCourse } from '../../../../lib/domain/usecases/abort-certification-course.js'; +import { CertificationCourse } from '../../../../lib/domain/models/CertificationCourse.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | abort-certification-course', function () { let certificationCourseRepository; diff --git a/api/tests/unit/domain/usecases/accept-certification-center-invitation_test.js b/api/tests/unit/domain/usecases/accept-certification-center-invitation_test.js index 6267f9ff958..ce363b39f99 100644 --- a/api/tests/unit/domain/usecases/accept-certification-center-invitation_test.js +++ b/api/tests/unit/domain/usecases/accept-certification-center-invitation_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const acceptCertificationCenterInvitation = require('../../../../lib/domain/usecases/accept-certification-center-invitation'); -const CertificationCenterInvitedUser = require('../../../../lib/domain/models/CertificationCenterInvitedUser'); -const CertificationCenterInvitation = require('../../../../lib/domain/models/CertificationCenterInvitation'); -const { AlreadyExistingMembershipError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { acceptCertificationCenterInvitation } from '../../../../lib/domain/usecases/accept-certification-center-invitation.js'; +import { CertificationCenterInvitedUser } from '../../../../lib/domain/models/CertificationCenterInvitedUser.js'; +import { CertificationCenterInvitation } from '../../../../lib/domain/models/CertificationCenterInvitation.js'; +import { AlreadyExistingMembershipError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | accept-certification-center-invitation', function () { it('should throw an error if user is already member of the certification center', async function () { diff --git a/api/tests/unit/domain/usecases/accept-organization-invitation_test.js b/api/tests/unit/domain/usecases/accept-organization-invitation_test.js index f8a813e6139..425372336cc 100644 --- a/api/tests/unit/domain/usecases/accept-organization-invitation_test.js +++ b/api/tests/unit/domain/usecases/accept-organization-invitation_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const acceptOrganizationInvitation = require('../../../../lib/domain/usecases/accept-organization-invitation'); -const OrganizationInvitedUser = require('../../../../lib/domain/models/OrganizationInvitedUser'); -const { AlreadyExistingMembershipError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { acceptOrganizationInvitation } from '../../../../lib/domain/usecases/accept-organization-invitation.js'; +import { OrganizationInvitedUser } from '../../../../lib/domain/models/OrganizationInvitedUser.js'; +import { AlreadyExistingMembershipError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | accept-organization-invitation', function () { let organizationInvitedUserRepository; diff --git a/api/tests/unit/domain/usecases/accept-pix-certif-terms-of-service_test.js b/api/tests/unit/domain/usecases/accept-pix-certif-terms-of-service_test.js index abead5514d7..4b95e21cd83 100644 --- a/api/tests/unit/domain/usecases/accept-pix-certif-terms-of-service_test.js +++ b/api/tests/unit/domain/usecases/accept-pix-certif-terms-of-service_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const acceptPixCertifTermsOfService = require('../../../../lib/domain/usecases/accept-pix-certif-terms-of-service'); +import { expect, sinon } from '../../../test-helper.js'; +import { acceptPixCertifTermsOfService } from '../../../../lib/domain/usecases/accept-pix-certif-terms-of-service.js'; describe('Unit | UseCase | accept-pix-certif-terms-of-service', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/accept-pix-orga-terms-of-service_test.js b/api/tests/unit/domain/usecases/accept-pix-orga-terms-of-service_test.js index 9365926659b..cda0daa3709 100644 --- a/api/tests/unit/domain/usecases/accept-pix-orga-terms-of-service_test.js +++ b/api/tests/unit/domain/usecases/accept-pix-orga-terms-of-service_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const acceptPixOrgaTermsOfService = require('../../../../lib/domain/usecases/accept-pix-orga-terms-of-service'); +import { expect, sinon } from '../../../test-helper.js'; +import { acceptPixOrgaTermsOfService } from '../../../../lib/domain/usecases/accept-pix-orga-terms-of-service.js'; describe('Unit | UseCase | accept-pix-orga-terms-of-service', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/accept-pix-terms-of-service_test.js b/api/tests/unit/domain/usecases/accept-pix-terms-of-service_test.js index a95dff2927e..4ac66e4957e 100644 --- a/api/tests/unit/domain/usecases/accept-pix-terms-of-service_test.js +++ b/api/tests/unit/domain/usecases/accept-pix-terms-of-service_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const acceptPixLastTermsOfService = require('../../../../lib/domain/usecases/accept-pix-last-terms-of-service'); +import { expect, sinon } from '../../../test-helper.js'; +import { acceptPixLastTermsOfService } from '../../../../lib/domain/usecases/accept-pix-last-terms-of-service.js'; describe('Unit | UseCase | accept-pix-last-terms-of-service', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/account-recovery/get-account-recovery-details_test.js b/api/tests/unit/domain/usecases/account-recovery/get-account-recovery-details_test.js index 1817b0f2ad5..f577f92709a 100644 --- a/api/tests/unit/domain/usecases/account-recovery/get-account-recovery-details_test.js +++ b/api/tests/unit/domain/usecases/account-recovery/get-account-recovery-details_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../../test-helper'); -const getAccountRecoveryDetails = require('../../../../../lib/domain/usecases/account-recovery/get-account-recovery-details'); +import { expect, sinon } from '../../../../test-helper.js'; +import { getAccountRecoveryDetails } from '../../../../../lib/domain/usecases/account-recovery/get-account-recovery-details.js'; describe('Unit | UseCase | get-account-recovery-details', function () { it('should return new email and firstName of account recovery demand', async function () { diff --git a/api/tests/unit/domain/usecases/account-recovery/send-email-for-account-recovery_test.js b/api/tests/unit/domain/usecases/account-recovery/send-email-for-account-recovery_test.js index 132aef8cb50..f656d59fc19 100644 --- a/api/tests/unit/domain/usecases/account-recovery/send-email-for-account-recovery_test.js +++ b/api/tests/unit/domain/usecases/account-recovery/send-email-for-account-recovery_test.js @@ -1,7 +1,7 @@ -const { sinon, expect, catchErr } = require('../../../../test-helper'); -const sendEmailForAccountRecovery = require('../../../../../lib/domain/usecases/account-recovery/send-email-for-account-recovery.js'); -const { AlreadyRegisteredEmailError } = require('../../../../../lib/domain/errors'); -const AccountRecoveryDemand = require('../../../../../lib/domain/models/AccountRecoveryDemand'); +import { sinon, expect, catchErr } from '../../../../test-helper.js'; +import { sendEmailForAccountRecovery } from '../../../../../lib/domain/usecases/account-recovery/send-email-for-account-recovery.js'; +import { AlreadyRegisteredEmailError } from '../../../../../lib/domain/errors.js'; +import { AccountRecoveryDemand } from '../../../../../lib/domain/models/AccountRecoveryDemand.js'; describe('Unit | UseCase | Account-recovery | account-recovery | send-email-for-account-recovery', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/account-recovery/update-user-for-account-recovery_test.js b/api/tests/unit/domain/usecases/account-recovery/update-user-for-account-recovery_test.js index 1958c1fd297..6e723d08e9d 100644 --- a/api/tests/unit/domain/usecases/account-recovery/update-user-for-account-recovery_test.js +++ b/api/tests/unit/domain/usecases/account-recovery/update-user-for-account-recovery_test.js @@ -1,10 +1,9 @@ -const sinon = require('sinon'); -const { expect, domainBuilder } = require('../../../../test-helper'); -const updateUserForAccountRecovery = require('../../../../../lib/domain/usecases/account-recovery/update-user-for-account-recovery'); -const AuthenticationMethod = require('../../../../../lib/domain/models/AuthenticationMethod'); -const DomainTransaction = require('../../../../../lib/infrastructure/DomainTransaction'); - -const User = require('../../../../../lib/domain/models/User'); +import sinon from 'sinon'; +import { expect, domainBuilder } from '../../../../test-helper.js'; +import { updateUserForAccountRecovery } from '../../../../../lib/domain/usecases/account-recovery/update-user-for-account-recovery.js'; +import { AuthenticationMethod } from '../../../../../lib/domain/models/AuthenticationMethod.js'; +import { DomainTransaction } from '../../../../../lib/infrastructure/DomainTransaction.js'; +import { User } from '../../../../../lib/domain/models/User.js'; describe('Unit | Usecases | update-user-for-account-recovery', function () { let userRepository, diff --git a/api/tests/unit/domain/usecases/add-certification-candidate-to-session_test.js b/api/tests/unit/domain/usecases/add-certification-candidate-to-session_test.js index f88d08a397f..a46e534dd12 100644 --- a/api/tests/unit/domain/usecases/add-certification-candidate-to-session_test.js +++ b/api/tests/unit/domain/usecases/add-certification-candidate-to-session_test.js @@ -1,12 +1,13 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const addCertificationCandidateToSession = require('../../../../lib/domain/usecases/add-certification-candidate-to-session'); -const { CpfBirthInformationValidation } = require('../../../../lib/domain/services/certification-cpf-service'); -const { +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { addCertificationCandidateToSession } from '../../../../lib/domain/usecases/add-certification-candidate-to-session.js'; +import { CpfBirthInformationValidation } from '../../../../lib/domain/services/certification-cpf-service.js'; + +import { CertificationCandidateByPersonalInfoTooManyMatchesError, CpfBirthInformationValidationError, CertificationCandidateAddError, CertificationCandidateOnFinalizedSessionError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | add-certification-candidate-to-session', function () { let certificationCandidateRepository; diff --git a/api/tests/unit/domain/usecases/add-pix-authentication-method-by-email_test.js b/api/tests/unit/domain/usecases/add-pix-authentication-method-by-email_test.js index 878fcbf1259..397ec675cee 100644 --- a/api/tests/unit/domain/usecases/add-pix-authentication-method-by-email_test.js +++ b/api/tests/unit/domain/usecases/add-pix-authentication-method-by-email_test.js @@ -1,6 +1,6 @@ -const { domainBuilder, expect, sinon } = require('../../../test-helper'); -const addPixAuthenticationMethodByEmail = require('../../../../lib/domain/usecases/add-pix-authentication-method-by-email'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); +import { domainBuilder, expect, sinon } from '../../../test-helper.js'; +import { addPixAuthenticationMethodByEmail } from '../../../../lib/domain/usecases/add-pix-authentication-method-by-email.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; describe('Unit | UseCase | add-pix-authentication-method-by-email', function () { let userRepository, authenticationMethodRepository; diff --git a/api/tests/unit/domain/usecases/add-tutorial-evaluation_test.js b/api/tests/unit/domain/usecases/add-tutorial-evaluation_test.js index 4498f524882..965fda1f7da 100644 --- a/api/tests/unit/domain/usecases/add-tutorial-evaluation_test.js +++ b/api/tests/unit/domain/usecases/add-tutorial-evaluation_test.js @@ -1,7 +1,7 @@ -const { sinon, expect, domainBuilder, catchErr } = require('../../../test-helper'); -const addTutorialEvaluation = require('../../../../lib/domain/usecases/add-tutorial-evaluation'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const TutorialEvaluation = require('../../../../lib/domain/models/TutorialEvaluation'); +import { sinon, expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { addTutorialEvaluation } from '../../../../lib/domain/usecases/add-tutorial-evaluation.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { TutorialEvaluation } from '../../../../lib/domain/models/TutorialEvaluation.js'; describe('Unit | UseCase | add-tutorial-evaluation', function () { let tutorialRepository; diff --git a/api/tests/unit/domain/usecases/add-tutorial-to-user_test.js b/api/tests/unit/domain/usecases/add-tutorial-to-user_test.js index b725ed24ef3..11d23699876 100644 --- a/api/tests/unit/domain/usecases/add-tutorial-to-user_test.js +++ b/api/tests/unit/domain/usecases/add-tutorial-to-user_test.js @@ -1,6 +1,6 @@ -const { sinon, expect, domainBuilder, catchErr } = require('../../../test-helper'); -const addTutorialToUser = require('../../../../lib/domain/usecases/add-tutorial-to-user'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { sinon, expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { addTutorialToUser } from '../../../../lib/domain/usecases/add-tutorial-to-user.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | add-tutorial-to-user', function () { let tutorialRepository; diff --git a/api/tests/unit/domain/usecases/anonymize-user_test.js b/api/tests/unit/domain/usecases/anonymize-user_test.js index 09f4a20d402..5d9b6ac6014 100644 --- a/api/tests/unit/domain/usecases/anonymize-user_test.js +++ b/api/tests/unit/domain/usecases/anonymize-user_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const anonymizeUser = require('../../../../lib/domain/usecases/anonymize-user'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); +import { expect, sinon } from '../../../test-helper.js'; +import { anonymizeUser } from '../../../../lib/domain/usecases/anonymize-user.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; describe('Unit | UseCase | anonymize-user', function () { let clock; diff --git a/api/tests/unit/domain/usecases/archive-campaign-from-campaign-code_test.js b/api/tests/unit/domain/usecases/archive-campaign-from-campaign-code_test.js index 2e54d291333..fc0dee8ed30 100644 --- a/api/tests/unit/domain/usecases/archive-campaign-from-campaign-code_test.js +++ b/api/tests/unit/domain/usecases/archive-campaign-from-campaign-code_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const archiveCampaignFromCampaignCode = require('../../../../lib/domain/usecases/archive-campaign-from-campaign-code'); -const Campaign = require('../../../../lib/domain/models/CampaignForArchiving'); +import { expect, sinon } from '../../../test-helper.js'; +import { archiveCampaignFromCampaignCode } from '../../../../lib/domain/usecases/archive-campaign-from-campaign-code.js'; +import { CampaignForArchiving as Campaign } from '../../../../lib/domain/models/CampaignForArchiving.js'; describe('Unit | UseCase | archive-campaign', function () { let campaignForArchivingRepository; diff --git a/api/tests/unit/domain/usecases/archive-campaign_test.js b/api/tests/unit/domain/usecases/archive-campaign_test.js index 6da00597531..dbd5aef6238 100644 --- a/api/tests/unit/domain/usecases/archive-campaign_test.js +++ b/api/tests/unit/domain/usecases/archive-campaign_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const Campaign = require('../../../../lib/domain/models/CampaignForArchiving'); -const archiveCampaign = require('../../../../lib/domain/usecases/archive-campaign'); +import { expect, sinon } from '../../../test-helper.js'; +import { CampaignForArchiving as Campaign } from '../../../../lib/domain/models/CampaignForArchiving.js'; +import { archiveCampaign } from '../../../../lib/domain/usecases/archive-campaign.js'; describe('Unit | UseCase | archive-campaign', function () { let clock; diff --git a/api/tests/unit/domain/usecases/archive-organization_test.js b/api/tests/unit/domain/usecases/archive-organization_test.js index 912e95b02da..d93d3518a62 100644 --- a/api/tests/unit/domain/usecases/archive-organization_test.js +++ b/api/tests/unit/domain/usecases/archive-organization_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const archiveOrganization = require('../../../../lib/domain/usecases/archive-organization'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { archiveOrganization } from '../../../../lib/domain/usecases/archive-organization.js'; describe('Unit | UseCase | archive-organization', function () { it('should archive the organization', async function () { diff --git a/api/tests/unit/domain/usecases/assign-certification-officer-to-session_test.js b/api/tests/unit/domain/usecases/assign-certification-officer-to-session_test.js index 4360cd4ef15..5f5060f959a 100644 --- a/api/tests/unit/domain/usecases/assign-certification-officer-to-session_test.js +++ b/api/tests/unit/domain/usecases/assign-certification-officer-to-session_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const assignCertificationOfficerToJurySession = require('../../../../lib/domain/usecases/assign-certification-officer-to-jury-session'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { assignCertificationOfficerToJurySession } from '../../../../lib/domain/usecases/assign-certification-officer-to-jury-session.js'; describe('Unit | UseCase | assign-certification-officer-to-session', function () { it('should return the session id after assigningUser to it', async function () { diff --git a/api/tests/unit/domain/usecases/attach-target-profiles-to-organization_test.js b/api/tests/unit/domain/usecases/attach-target-profiles-to-organization_test.js index 58d30d19b32..1728d119114 100644 --- a/api/tests/unit/domain/usecases/attach-target-profiles-to-organization_test.js +++ b/api/tests/unit/domain/usecases/attach-target-profiles-to-organization_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const attachTargetProfilesToOrganization = require('../../../../lib/domain/usecases/attach-target-profiles-to-organization'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { attachTargetProfilesToOrganization } from '../../../../lib/domain/usecases/attach-target-profiles-to-organization.js'; describe('Unit | UseCase | attach-target-profiles-to-organization', function () { let targetProfileRepository; diff --git a/api/tests/unit/domain/usecases/attach-target-profiles-to-training_test.js b/api/tests/unit/domain/usecases/attach-target-profiles-to-training_test.js index f3993eee1ca..91ad65c1c22 100644 --- a/api/tests/unit/domain/usecases/attach-target-profiles-to-training_test.js +++ b/api/tests/unit/domain/usecases/attach-target-profiles-to-training_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const attachTargetProfilesToTraining = require('../../../../lib/domain/usecases/attach-target-profiles-to-training'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { attachTargetProfilesToTraining } from '../../../../lib/domain/usecases/attach-target-profiles-to-training.js'; describe('Unit | UseCase | attach-target-profiles-to-training', function () { let targetProfileRepository; diff --git a/api/tests/unit/domain/usecases/authenticate-anonymous-user_test.js b/api/tests/unit/domain/usecases/authenticate-anonymous-user_test.js index 1c7c9a4d032..b3019bed4ce 100644 --- a/api/tests/unit/domain/usecases/authenticate-anonymous-user_test.js +++ b/api/tests/unit/domain/usecases/authenticate-anonymous-user_test.js @@ -1,7 +1,6 @@ -const { catchErr, expect, sinon } = require('../../../test-helper'); -const { UserCantBeCreatedError } = require('../../../../lib/domain/errors'); - -const authenticateAnonymousUser = require('../../../../lib/domain/usecases/authenticate-anonymous-user'); +import { catchErr, expect, sinon } from '../../../test-helper.js'; +import { UserCantBeCreatedError } from '../../../../lib/domain/errors.js'; +import { authenticateAnonymousUser } from '../../../../lib/domain/usecases/authenticate-anonymous-user.js'; describe('Unit | UseCase | authenticate-anonymous-user', function () { let campaignCode; diff --git a/api/tests/unit/domain/usecases/authenticate-external-user_test.js b/api/tests/unit/domain/usecases/authenticate-external-user_test.js index 39d8bd360b9..8694278f609 100644 --- a/api/tests/unit/domain/usecases/authenticate-external-user_test.js +++ b/api/tests/unit/domain/usecases/authenticate-external-user_test.js @@ -1,16 +1,16 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { authenticateExternalUser } from '../../../../lib/domain/usecases/authenticate-external-user.js'; -const authenticateExternalUser = require('../../../../lib/domain/usecases/authenticate-external-user'); - -const { +import { MissingOrInvalidCredentialsError, UserNotFoundError, PasswordNotMatching, UnexpectedUserAccountError, UserShouldChangePasswordError, UserAlreadyExistsWithAuthenticationMethodError, -} = require('../../../../lib/domain/errors'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); +} from '../../../../lib/domain/errors.js'; + +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; describe('Unit | Application | UseCase | authenticate-external-user', function () { let tokenService; diff --git a/api/tests/unit/domain/usecases/authenticate-user_test.js b/api/tests/unit/domain/usecases/authenticate-user_test.js index 29d98a89dd0..38be4e44c18 100644 --- a/api/tests/unit/domain/usecases/authenticate-user_test.js +++ b/api/tests/unit/domain/usecases/authenticate-user_test.js @@ -1,17 +1,16 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { authenticateUser } from '../../../../lib/domain/usecases/authenticate-user.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { AdminMember } from '../../../../lib/domain/models/AdminMember.js'; -const authenticateUser = require('../../../../lib/domain/usecases/authenticate-user'); -const User = require('../../../../lib/domain/models/User'); -const AdminMember = require('../../../../lib/domain/models/AdminMember'); - -const { +import { UserNotFoundError, MissingOrInvalidCredentialsError, ForbiddenAccess, UserShouldChangePasswordError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; -const appMessages = require('../../../../lib/domain/constants'); +import * as appMessages from '../../../../lib/domain/constants.js'; describe('Unit | Application | UseCase | authenticate-user', function () { let refreshTokenService; diff --git a/api/tests/unit/domain/usecases/authentication/authenticate-oidc-user_test.js b/api/tests/unit/domain/usecases/authentication/authenticate-oidc-user_test.js index 51cf280416c..53f9c063312 100644 --- a/api/tests/unit/domain/usecases/authentication/authenticate-oidc-user_test.js +++ b/api/tests/unit/domain/usecases/authentication/authenticate-oidc-user_test.js @@ -1,11 +1,10 @@ -const { expect, sinon, catchErr } = require('../../../../test-helper'); -const { UnexpectedOidcStateError } = require('../../../../../lib/domain/errors'); -const logger = require('../../../../../lib/infrastructure/logger'); - -const authenticateOidcUser = require('../../../../../lib/domain/usecases/authentication/authenticate-oidc-user'); -const AuthenticationSessionContent = require('../../../../../lib/domain/models/AuthenticationSessionContent'); -const AuthenticationMethod = require('../../../../../lib/domain/models/AuthenticationMethod'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); +import { expect, sinon, catchErr } from '../../../../test-helper.js'; +import { UnexpectedOidcStateError } from '../../../../../lib/domain/errors.js'; +import { logger } from '../../../../../lib/infrastructure/logger.js'; +import { authenticateOidcUser } from '../../../../../lib/domain/usecases/authentication/authenticate-oidc-user.js'; +import { AuthenticationSessionContent } from '../../../../../lib/domain/models/AuthenticationSessionContent.js'; +import { AuthenticationMethod } from '../../../../../lib/domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; describe('Unit | UseCase | authenticate-oidc-user', function () { let oidcAuthenticationService; diff --git a/api/tests/unit/domain/usecases/authorize-certification-candidate-to-resume_test.js b/api/tests/unit/domain/usecases/authorize-certification-candidate-to-resume_test.js index e8cc27f51f6..3067a313938 100644 --- a/api/tests/unit/domain/usecases/authorize-certification-candidate-to-resume_test.js +++ b/api/tests/unit/domain/usecases/authorize-certification-candidate-to-resume_test.js @@ -1,5 +1,5 @@ -const { domainBuilder, expect, sinon } = require('../../../test-helper'); -const authorizeCertificationCandidateToResume = require('../../../../lib/domain/usecases/authorize-certification-candidate-to-resume'); +import { domainBuilder, expect, sinon } from '../../../test-helper.js'; +import { authorizeCertificationCandidateToResume } from '../../../../lib/domain/usecases/authorize-certification-candidate-to-resume.js'; describe('Unit | Domain | Use Cases | authorize-certification-candidate-to-resume', function () { let certificationCandidateForSupervisingRepository; diff --git a/api/tests/unit/domain/usecases/authorize-certification-candidate-to-start_test.js b/api/tests/unit/domain/usecases/authorize-certification-candidate-to-start_test.js index 81b866e7148..2dbfa4943a4 100644 --- a/api/tests/unit/domain/usecases/authorize-certification-candidate-to-start_test.js +++ b/api/tests/unit/domain/usecases/authorize-certification-candidate-to-start_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const authorizeCertificationCandidateToStart = require('../../../../lib/domain/usecases/authorize-certification-candidate-to-start'); -const CertificationCandidateForSupervising = require('../../../../lib/domain/models/CertificationCandidateForSupervising'); +import { expect, sinon } from '../../../test-helper.js'; +import { authorizeCertificationCandidateToStart } from '../../../../lib/domain/usecases/authorize-certification-candidate-to-start.js'; +import { CertificationCandidateForSupervising } from '../../../../lib/domain/models/CertificationCandidateForSupervising.js'; describe('Unit | Domain | Use Cases | authorize-certification-candidate-to-start', function () { let certificationCandidateForSupervisingRepository; diff --git a/api/tests/unit/domain/usecases/begin-campaign-participation-improvement_test.js b/api/tests/unit/domain/usecases/begin-campaign-participation-improvement_test.js index 405be3246b5..3343cf83939 100644 --- a/api/tests/unit/domain/usecases/begin-campaign-participation-improvement_test.js +++ b/api/tests/unit/domain/usecases/begin-campaign-participation-improvement_test.js @@ -1,12 +1,15 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { beginCampaignParticipationImprovement } = require('../../../../lib/domain/usecases/index.js'); -const { +import { AlreadySharedCampaignParticipationError, UserNotAuthorizedToAccessEntityError, -} = require('../../../../lib/domain/errors'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +} from '../../../../lib/domain/errors.js'; + +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; + +const { beginCampaignParticipationImprovement } = usecases; describe('Unit | Usecase | begin-campaign-participation-improvement', function () { let dependencies; diff --git a/api/tests/unit/domain/usecases/campaigns-administration/archive-campaigns_test.js b/api/tests/unit/domain/usecases/campaigns-administration/archive-campaigns_test.js index 1e07a0ece9f..1d55a360ab8 100644 --- a/api/tests/unit/domain/usecases/campaigns-administration/archive-campaigns_test.js +++ b/api/tests/unit/domain/usecases/campaigns-administration/archive-campaigns_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../../test-helper'); -const archiveCampaigns = require('../../../../../lib/domain/usecases/campaigns-administration/archive-campaigns'); +import { expect, sinon } from '../../../../test-helper.js'; +import { archiveCampaigns } from '../../../../../lib/domain/usecases/campaigns-administration/archive-campaigns.js'; describe('Unit | UseCase | archive-campaign', function () { let campaignAdministrationRepository; diff --git a/api/tests/unit/domain/usecases/cancel-certification-course_test.js b/api/tests/unit/domain/usecases/cancel-certification-course_test.js index 6200a0cea5c..f8c837fdc14 100644 --- a/api/tests/unit/domain/usecases/cancel-certification-course_test.js +++ b/api/tests/unit/domain/usecases/cancel-certification-course_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const cancelCertificationCourse = require('../../../../lib/domain/usecases/cancel-certification-course'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { cancelCertificationCourse } from '../../../../lib/domain/usecases/cancel-certification-course.js'; describe('Unit | UseCase | cancel-certification-course', function () { it('should cancel the certification course', async function () { diff --git a/api/tests/unit/domain/usecases/cancel-organization-invitation_test.js b/api/tests/unit/domain/usecases/cancel-organization-invitation_test.js index b501f9890dd..1135abd5c4c 100644 --- a/api/tests/unit/domain/usecases/cancel-organization-invitation_test.js +++ b/api/tests/unit/domain/usecases/cancel-organization-invitation_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { NotFoundError, UncancellableOrganizationInvitationError } = require('../../../../lib/domain/errors'); -const cancelOrganizationInvitation = require('../../../../lib/domain/usecases/cancel-organization-invitation'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { NotFoundError, UncancellableOrganizationInvitationError } from '../../../../lib/domain/errors.js'; +import { cancelOrganizationInvitation } from '../../../../lib/domain/usecases/cancel-organization-invitation.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; describe('Unit | UseCase | cancel-organization-invitation', function () { let organizationInvitationRepository; diff --git a/api/tests/unit/domain/usecases/change-user-lang_test.js b/api/tests/unit/domain/usecases/change-user-lang_test.js index 92b5f3b3e6c..a1707c84164 100644 --- a/api/tests/unit/domain/usecases/change-user-lang_test.js +++ b/api/tests/unit/domain/usecases/change-user-lang_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const changeUserLang = require('../../../../lib/domain/usecases/change-user-lang'); +import { expect, sinon } from '../../../test-helper.js'; +import { changeUserLang } from '../../../../lib/domain/usecases/change-user-lang.js'; describe('Unit | UseCase | change-user-lang', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/check-sco-account-recovery_test.js b/api/tests/unit/domain/usecases/check-sco-account-recovery_test.js index b16c6fbc646..813acdc8660 100644 --- a/api/tests/unit/domain/usecases/check-sco-account-recovery_test.js +++ b/api/tests/unit/domain/usecases/check-sco-account-recovery_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const StudentInformationForAccountRecovery = require('../../../../lib/domain/read-models/StudentInformationForAccountRecovery'); -const checkScoAccountRecovery = require('../../../../lib/domain/usecases/check-sco-account-recovery'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { StudentInformationForAccountRecovery } from '../../../../lib/domain/read-models/StudentInformationForAccountRecovery.js'; +import { checkScoAccountRecovery } from '../../../../lib/domain/usecases/check-sco-account-recovery.js'; describe('Unit | UseCase | check-sco-account-recovery', function () { let organizationLearnerRepository; diff --git a/api/tests/unit/domain/usecases/comment-session-as-jury_test.js b/api/tests/unit/domain/usecases/comment-session-as-jury_test.js index b97b2a999c6..7a443fea486 100644 --- a/api/tests/unit/domain/usecases/comment-session-as-jury_test.js +++ b/api/tests/unit/domain/usecases/comment-session-as-jury_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const commentSessionAsJury = require('../../../../lib/domain/usecases/comment-session-as-jury'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { commentSessionAsJury } from '../../../../lib/domain/usecases/comment-session-as-jury.js'; describe('Unit | UseCase | comment-session-as-jury', function () { const sessionJuryCommentRepository = { get: null, save: null }; diff --git a/api/tests/unit/domain/usecases/complete-assessment_test.js b/api/tests/unit/domain/usecases/complete-assessment_test.js index 9beaa4b3fec..04698291a85 100644 --- a/api/tests/unit/domain/usecases/complete-assessment_test.js +++ b/api/tests/unit/domain/usecases/complete-assessment_test.js @@ -1,10 +1,10 @@ -const _ = require('lodash'); -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const completeAssessment = require('../../../../lib/domain/usecases/complete-assessment'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { AlreadyRatedAssessmentError } = require('../../../../lib/domain/errors'); -const AssessmentCompleted = require('../../../../lib/domain/events/AssessmentCompleted'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); +import _ from 'lodash'; +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { completeAssessment } from '../../../../lib/domain/usecases/complete-assessment.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { AlreadyRatedAssessmentError } from '../../../../lib/domain/errors.js'; +import { AssessmentCompleted } from '../../../../lib/domain/events/AssessmentCompleted.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; describe('Unit | UseCase | complete-assessment', function () { let assessmentRepository; diff --git a/api/tests/unit/domain/usecases/compute-campaign-analysis_test.js b/api/tests/unit/domain/usecases/compute-campaign-analysis_test.js index a442c16ef7d..787b28852ad 100644 --- a/api/tests/unit/domain/usecases/compute-campaign-analysis_test.js +++ b/api/tests/unit/domain/usecases/compute-campaign-analysis_test.js @@ -1,7 +1,10 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { computeCampaignAnalysis } = require('../../../../lib/domain/usecases/index.js'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_SPOKEN } = LOCALE; +const { computeCampaignAnalysis } = usecases; describe('Unit | UseCase | compute-campaign-analysis', function () { let campaignRepository; diff --git a/api/tests/unit/domain/usecases/compute-campaign-collective-result_test.js b/api/tests/unit/domain/usecases/compute-campaign-collective-result_test.js index c1e3619a92c..5891f2094cf 100644 --- a/api/tests/unit/domain/usecases/compute-campaign-collective-result_test.js +++ b/api/tests/unit/domain/usecases/compute-campaign-collective-result_test.js @@ -1,6 +1,8 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { computeCampaignCollectiveResult } = require('../../../../lib/domain/usecases/index.js'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; + +const { computeCampaignCollectiveResult } = usecases; describe('Unit | UseCase | compute-campaign-collective-result', function () { const userId = 1; diff --git a/api/tests/unit/domain/usecases/compute-campaign-participation-analysis_test.js b/api/tests/unit/domain/usecases/compute-campaign-participation-analysis_test.js index e236c3143b6..9ce97f64d35 100644 --- a/api/tests/unit/domain/usecases/compute-campaign-participation-analysis_test.js +++ b/api/tests/unit/domain/usecases/compute-campaign-participation-analysis_test.js @@ -1,11 +1,14 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { computeCampaignParticipationAnalysis } = require('../../../../lib/domain/usecases/index.js'); -const { +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { UserNotAuthorizedToAccessEntityError, CampaignParticipationDeletedError, -} = require('../../../../lib/domain/errors'); -const CampaignParticipationStatuses = require('../../../../lib/domain/models/CampaignParticipationStatuses'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +} from '../../../../lib/domain/errors.js'; +import { CampaignParticipationStatuses } from '../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { computeCampaignParticipationAnalysis } = usecases; +const { FRENCH_SPOKEN } = LOCALE; const { TO_SHARE } = CampaignParticipationStatuses; diff --git a/api/tests/unit/domain/usecases/correct-answer-then-update-assessment_test.js b/api/tests/unit/domain/usecases/correct-answer-then-update-assessment_test.js index 1f3739c6b69..ac7a5a8e8b3 100644 --- a/api/tests/unit/domain/usecases/correct-answer-then-update-assessment_test.js +++ b/api/tests/unit/domain/usecases/correct-answer-then-update-assessment_test.js @@ -1,17 +1,16 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { correctAnswerThenUpdateAssessment } from '../../../../lib/domain/usecases/correct-answer-then-update-assessment.js'; -const Assessment = require('../../../../lib/domain/models/Assessment'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const correctAnswerThenUpdateAssessment = require('../../../../lib/domain/usecases/correct-answer-then-update-assessment'); - -const { +import { ChallengeNotAskedError, NotFoundError, ForbiddenAccess, CertificationEndedBySupervisorError, CertificationEndedByFinalizationError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Use Cases | correct-answer-then-update-assessment', function () { const userId = 1; diff --git a/api/tests/unit/domain/usecases/correct-candidate-identity-in-certification-course_test.js b/api/tests/unit/domain/usecases/correct-candidate-identity-in-certification-course_test.js index d8664d4e978..cc7d716ccff 100644 --- a/api/tests/unit/domain/usecases/correct-candidate-identity-in-certification-course_test.js +++ b/api/tests/unit/domain/usecases/correct-candidate-identity-in-certification-course_test.js @@ -1,9 +1,8 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const CertificationCourse = require('../../../../lib/domain/models/CertificationCourse'); - -const correctCandidateIdentityInCertificationCourse = require('../../../../lib/domain/usecases/correct-candidate-identity-in-certification-course'); -const { CpfBirthInformationValidation } = require('../../../../lib/domain/services/certification-cpf-service'); -const { CpfBirthInformationValidationError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { CertificationCourse } from '../../../../lib/domain/models/CertificationCourse.js'; +import { correctCandidateIdentityInCertificationCourse } from '../../../../lib/domain/usecases/correct-candidate-identity-in-certification-course.js'; +import { CpfBirthInformationValidation } from '../../../../lib/domain/services/certification-cpf-service.js'; +import { CpfBirthInformationValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | correct-candidate-identity-in-certification-course', function () { let certificationCourseRepository; diff --git a/api/tests/unit/domain/usecases/create-access-token-from-refresh-token_test.js b/api/tests/unit/domain/usecases/create-access-token-from-refresh-token_test.js index 8acaa6ac805..fedbd9f8d84 100644 --- a/api/tests/unit/domain/usecases/create-access-token-from-refresh-token_test.js +++ b/api/tests/unit/domain/usecases/create-access-token-from-refresh-token_test.js @@ -1,5 +1,5 @@ -const createAccessTokenFromRefreshToken = require('../../../../lib/domain/usecases/create-access-token-from-refresh-token'); -const { expect, sinon } = require('../../../test-helper'); +import { createAccessTokenFromRefreshToken } from '../../../../lib/domain/usecases/create-access-token-from-refresh-token.js'; +import { expect, sinon } from '../../../test-helper.js'; describe('Unit | UseCase | create-access-token-from-refresh-token', function () { context('when refresh token is provided', function () { diff --git a/api/tests/unit/domain/usecases/create-and-reconcile-user-to-organization-learner_test.js b/api/tests/unit/domain/usecases/create-and-reconcile-user-to-organization-learner_test.js index 2a1cf390094..f7709e55662 100644 --- a/api/tests/unit/domain/usecases/create-and-reconcile-user-to-organization-learner_test.js +++ b/api/tests/unit/domain/usecases/create-and-reconcile-user-to-organization-learner_test.js @@ -1,15 +1,15 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; -const { +import { AlreadyRegisteredEmailError, AlreadyRegisteredUsernameError, CampaignCodeError, EntityValidationError, OrganizationLearnerAlreadyLinkedToUserError, NotFoundError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | create-and-reconcile-user-to-organization-learner', function () { const organizationId = 1; diff --git a/api/tests/unit/domain/usecases/create-campaign_test.js b/api/tests/unit/domain/usecases/create-campaign_test.js index c5ea2e0de42..440b76f2503 100644 --- a/api/tests/unit/domain/usecases/create-campaign_test.js +++ b/api/tests/unit/domain/usecases/create-campaign_test.js @@ -1,8 +1,8 @@ -const { expect, sinon } = require('../../../test-helper'); -const createCampaign = require('../../../../lib/domain/usecases/create-campaign'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); -const CampaignCreator = require('../../../../lib/domain/models/CampaignCreator'); -const CampaignForCreation = require('../../../../lib/domain/models/CampaignForCreation'); +import { expect, sinon } from '../../../test-helper.js'; +import { createCampaign } from '../../../../lib/domain/usecases/create-campaign.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; +import { CampaignCreator } from '../../../../lib/domain/models/CampaignCreator.js'; +import { CampaignForCreation } from '../../../../lib/domain/models/CampaignForCreation.js'; describe('Unit | UseCase | create-campaign', function () { let campaignRepository; diff --git a/api/tests/unit/domain/usecases/create-certification-center-membership-by-email_test.js b/api/tests/unit/domain/usecases/create-certification-center-membership-by-email_test.js index dc6315c7d80..01765068c41 100644 --- a/api/tests/unit/domain/usecases/create-certification-center-membership-by-email_test.js +++ b/api/tests/unit/domain/usecases/create-certification-center-membership-by-email_test.js @@ -1,8 +1,6 @@ -const { catchErr, expect, sinon } = require('../../../test-helper'); - -const { AlreadyExistingEntityError, UserNotFoundError } = require('../../../../lib/domain/errors'); - -const createCertificationCenterMembershipByEmail = require('../../../../lib/domain/usecases/create-certification-center-membership-by-email'); +import { catchErr, expect, sinon } from '../../../test-helper.js'; +import { AlreadyExistingEntityError, UserNotFoundError } from '../../../../lib/domain/errors.js'; +import { createCertificationCenterMembershipByEmail } from '../../../../lib/domain/usecases/create-certification-center-membership-by-email.js'; describe('Unit | UseCase | create-certification-center-membership-by-email', function () { const certificationCenterId = 1; diff --git a/api/tests/unit/domain/usecases/create-certification-center-membership-for-sco-organization-member_test.js b/api/tests/unit/domain/usecases/create-certification-center-membership-for-sco-organization-member_test.js index 52470720151..df4d7c9dd22 100644 --- a/api/tests/unit/domain/usecases/create-certification-center-membership-for-sco-organization-member_test.js +++ b/api/tests/unit/domain/usecases/create-certification-center-membership-for-sco-organization-member_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const { - createCertificationCenterMembershipForScoOrganizationMember, -} = require('../../../../lib/domain/usecases/index.js'); -const Membership = require('../../../../lib/domain/models/Membership'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; + +const { createCertificationCenterMembershipForScoOrganizationMember } = usecases; describe('Unit | UseCase | create-certification-center-membership-for-sco-organization-member', function () { let membershipRepository; diff --git a/api/tests/unit/domain/usecases/create-certification-center_test.js b/api/tests/unit/domain/usecases/create-certification-center_test.js index edfca15b17b..b28e4cfeafa 100644 --- a/api/tests/unit/domain/usecases/create-certification-center_test.js +++ b/api/tests/unit/domain/usecases/create-certification-center_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const createCertificationCenter = require('../../../../lib/domain/usecases/create-certification-center'); -const DataProtectionOfficer = require('../../../../lib/domain/models/DataProtectionOfficer'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { createCertificationCenter } from '../../../../lib/domain/usecases/create-certification-center.js'; +import { DataProtectionOfficer } from '../../../../lib/domain/models/DataProtectionOfficer.js'; describe('Unit | UseCase | create-certification-center', function () { describe('#createCertificationCenter', function () { diff --git a/api/tests/unit/domain/usecases/create-lcms-release_test.js b/api/tests/unit/domain/usecases/create-lcms-release_test.js index 607e19ab674..a2786b0acfd 100644 --- a/api/tests/unit/domain/usecases/create-lcms-release_test.js +++ b/api/tests/unit/domain/usecases/create-lcms-release_test.js @@ -1,7 +1,7 @@ -const { expect, sinon } = require('../../../test-helper'); -const lcms = require('../../../../lib/infrastructure/lcms'); -const { learningContentCache } = require('../../../../lib/infrastructure/caches/learning-content-cache'); -const createLcmsRelease = require('../../../../lib/domain/usecases/create-lcms-release'); +import { expect, sinon } from '../../../test-helper.js'; +import { lcms } from '../../../../lib/infrastructure/lcms.js'; +import { learningContentCache } from '../../../../lib/infrastructure/caches/learning-content-cache.js'; +import { createLcmsRelease } from '../../../../lib/domain/usecases/create-lcms-release.js'; describe('Unit | UseCase | create-lcms-release', function () { it('call the createRelease on the lcms module', async function () { diff --git a/api/tests/unit/domain/usecases/create-membership_test.js b/api/tests/unit/domain/usecases/create-membership_test.js index 8e7f2cae1f9..2abe85f4956 100644 --- a/api/tests/unit/domain/usecases/create-membership_test.js +++ b/api/tests/unit/domain/usecases/create-membership_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const createMembership = require('../../../../lib/domain/usecases/create-membership'); -const Membership = require('../../../../lib/domain/models/Membership'); -const { OrganizationArchivedError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { createMembership } from '../../../../lib/domain/usecases/create-membership.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { OrganizationArchivedError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | create-membership', function () { it('should insert a new membership with role ADMIN', async function () { diff --git a/api/tests/unit/domain/usecases/create-oidc-user_test.js b/api/tests/unit/domain/usecases/create-oidc-user_test.js index 283dbbceb41..1cbd95a14a5 100644 --- a/api/tests/unit/domain/usecases/create-oidc-user_test.js +++ b/api/tests/unit/domain/usecases/create-oidc-user_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const { +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { AuthenticationKeyExpired, UserAlreadyExistsWithAuthenticationMethodError, -} = require('../../../../lib/domain/errors'); -const createOidcUser = require('../../../../lib/domain/usecases/create-oidc-user'); +} from '../../../../lib/domain/errors.js'; +import { createOidcUser } from '../../../../lib/domain/usecases/create-oidc-user.js'; describe('Unit | UseCase | create-oidc-user', function () { let authenticationMethodRepository, userToCreateRepository, userRepository; diff --git a/api/tests/unit/domain/usecases/create-or-update-training-trigger_test.js b/api/tests/unit/domain/usecases/create-or-update-training-trigger_test.js index f34e9831bfc..5be72d76ee2 100644 --- a/api/tests/unit/domain/usecases/create-or-update-training-trigger_test.js +++ b/api/tests/unit/domain/usecases/create-or-update-training-trigger_test.js @@ -1,5 +1,5 @@ -const createOrUpdateTrainingTrigger = require('../../../../lib/domain/usecases/create-or-update-training-trigger'); -const { expect, catchErr, sinon } = require('../../../test-helper'); +import { createOrUpdateTrainingTrigger } from '../../../../lib/domain/usecases/create-or-update-training-trigger.js'; +import { expect, catchErr, sinon } from '../../../test-helper.js'; describe('Unit | UseCase | create-or-update-training-trigger', function () { let trainingRepository; diff --git a/api/tests/unit/domain/usecases/create-or-update-user-orga-settings_test.js b/api/tests/unit/domain/usecases/create-or-update-user-orga-settings_test.js index 2a534abbea2..202e7f62888 100644 --- a/api/tests/unit/domain/usecases/create-or-update-user-orga-settings_test.js +++ b/api/tests/unit/domain/usecases/create-or-update-user-orga-settings_test.js @@ -1,15 +1,15 @@ -const createOrUpdateUserOrgaSettings = require('../../../../lib/domain/usecases/create-or-update-user-orga-settings'); -const { expect, catchErr, sinon } = require('../../../test-helper'); -const { UserNotMemberOfOrganizationError } = require('../../../../lib/domain/errors'); -const membershipRepository = require('../../../../lib/infrastructure/repositories/membership-repository'); +import { createOrUpdateUserOrgaSettings } from '../../../../lib/domain/usecases/create-or-update-user-orga-settings.js'; +import { expect, catchErr, sinon } from '../../../test-helper.js'; +import { UserNotMemberOfOrganizationError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | create-or-update-user-orga-settings', function () { const userId = 1; const organizationId = 3; let userOrgaSettingsRepository; + let membershipRepository; beforeEach(function () { - membershipRepository.findByUserIdAndOrganizationId = sinon.stub(); + membershipRepository = { findByUserIdAndOrganizationId: sinon.stub() }; userOrgaSettingsRepository = { createOrUpdate: sinon.stub() }; }); diff --git a/api/tests/unit/domain/usecases/create-organization-invitation-by-admin_test.js b/api/tests/unit/domain/usecases/create-organization-invitation-by-admin_test.js index 9abad5977bd..47c1510ceb3 100644 --- a/api/tests/unit/domain/usecases/create-organization-invitation-by-admin_test.js +++ b/api/tests/unit/domain/usecases/create-organization-invitation-by-admin_test.js @@ -1,9 +1,7 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); - -const Membership = require('../../../../lib/domain/models/Membership'); - -const createOrganizationInvitationByAdmin = require('../../../../lib/domain/usecases/create-organization-invitation-by-admin'); -const { OrganizationArchivedError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { createOrganizationInvitationByAdmin } from '../../../../lib/domain/usecases/create-organization-invitation-by-admin.js'; +import { OrganizationArchivedError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | create-organization-invitation-by-admin', function () { describe('#createOrganizationInvitationByAdmin', function () { diff --git a/api/tests/unit/domain/usecases/create-organization-invitations_test.js b/api/tests/unit/domain/usecases/create-organization-invitations_test.js index e6b97ddff76..0db9f41354a 100644 --- a/api/tests/unit/domain/usecases/create-organization-invitations_test.js +++ b/api/tests/unit/domain/usecases/create-organization-invitations_test.js @@ -1,7 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); - -const createOrganizationInvitations = require('../../../../lib/domain/usecases/create-organization-invitations'); -const { OrganizationArchivedError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { createOrganizationInvitations } from '../../../../lib/domain/usecases/create-organization-invitations.js'; +import { OrganizationArchivedError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | create-organization-invitations', function () { let organizationInvitationRepository, organizationRepository, organizationInvitationService; diff --git a/api/tests/unit/domain/usecases/create-organization-places-lot_test.js b/api/tests/unit/domain/usecases/create-organization-places-lot_test.js index cacb1f90038..a25f4b17e44 100644 --- a/api/tests/unit/domain/usecases/create-organization-places-lot_test.js +++ b/api/tests/unit/domain/usecases/create-organization-places-lot_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const OrganizationPlacesLot = require('../../../../lib/domain/models/OrganizationPlacesLot'); -const createOrganizationPlacesLot = require('../../../../lib/domain/usecases/create-organization-places-lot'); -const organizationPlacesLotManagement = require('../../../../lib/domain/read-models/OrganizationPlacesLotManagement'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { OrganizationPlacesLot } from '../../../../lib/domain/models/OrganizationPlacesLot.js'; +import { createOrganizationPlacesLot } from '../../../../lib/domain/usecases/create-organization-places-lot.js'; +import { OrganizationPlacesLotManagement as organizationPlacesLotManagement } from '../../../../lib/domain/read-models/OrganizationPlacesLotManagement.js'; describe('Unit | UseCase | create-organization-place-lot', function () { let organizationPlacesLotRepository, organizationRepository, organization; diff --git a/api/tests/unit/domain/usecases/create-organization_test.js b/api/tests/unit/domain/usecases/create-organization_test.js index d21e31cd29f..c78df6e9e77 100644 --- a/api/tests/unit/domain/usecases/create-organization_test.js +++ b/api/tests/unit/domain/usecases/create-organization_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const createOrganization = require('../../../../lib/domain/usecases/create-organization.js'); -const OrganizationForAdmin = require('../../../../lib/domain/models/organizations-administration/Organization'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { createOrganization } from '../../../../lib/domain/usecases/create-organization.js'; +import { OrganizationForAdmin } from '../../../../lib/domain/models/organizations-administration/Organization.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | create-organization', function () { let organizationCreationValidator; diff --git a/api/tests/unit/domain/usecases/create-organizations-with-tags-and-target-profiles_test.js b/api/tests/unit/domain/usecases/create-organizations-with-tags-and-target-profiles_test.js index c4501f2f3ee..efe6393fe79 100644 --- a/api/tests/unit/domain/usecases/create-organizations-with-tags-and-target-profiles_test.js +++ b/api/tests/unit/domain/usecases/create-organizations-with-tags-and-target-profiles_test.js @@ -1,16 +1,16 @@ -const { expect, catchErr, sinon, domainBuilder } = require('../../../test-helper'); -const Membership = require('../../../../lib/domain/models/Membership'); -const Organization = require('../../../../lib/domain/models/Organization'); -const OrganizationTag = require('../../../../lib/domain/models/OrganizationTag'); -const domainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const createOrganizationsWithTagsAndTargetProfiles = require('../../../../lib/domain/usecases/create-organizations-with-tags-and-target-profiles'); - -const { +import { expect, catchErr, sinon, domainBuilder } from '../../../test-helper.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; +import { OrganizationTag } from '../../../../lib/domain/models/OrganizationTag.js'; +import { DomainTransaction as domainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { createOrganizationsWithTagsAndTargetProfiles } from '../../../../lib/domain/usecases/create-organizations-with-tags-and-target-profiles.js'; + +import { ManyOrganizationsFoundError, ObjectValidationError, OrganizationAlreadyExistError, OrganizationTagNotFound, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | create-organizations-with-tags-and-target-profiles', function () { let organizationRepositoryStub; diff --git a/api/tests/unit/domain/usecases/create-password-reset-demand_test.js b/api/tests/unit/domain/usecases/create-password-reset-demand_test.js index ecb07f71571..da6bf0036f1 100644 --- a/api/tests/unit/domain/usecases/create-password-reset-demand_test.js +++ b/api/tests/unit/domain/usecases/create-password-reset-demand_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { UserNotFoundError } from '../../../../lib/domain/errors.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; -const { UserNotFoundError } = require('../../../../lib/domain/errors'); - -const { createPasswordResetDemand } = require('../../../../lib/domain/usecases/index.js'); +const { createPasswordResetDemand } = usecases; describe('Unit | UseCase | create-password-reset-demand', function () { const email = 'user@example.net'; diff --git a/api/tests/unit/domain/usecases/create-session_test.js b/api/tests/unit/domain/usecases/create-session_test.js index 75fa822c512..a18a3e30f27 100644 --- a/api/tests/unit/domain/usecases/create-session_test.js +++ b/api/tests/unit/domain/usecases/create-session_test.js @@ -1,8 +1,11 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const { noop } = require('lodash/noop'); -const createSession = require('../../../../lib/domain/usecases/create-session'); -const { ForbiddenAccess } = require('../../../../lib/domain/errors'); -const Session = require('../../../../lib/domain/models/Session'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import _ from 'lodash'; + +const { noop } = _; + +import { createSession } from '../../../../lib/domain/usecases/create-session.js'; +import { ForbiddenAccess } from '../../../../lib/domain/errors.js'; +import { Session } from '../../../../lib/domain/models/Session.js'; describe('Unit | UseCase | create-session', function () { describe('#save', function () { diff --git a/api/tests/unit/domain/usecases/create-tag_test.js b/api/tests/unit/domain/usecases/create-tag_test.js index 7f850291a5c..2417f07fe49 100644 --- a/api/tests/unit/domain/usecases/create-tag_test.js +++ b/api/tests/unit/domain/usecases/create-tag_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const Tag = require('../../../../lib/domain/models/Tag'); -const createTag = require('../../../../lib/domain/usecases/create-tag'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { Tag } from '../../../../lib/domain/models/Tag.js'; +import { createTag } from '../../../../lib/domain/usecases/create-tag.js'; describe('Unit | UseCase | create-tag', function () { it('should allow to create a tag', async function () { diff --git a/api/tests/unit/domain/usecases/create-target-profile_test.js b/api/tests/unit/domain/usecases/create-target-profile_test.js index 950150e16af..8a5f857a7d0 100644 --- a/api/tests/unit/domain/usecases/create-target-profile_test.js +++ b/api/tests/unit/domain/usecases/create-target-profile_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const createTargetProfile = require('../../../../lib/domain/usecases/create-target-profile'); -const { categories } = require('../../../../lib/domain/models/TargetProfile'); -const { TargetProfileCannotBeCreated } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { createTargetProfile } from '../../../../lib/domain/usecases/create-target-profile.js'; +import { categories } from '../../../../lib/domain/models/TargetProfile.js'; +import { TargetProfileCannotBeCreated } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | create-target-profile', function () { let targetProfileRepositoryStub; diff --git a/api/tests/unit/domain/usecases/create-training_test.js b/api/tests/unit/domain/usecases/create-training_test.js index 18ba801788d..7fafb1b0bb7 100644 --- a/api/tests/unit/domain/usecases/create-training_test.js +++ b/api/tests/unit/domain/usecases/create-training_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const createTraining = require('../../../../lib/domain/usecases/create-training'); +import { expect, sinon } from '../../../test-helper.js'; +import { createTraining } from '../../../../lib/domain/usecases/create-training.js'; describe('Unit | UseCase | create-training', function () { it('should call training repository to create the training', async function () { diff --git a/api/tests/unit/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user_test.js b/api/tests/unit/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user_test.js index 7dfb0728999..b890e4b33e6 100644 --- a/api/tests/unit/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user_test.js +++ b/api/tests/unit/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user_test.js @@ -1,5 +1,5 @@ -const { domainBuilder, expect, sinon } = require('../../../test-helper'); -const createUserAndReconcileToOrganizationLearnerFromExternalUser = require('../../../../lib/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user'); +import { domainBuilder, expect, sinon } from '../../../test-helper.js'; +import { createUserAndReconcileToOrganizationLearnerFromExternalUser } from '../../../../lib/domain/usecases/create-user-and-reconcile-to-organization-learner-from-external-user.js'; describe('Unit | UseCase | create-user-and-reconcile-to-organization-learner-from-external-user', function () { let obfuscationService; diff --git a/api/tests/unit/domain/usecases/create-user_test.js b/api/tests/unit/domain/usecases/create-user_test.js index c7ecc41569c..67f8ac7bf6b 100644 --- a/api/tests/unit/domain/usecases/create-user_test.js +++ b/api/tests/unit/domain/usecases/create-user_test.js @@ -1,10 +1,7 @@ -const { catchErr, expect, sinon } = require('../../../test-helper'); - -const { AlreadyRegisteredEmailError, EntityValidationError } = require('../../../../lib/domain/errors'); - -const User = require('../../../../lib/domain/models/User'); - -const createUser = require('../../../../lib/domain/usecases/create-user'); +import { catchErr, expect, sinon } from '../../../test-helper.js'; +import { AlreadyRegisteredEmailError, EntityValidationError } from '../../../../lib/domain/errors.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { createUser } from '../../../../lib/domain/usecases/create-user.js'; describe('Unit | UseCase | create-user', function () { const userId = 123; diff --git a/api/tests/unit/domain/usecases/deactivate-admin-member_test.js b/api/tests/unit/domain/usecases/deactivate-admin-member_test.js index 82d995799cc..2f6fd531f35 100644 --- a/api/tests/unit/domain/usecases/deactivate-admin-member_test.js +++ b/api/tests/unit/domain/usecases/deactivate-admin-member_test.js @@ -1,5 +1,5 @@ -const { sinon, expect } = require('../../../test-helper'); -const deactivateAdminMember = require('../../../../lib/domain/usecases/deactivate-admin-member'); +import { sinon, expect } from '../../../test-helper.js'; +import { deactivateAdminMember } from '../../../../lib/domain/usecases/deactivate-admin-member.js'; describe('Unit | UseCase | deactivate-admin-member', function () { it("should deactivate the given admin member and revoke all user's refresh tokens", async function () { diff --git a/api/tests/unit/domain/usecases/delete-campaign-participation-for-admin_test.js b/api/tests/unit/domain/usecases/delete-campaign-participation-for-admin_test.js index 3e405944893..c818082d58b 100644 --- a/api/tests/unit/domain/usecases/delete-campaign-participation-for-admin_test.js +++ b/api/tests/unit/domain/usecases/delete-campaign-participation-for-admin_test.js @@ -1,6 +1,8 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const { deleteCampaignParticipationForAdmin } = require('../../../../lib/domain/usecases/index.js'); -const CampaignParticipation = require('../../../../lib/domain/models/CampaignParticipation'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CampaignParticipation } from '../../../../lib/domain/models/CampaignParticipation.js'; + +const { deleteCampaignParticipationForAdmin } = usecases; describe('Unit | UseCase | delete-campaign-participation-for-admin', function () { //given @@ -21,7 +23,7 @@ describe('Unit | UseCase | delete-campaign-participation-for-admin', function () }; const campaignParticipationRepository = { getAllCampaignParticipationsInCampaignForASameLearner: sinon.stub(), - delete: sinon.stub(), + remove: sinon.stub(), }; const campaignParticipationId = 1234; const domainTransaction = Symbol('domainTransaction'); @@ -64,14 +66,14 @@ describe('Unit | UseCase | delete-campaign-participation-for-admin', function () }); //then - expect(campaignParticipationRepository.delete).to.have.been.calledTwice; + expect(campaignParticipationRepository.remove).to.have.been.calledTwice; campaignParticipations.forEach((campaignParticipation) => { const deletedCampaignParticipation = new CampaignParticipation({ ...campaignParticipation, deletedAt: now, deletedBy: ownerId, }); - expect(campaignParticipationRepository.delete).to.have.been.calledWithExactly({ + expect(campaignParticipationRepository.remove).to.have.been.calledWithExactly({ id: deletedCampaignParticipation.id, deletedAt: deletedCampaignParticipation.deletedAt, deletedBy: deletedCampaignParticipation.deletedBy, diff --git a/api/tests/unit/domain/usecases/delete-campaign-participation_test.js b/api/tests/unit/domain/usecases/delete-campaign-participation_test.js index 74b2e0b0a0c..9bd9ade352f 100644 --- a/api/tests/unit/domain/usecases/delete-campaign-participation_test.js +++ b/api/tests/unit/domain/usecases/delete-campaign-participation_test.js @@ -1,6 +1,8 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const { deleteCampaignParticipation } = require('../../../../lib/domain/usecases/index.js'); -const CampaignParticipation = require('../../../../lib/domain/models/CampaignParticipation'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CampaignParticipation } from '../../../../lib/domain/models/CampaignParticipation.js'; + +const { deleteCampaignParticipation } = usecases; describe('Unit | UseCase | delete-campaign-participation', function () { //given @@ -18,7 +20,7 @@ describe('Unit | UseCase | delete-campaign-participation', function () { it('should call repository method to delete a campaign participation', async function () { const campaignParticipationRepository = { getAllCampaignParticipationsInCampaignForASameLearner: sinon.stub(), - delete: sinon.stub(), + remove: sinon.stub(), }; const campaignParticipationId = 1234; const domainTransaction = Symbol('domainTransaction'); @@ -60,14 +62,14 @@ describe('Unit | UseCase | delete-campaign-participation', function () { }); //then - expect(campaignParticipationRepository.delete).to.have.been.calledTwice; + expect(campaignParticipationRepository.remove).to.have.been.calledTwice; campaignParticipations.forEach((campaignParticipation) => { const deletedCampaignParticipation = new CampaignParticipation({ ...campaignParticipation, deletedAt: now, deletedBy: ownerId, }); - expect(campaignParticipationRepository.delete).to.have.been.calledWithExactly({ + expect(campaignParticipationRepository.remove).to.have.been.calledWithExactly({ id: deletedCampaignParticipation.id, deletedAt: deletedCampaignParticipation.deletedAt, deletedBy: deletedCampaignParticipation.deletedBy, diff --git a/api/tests/unit/domain/usecases/delete-certification-issue-report_test.js b/api/tests/unit/domain/usecases/delete-certification-issue-report_test.js index 8849dda29f7..ad5aad90bd6 100644 --- a/api/tests/unit/domain/usecases/delete-certification-issue-report_test.js +++ b/api/tests/unit/domain/usecases/delete-certification-issue-report_test.js @@ -1,14 +1,11 @@ -const _ = require('lodash'); -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const deleteCertificationIssueReport = require('../../../../lib/domain/usecases/delete-certification-issue-report'); -const { ForbiddenAccess } = require('../../../../lib/domain/errors'); +import _ from 'lodash'; +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { deleteCertificationIssueReport } from '../../../../lib/domain/usecases/delete-certification-issue-report.js'; +import { ForbiddenAccess } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | delete-certification-issue-report', function () { const certificationCourseRepository = { get: () => _.noop() }; - const certificationIssueReportRepository = { - delete: () => _.noop(), - get: () => _.noop(), - }; + let certificationIssueReportRepository; const sessionRepository = { isFinalized: () => _.noop() }; const certificationIssueReportId = 456; const userId = 789; @@ -24,8 +21,10 @@ describe('Unit | UseCase | delete-certification-issue-report', function () { certificationCourseRepository.get .withArgs(certificationIssueReport.certificationCourseId) .resolves(certificationCourse); - sinon.stub(certificationIssueReportRepository, 'delete'); - sinon.stub(certificationIssueReportRepository, 'get'); + certificationIssueReportRepository = { + remove: sinon.stub(), + get: sinon.stub(), + }; certificationIssueReportRepository.get.withArgs(certificationIssueReportId).resolves(certificationIssueReport); sinon.stub(sessionRepository, 'isFinalized'); }); @@ -51,7 +50,7 @@ describe('Unit | UseCase | delete-certification-issue-report', function () { // given const deletionResult = Symbol('someValue'); sessionRepository.isFinalized.withArgs(sessionId).resolves(false); - certificationIssueReportRepository.delete.withArgs(certificationIssueReportId).resolves(deletionResult); + certificationIssueReportRepository.remove.withArgs(certificationIssueReportId).resolves(deletionResult); // when const actualDeletionResult = await deleteCertificationIssueReport({ diff --git a/api/tests/unit/domain/usecases/delete-organization-place-lot_test.js b/api/tests/unit/domain/usecases/delete-organization-place-lot_test.js index 845036787e2..b85f2a8b3b7 100644 --- a/api/tests/unit/domain/usecases/delete-organization-place-lot_test.js +++ b/api/tests/unit/domain/usecases/delete-organization-place-lot_test.js @@ -1,12 +1,12 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const deleteOrganizationPlaceLot = require('../../../../lib/domain/usecases/delete-organization-place-lot'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { deleteOrganizationPlaceLot } from '../../../../lib/domain/usecases/delete-organization-place-lot.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | delete-organization-place-lot', function () { it('should delete the organization place lot', async function () { // given const organizationPlacesLotRepository = { - delete: sinon.stub(), + remove: sinon.stub(), get: sinon.stub(), }; @@ -19,13 +19,13 @@ describe('Unit | UseCase | delete-organization-place-lot', function () { // then expect(organizationPlacesLotRepository.get).to.have.been.calledWithExactly(999); - expect(organizationPlacesLotRepository.delete).to.have.been.calledWithExactly({ id: 999, deletedBy: 666 }); + expect(organizationPlacesLotRepository.remove).to.have.been.calledWithExactly({ id: 999, deletedBy: 666 }); }); it('should not call sofDelete given wrong organizationId', async function () { // given const organizationPlacesLotRepository = { - delete: sinon.stub(), + remove: sinon.stub(), get: sinon.stub(), }; organizationPlacesLotRepository.get.withArgs(999).rejects(new NotFoundError()); @@ -39,6 +39,6 @@ describe('Unit | UseCase | delete-organization-place-lot', function () { // then expect(response).to.be.instanceOf(NotFoundError); - expect(organizationPlacesLotRepository.delete).to.not.have.been.called; + expect(organizationPlacesLotRepository.remove).to.not.have.been.called; }); }); diff --git a/api/tests/unit/domain/usecases/delete-session-jury-comment_test.js b/api/tests/unit/domain/usecases/delete-session-jury-comment_test.js index 816f6ba893d..0c814ca17bb 100644 --- a/api/tests/unit/domain/usecases/delete-session-jury-comment_test.js +++ b/api/tests/unit/domain/usecases/delete-session-jury-comment_test.js @@ -1,10 +1,10 @@ -const { expect, sinon } = require('../../../test-helper'); -const deleteSessionJuryComment = require('../../../../lib/domain/usecases/delete-session-jury-comment'); +import { expect, sinon } from '../../../test-helper.js'; +import { deleteSessionJuryComment } from '../../../../lib/domain/usecases/delete-session-jury-comment.js'; describe('Unit | UseCase | delete-session-jury-comment', function () { it('should delete the session jury comment', async function () { // given - const sessionJuryCommentRepository = { delete: sinon.stub() }; + const sessionJuryCommentRepository = { remove: sinon.stub() }; // when await deleteSessionJuryComment({ @@ -13,6 +13,6 @@ describe('Unit | UseCase | delete-session-jury-comment', function () { }); // then - expect(sessionJuryCommentRepository.delete).to.have.been.calledWithExactly(123); + expect(sessionJuryCommentRepository.remove).to.have.been.calledWithExactly(123); }); }); diff --git a/api/tests/unit/domain/usecases/delete-session_test.js b/api/tests/unit/domain/usecases/delete-session_test.js index 878eb7bd0f8..f0e9ce4de86 100644 --- a/api/tests/unit/domain/usecases/delete-session_test.js +++ b/api/tests/unit/domain/usecases/delete-session_test.js @@ -1,12 +1,12 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const deleteSession = require('../../../../lib/domain/usecases/delete-session'); -const { SessionStartedDeletionError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { deleteSession } from '../../../../lib/domain/usecases/delete-session.js'; +import { SessionStartedDeletionError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | delete-session', function () { context('when there are no certification courses', function () { it('should delete the session', async function () { // given - const sessionRepository = { delete: sinon.stub() }; + const sessionRepository = { remove: sinon.stub() }; const certificationCourseRepository = { findCertificationCoursesBySessionId: sinon.stub() }; certificationCourseRepository.findCertificationCoursesBySessionId.resolves([]); @@ -18,14 +18,14 @@ describe('Unit | UseCase | delete-session', function () { }); // then - expect(sessionRepository.delete).to.have.been.calledWithExactly(123); + expect(sessionRepository.remove).to.have.been.calledWithExactly(123); }); }); context('when there are certification courses', function () { it('should throw SessionStartedDeletionError error', async function () { // given - const sessionRepository = { delete: sinon.stub() }; + const sessionRepository = { remove: sinon.stub() }; const certificationCourseRepository = { findCertificationCoursesBySessionId: sinon.stub() }; certificationCourseRepository.findCertificationCoursesBySessionId.resolves([ domainBuilder.buildCertificationCourse({ sessionId: 123 }), @@ -40,7 +40,7 @@ describe('Unit | UseCase | delete-session', function () { // then expect(error).to.be.instanceOf(SessionStartedDeletionError); - expect(sessionRepository.delete).to.not.have.been.called; + expect(sessionRepository.remove).to.not.have.been.called; }); }); }); diff --git a/api/tests/unit/domain/usecases/delete-unassociated-badge_test.js b/api/tests/unit/domain/usecases/delete-unassociated-badge_test.js index 7def44fd7f8..a7c3bee85bd 100644 --- a/api/tests/unit/domain/usecases/delete-unassociated-badge_test.js +++ b/api/tests/unit/domain/usecases/delete-unassociated-badge_test.js @@ -1,10 +1,10 @@ -const { sinon, expect, catchErr } = require('../../../test-helper'); +import { sinon, expect, catchErr } from '../../../test-helper.js'; +import { deleteUnassociatedBadge } from '../../../../lib/domain/usecases/delete-unassociated-badge.js'; -const deleteUnassociatedBadge = require('../../../../lib/domain/usecases/delete-unassociated-badge'); -const { +import { AcquiredBadgeForbiddenDeletionError, CertificationBadgeForbiddenDeletionError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | delete-unassociated-badge', function () { let badgeId; @@ -14,7 +14,7 @@ describe('Unit | UseCase | delete-unassociated-badge', function () { badgeId = 'badgeId'; badgeRepository = { isAssociated: sinon.stub(), - delete: sinon.stub(), + remove: sinon.stub(), isRelatedToCertification: sinon.stub(), }; }); @@ -22,7 +22,7 @@ describe('Unit | UseCase | delete-unassociated-badge', function () { context('When the badge is not associated to a badge acquisition', function () { beforeEach(function () { badgeRepository.isAssociated.withArgs(badgeId).resolves(false); - badgeRepository.delete.withArgs(badgeId).resolves(true); + badgeRepository.remove.withArgs(badgeId).resolves(true); }); it('should delete the badge', async function () { @@ -57,7 +57,7 @@ describe('Unit | UseCase | delete-unassociated-badge', function () { context('When the badge is related to a certification', function () { beforeEach(function () { badgeRepository.isRelatedToCertification.withArgs(badgeId).resolves(true); - badgeRepository.delete.withArgs(badgeId).resolves(true); + badgeRepository.remove.withArgs(badgeId).resolves(true); }); it('should not delete the badge', async function () { @@ -75,7 +75,7 @@ describe('Unit | UseCase | delete-unassociated-badge', function () { context('When the badge is not related to a certification', function () { beforeEach(function () { badgeRepository.isRelatedToCertification.withArgs(badgeId).resolves(false); - badgeRepository.delete.withArgs(badgeId).resolves(true); + badgeRepository.remove.withArgs(badgeId).resolves(true); }); it('should delete the badge', async function () { diff --git a/api/tests/unit/domain/usecases/delete-unlinked-certification-candidate_test.js b/api/tests/unit/domain/usecases/delete-unlinked-certification-candidate_test.js index 6725be9feae..5cc56517bd7 100644 --- a/api/tests/unit/domain/usecases/delete-unlinked-certification-candidate_test.js +++ b/api/tests/unit/domain/usecases/delete-unlinked-certification-candidate_test.js @@ -1,7 +1,6 @@ -const { sinon, expect, catchErr } = require('../../../test-helper'); - -const deleteUnlinkedCertificationCandidate = require('../../../../lib/domain/usecases/delete-unlinked-certification-candidate'); -const { CertificationCandidateForbiddenDeletionError } = require('../../../../lib/domain/errors'); +import { sinon, expect, catchErr } from '../../../test-helper.js'; +import { deleteUnlinkedCertificationCandidate } from '../../../../lib/domain/usecases/delete-unlinked-certification-candidate.js'; +import { CertificationCandidateForbiddenDeletionError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | delete-unlinked-sertification-candidate', function () { let certificationCandidateId; @@ -11,14 +10,14 @@ describe('Unit | UseCase | delete-unlinked-sertification-candidate', function () certificationCandidateId = 'dummy certification candidate id'; certificationCandidateRepository = { isNotLinked: sinon.stub(), - delete: sinon.stub(), + remove: sinon.stub(), }; }); context('When the certification candidate is not linked to a user', function () { beforeEach(function () { certificationCandidateRepository.isNotLinked.withArgs(certificationCandidateId).resolves(true); - certificationCandidateRepository.delete.withArgs(certificationCandidateId).resolves(true); + certificationCandidateRepository.remove.withArgs(certificationCandidateId).resolves(true); }); it('should delete the certification candidate', async function () { diff --git a/api/tests/unit/domain/usecases/deneutralize-challenge_test.js b/api/tests/unit/domain/usecases/deneutralize-challenge_test.js index 0a4ef85e9a6..984143b5365 100644 --- a/api/tests/unit/domain/usecases/deneutralize-challenge_test.js +++ b/api/tests/unit/domain/usecases/deneutralize-challenge_test.js @@ -1,7 +1,7 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const CertificationAssessment = require('../../../../lib/domain/models/CertificationAssessment'); -const deneutralizeChallenge = require('../../../../lib/domain/usecases/deneutralize-challenge'); -const ChallengeDeneutralized = require('../../../../lib/domain/events/ChallengeDeneutralized'); +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { CertificationAssessment } from '../../../../lib/domain/models/CertificationAssessment.js'; +import { deneutralizeChallenge } from '../../../../lib/domain/usecases/deneutralize-challenge.js'; +import { ChallengeDeneutralized } from '../../../../lib/domain/events/ChallengeDeneutralized.js'; describe('Unit | UseCase | deneutralize-challenge', function () { it('deneutralizes a challenge by its recId', async function () { diff --git a/api/tests/unit/domain/usecases/disable-certification-center-membership_test.js b/api/tests/unit/domain/usecases/disable-certification-center-membership_test.js index ad53d85ba75..e1898179fc3 100644 --- a/api/tests/unit/domain/usecases/disable-certification-center-membership_test.js +++ b/api/tests/unit/domain/usecases/disable-certification-center-membership_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const disableCertificationCenterMembership = require('../../../../lib/domain/usecases/disable-certification-center-membership.js'); +import { expect, sinon } from '../../../test-helper.js'; +import { disableCertificationCenterMembership } from '../../../../lib/domain/usecases/disable-certification-center-membership.js'; describe('Unit | UseCase | disable-certification-center-membership', function () { let certificationCenterMembershipRepository; diff --git a/api/tests/unit/domain/usecases/disable-membership_test.js b/api/tests/unit/domain/usecases/disable-membership_test.js index 1ff9ebc7e9c..db6cce14319 100644 --- a/api/tests/unit/domain/usecases/disable-membership_test.js +++ b/api/tests/unit/domain/usecases/disable-membership_test.js @@ -1,6 +1,6 @@ -const { catchErr, expect, sinon } = require('../../../test-helper'); -const disableMembership = require('../../../../lib/domain/usecases/disable-membership.js'); -const { MembershipUpdateError } = require('../../../../lib/domain/errors'); +import { catchErr, expect, sinon } from '../../../test-helper.js'; +import { disableMembership } from '../../../../lib/domain/usecases/disable-membership.js'; +import { MembershipUpdateError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | disable-membership', function () { let membershipRepository; diff --git a/api/tests/unit/domain/usecases/dissociate-user-from-organization-learner_test.js b/api/tests/unit/domain/usecases/dissociate-user-from-organization-learner_test.js index 57278dccd30..0a5125cee27 100644 --- a/api/tests/unit/domain/usecases/dissociate-user-from-organization-learner_test.js +++ b/api/tests/unit/domain/usecases/dissociate-user-from-organization-learner_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const { OrganizationLearnerCannotBeDissociatedError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { OrganizationLearnerCannotBeDissociatedError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | dissociate-user-from-organization-learner', function () { const organizationId = 1; diff --git a/api/tests/unit/domain/usecases/end-assessment-by-supervisor_test.js b/api/tests/unit/domain/usecases/end-assessment-by-supervisor_test.js index c7586db6724..9d210cc8586 100644 --- a/api/tests/unit/domain/usecases/end-assessment-by-supervisor_test.js +++ b/api/tests/unit/domain/usecases/end-assessment-by-supervisor_test.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const endAssessmentBySupervisor = require('../../../../lib/domain/usecases/end-assessment-by-supervisor'); +import _ from 'lodash'; +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { endAssessmentBySupervisor } from '../../../../lib/domain/usecases/end-assessment-by-supervisor.js'; describe('Unit | UseCase | end-assessment-by-supervisor', function () { let assessmentRepository; diff --git a/api/tests/unit/domain/usecases/enroll-students-to-session_test.js b/api/tests/unit/domain/usecases/enroll-students-to-session_test.js index 4c926051bea..0c9c1afd63a 100644 --- a/api/tests/unit/domain/usecases/enroll-students-to-session_test.js +++ b/api/tests/unit/domain/usecases/enroll-students-to-session_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); - -const enrolStudentsToSession = require('../../../../lib/domain/usecases/enrol-students-to-session'); -const SCOCertificationCandidate = require('../../../../lib/domain/models/SCOCertificationCandidate'); -const { ForbiddenAccess, UnknownCountryForStudentEnrolmentError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { enrolStudentsToSession } from '../../../../lib/domain/usecases/enrol-students-to-session.js'; +import { SCOCertificationCandidate } from '../../../../lib/domain/models/SCOCertificationCandidate.js'; +import { ForbiddenAccess, UnknownCountryForStudentEnrolmentError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | enrol-students-to-session', function () { context('when referent is allowed to Pix Certif', function () { diff --git a/api/tests/unit/domain/usecases/finalize-session_test.js b/api/tests/unit/domain/usecases/finalize-session_test.js index d77005dc01f..5bb7bcdf131 100644 --- a/api/tests/unit/domain/usecases/finalize-session_test.js +++ b/api/tests/unit/domain/usecases/finalize-session_test.js @@ -1,14 +1,15 @@ -const { sinon, expect, catchErr, domainBuilder } = require('../../../test-helper'); +import { sinon, expect, catchErr, domainBuilder } from '../../../test-helper.js'; +import { finalizeSession } from '../../../../lib/domain/usecases/finalize-session.js'; -const finalizeSession = require('../../../../lib/domain/usecases/finalize-session'); -const { +import { SessionAlreadyFinalizedError, SessionWithoutStartedCertificationError, SessionWithAbortReasonOnCompletedCertificationCourseError, SessionWithMissingAbortReasonError, InvalidCertificationReportForFinalization, -} = require('../../../../lib/domain/errors'); -const SessionFinalized = require('../../../../lib/domain/events/SessionFinalized'); +} from '../../../../lib/domain/errors.js'; + +import { SessionFinalized } from '../../../../lib/domain/events/SessionFinalized.js'; describe('Unit | UseCase | finalize-session', function () { let sessionId; diff --git a/api/tests/unit/domain/usecases/find-all-tags_test.js b/api/tests/unit/domain/usecases/find-all-tags_test.js index 9683d74cf38..6d6b282623b 100644 --- a/api/tests/unit/domain/usecases/find-all-tags_test.js +++ b/api/tests/unit/domain/usecases/find-all-tags_test.js @@ -1,6 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); - -const findAllTags = require('../../../../lib/domain/usecases/find-all-tags'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findAllTags } from '../../../../lib/domain/usecases/find-all-tags.js'; describe('Unit | UseCase | find-all-tags', function () { let tagRepository; diff --git a/api/tests/unit/domain/usecases/find-answer-by-assessment_test.js b/api/tests/unit/domain/usecases/find-answer-by-assessment_test.js index 62a2928c51c..703d76faa8a 100644 --- a/api/tests/unit/domain/usecases/find-answer-by-assessment_test.js +++ b/api/tests/unit/domain/usecases/find-answer-by-assessment_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const findAnswerByAssessment = require('../../../../lib/domain/usecases/find-answer-by-assessment'); -const { UserNotAuthorizedToAccessEntityError, EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { findAnswerByAssessment } from '../../../../lib/domain/usecases/find-answer-by-assessment.js'; +import { UserNotAuthorizedToAccessEntityError, EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | find-answer-by-challenge-and-assessment', function () { const assessmentId = 123; diff --git a/api/tests/unit/domain/usecases/find-answer-by-challenge-and-assessment_test.js b/api/tests/unit/domain/usecases/find-answer-by-challenge-and-assessment_test.js index e295eb1fc43..b53a372cf09 100644 --- a/api/tests/unit/domain/usecases/find-answer-by-challenge-and-assessment_test.js +++ b/api/tests/unit/domain/usecases/find-answer-by-challenge-and-assessment_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const findAnswerByChallengeAndAssessment = require('../../../../lib/domain/usecases/find-answer-by-challenge-and-assessment'); +import { expect, sinon } from '../../../test-helper.js'; +import { findAnswerByChallengeAndAssessment } from '../../../../lib/domain/usecases/find-answer-by-challenge-and-assessment.js'; describe('Unit | UseCase | find-answer-by-challenge-and-assessment', function () { const challengeId = 'recChallenge'; diff --git a/api/tests/unit/domain/usecases/find-assessment-participation-result-list_test.js b/api/tests/unit/domain/usecases/find-assessment-participation-result-list_test.js index cdd5df6fa6e..474011be832 100644 --- a/api/tests/unit/domain/usecases/find-assessment-participation-result-list_test.js +++ b/api/tests/unit/domain/usecases/find-assessment-participation-result-list_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const findAssessmentParticipationResultList = require('../../../../lib/domain/usecases/find-assessment-participation-result-list'); +import { expect, sinon } from '../../../test-helper.js'; +import { findAssessmentParticipationResultList } from '../../../../lib/domain/usecases/find-assessment-participation-result-list.js'; describe('Unit | UseCase | find-assessment-participation-result-list', function () { it('return the assessmentParticipationResultMinimal list', async function () { diff --git a/api/tests/unit/domain/usecases/find-association-between-user-and-organization-learner_test.js b/api/tests/unit/domain/usecases/find-association-between-user-and-organization-learner_test.js index d87ea88ed3a..ed87602d78e 100644 --- a/api/tests/unit/domain/usecases/find-association-between-user-and-organization-learner_test.js +++ b/api/tests/unit/domain/usecases/find-association-between-user-and-organization-learner_test.js @@ -1,11 +1,12 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const findAssociationBetweenUserAndOrganizationLearner = require('../../../../lib/domain/usecases/find-association-between-user-and-organization-learner.js'); -const OrganizationLearner = require('../../../../lib/domain/models/OrganizationLearner'); -const { +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { findAssociationBetweenUserAndOrganizationLearner } from '../../../../lib/domain/usecases/find-association-between-user-and-organization-learner.js'; +import { OrganizationLearner } from '../../../../lib/domain/models/OrganizationLearner.js'; + +import { CampaignCodeError, UserNotAuthorizedToAccessEntityError, OrganizationLearnerDisabledError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | find-association-between-user-and-organization-learner', function () { let organizationLearnerReceivedStub; diff --git a/api/tests/unit/domain/usecases/find-campaign-participation-trainings_test.js b/api/tests/unit/domain/usecases/find-campaign-participation-trainings_test.js index 13ae61d6aa7..e838619b81e 100644 --- a/api/tests/unit/domain/usecases/find-campaign-participation-trainings_test.js +++ b/api/tests/unit/domain/usecases/find-campaign-participation-trainings_test.js @@ -1,6 +1,6 @@ -const { sinon, expect, domainBuilder, catchErr } = require('../../../test-helper'); -const findCampaignParticipationTrainings = require('../../../../lib/domain/usecases/find-campaign-participation-trainings.js'); -const { UserNotAuthorizedToFindTrainings } = require('../../../../lib/domain/errors'); +import { sinon, expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { findCampaignParticipationTrainings } from '../../../../lib/domain/usecases/find-campaign-participation-trainings.js'; +import { UserNotAuthorizedToFindTrainings } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | find-campaign-participation-trainings', function () { let campaignParticipationRepository; diff --git a/api/tests/unit/domain/usecases/find-campaign-participations-for-user-management_test.js b/api/tests/unit/domain/usecases/find-campaign-participations-for-user-management_test.js index e7d1ad1942d..e5d3db22b4a 100644 --- a/api/tests/unit/domain/usecases/find-campaign-participations-for-user-management_test.js +++ b/api/tests/unit/domain/usecases/find-campaign-participations-for-user-management_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const findCampaignParticipationsForUserManagement = require('../../../../lib/domain/usecases/find-campaign-participations-for-user-management'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findCampaignParticipationsForUserManagement } from '../../../../lib/domain/usecases/find-campaign-participations-for-user-management.js'; describe('Unit | UseCase | findCampaignParticipationsForUserManagement', function () { const userId = 1; diff --git a/api/tests/unit/domain/usecases/find-campaign-profiles-collection-participation-summaries_test.js b/api/tests/unit/domain/usecases/find-campaign-profiles-collection-participation-summaries_test.js index dde9066bfc4..6f52a4ee94e 100644 --- a/api/tests/unit/domain/usecases/find-campaign-profiles-collection-participation-summaries_test.js +++ b/api/tests/unit/domain/usecases/find-campaign-profiles-collection-participation-summaries_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const findCampaignProfilesCollectionParticipationSummaries = require('../../../../lib/domain/usecases/find-campaign-profiles-collection-participation-summaries'); -const CampaignProfilesCollectionParticipationSummary = require('../../../../lib/domain/read-models/CampaignProfilesCollectionParticipationSummary'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { findCampaignProfilesCollectionParticipationSummaries } from '../../../../lib/domain/usecases/find-campaign-profiles-collection-participation-summaries.js'; +import { CampaignProfilesCollectionParticipationSummary } from '../../../../lib/domain/read-models/CampaignProfilesCollectionParticipationSummary.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | find-campaign-profiles-collection-participation-summaries', function () { // TODO: Fix this the next time the file is edited. diff --git a/api/tests/unit/domain/usecases/find-certification-attestations-for-division_test.js b/api/tests/unit/domain/usecases/find-certification-attestations-for-division_test.js index eec19d9726a..89ac499ba09 100644 --- a/api/tests/unit/domain/usecases/find-certification-attestations-for-division_test.js +++ b/api/tests/unit/domain/usecases/find-certification-attestations-for-division_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const findCertificationAttestationsForDivision = require('../../../../lib/domain/usecases/certificate/find-certification-attestations-for-division'); -const { NoCertificationAttestationForDivisionError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { findCertificationAttestationsForDivision } from '../../../../lib/domain/usecases/certificate/find-certification-attestations-for-division.js'; +import { NoCertificationAttestationForDivisionError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | find-certification-attestations-for-division', function () { const certificateRepository = { diff --git a/api/tests/unit/domain/usecases/find-certification-center-memberships-by-certification-center_test.js b/api/tests/unit/domain/usecases/find-certification-center-memberships-by-certification-center_test.js index 2ce9b0d4ff5..12e668637e0 100644 --- a/api/tests/unit/domain/usecases/find-certification-center-memberships-by-certification-center_test.js +++ b/api/tests/unit/domain/usecases/find-certification-center-memberships-by-certification-center_test.js @@ -1,6 +1,5 @@ -const { domainBuilder, expect, sinon } = require('../../../test-helper'); - -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { domainBuilder, expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | find-certification-center-memberships-by-certification-center', function () { it('should result certification-center-memberships by certification center id', async function () { diff --git a/api/tests/unit/domain/usecases/find-certification-center-memberships-by-user_test.js b/api/tests/unit/domain/usecases/find-certification-center-memberships-by-user_test.js index 83a0caca2c5..c6aaabfe969 100644 --- a/api/tests/unit/domain/usecases/find-certification-center-memberships-by-user_test.js +++ b/api/tests/unit/domain/usecases/find-certification-center-memberships-by-user_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const findCertificationCenterMembershipsByUser = require('../../../../lib/domain/usecases/find-certification-center-memberships-by-user'); +import { expect, sinon } from '../../../test-helper.js'; +import { findCertificationCenterMembershipsByUser } from '../../../../lib/domain/usecases/find-certification-center-memberships-by-user.js'; describe('Unit | UseCase | find-certification-center-memberships-by-user', function () { let certificationCenterMembershipRepository; diff --git a/api/tests/unit/domain/usecases/find-competence-evaluations-by-assessment_test.js b/api/tests/unit/domain/usecases/find-competence-evaluations-by-assessment_test.js index c6b4aa62cd3..ab4c2137dd7 100644 --- a/api/tests/unit/domain/usecases/find-competence-evaluations-by-assessment_test.js +++ b/api/tests/unit/domain/usecases/find-competence-evaluations-by-assessment_test.js @@ -1,7 +1,7 @@ -const _ = require('lodash'); -const { expect, sinon, catchErr } = require('../../../test-helper'); -const findCompetenceEvaluationsByAssessment = require('../../../../lib/domain/usecases/find-competence-evaluations-by-assessment'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); +import _ from 'lodash'; +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { findCompetenceEvaluationsByAssessment } from '../../../../lib/domain/usecases/find-competence-evaluations-by-assessment.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | find-competence-evaluations-by-assessment', function () { const userId = 1; diff --git a/api/tests/unit/domain/usecases/find-complementary-certifications_test.js b/api/tests/unit/domain/usecases/find-complementary-certifications_test.js index ccc838b6eed..a52371674b3 100644 --- a/api/tests/unit/domain/usecases/find-complementary-certifications_test.js +++ b/api/tests/unit/domain/usecases/find-complementary-certifications_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const findComplementaryCertifications = require('../../../../lib/domain/usecases/find-complementary-certifications'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { findComplementaryCertifications } from '../../../../lib/domain/usecases/find-complementary-certifications.js'; describe('Unit | UseCase | find-complementary-certifications', function () { let complementaryCertificationRepository; diff --git a/api/tests/unit/domain/usecases/find-countries_test.js b/api/tests/unit/domain/usecases/find-countries_test.js index 48c03a8784a..e486079f70c 100644 --- a/api/tests/unit/domain/usecases/find-countries_test.js +++ b/api/tests/unit/domain/usecases/find-countries_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const findCountries = require('../../../../lib/domain/usecases/find-countries'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { findCountries } from '../../../../lib/domain/usecases/find-countries.js'; describe('Unit | UseCase | find-country', function () { let countryRepository; diff --git a/api/tests/unit/domain/usecases/find-divisions-by-certification-center_test.js b/api/tests/unit/domain/usecases/find-divisions-by-certification-center_test.js index 5baa075a04d..39c77f78ff2 100644 --- a/api/tests/unit/domain/usecases/find-divisions-by-certification-center_test.js +++ b/api/tests/unit/domain/usecases/find-divisions-by-certification-center_test.js @@ -1,6 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); - -const findDivisionsByCertificationCenter = require('../../../../lib/domain/usecases/find-divisions-by-certification-center'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findDivisionsByCertificationCenter } from '../../../../lib/domain/usecases/find-divisions-by-certification-center.js'; describe('Unit | UseCase | find-divisions-by-certification-center', function () { let organization; diff --git a/api/tests/unit/domain/usecases/find-divisions-by-organization_test.js b/api/tests/unit/domain/usecases/find-divisions-by-organization_test.js index 84df1f20283..a0b1848191b 100644 --- a/api/tests/unit/domain/usecases/find-divisions-by-organization_test.js +++ b/api/tests/unit/domain/usecases/find-divisions-by-organization_test.js @@ -1,6 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); - -const findDivisionsByOrganization = require('../../../../lib/domain/usecases/find-divisions-by-organization'); +import { expect, sinon } from '../../../test-helper.js'; +import { findDivisionsByOrganization } from '../../../../lib/domain/usecases/find-divisions-by-organization.js'; describe('Unit | UseCase | find-divisions-by-organization', function () { describe('when user has access to organization', function () { diff --git a/api/tests/unit/domain/usecases/find-finalized-sessions-to-publish_test.js b/api/tests/unit/domain/usecases/find-finalized-sessions-to-publish_test.js index 3bcb5686ea2..144ec6b44fd 100644 --- a/api/tests/unit/domain/usecases/find-finalized-sessions-to-publish_test.js +++ b/api/tests/unit/domain/usecases/find-finalized-sessions-to-publish_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const findFinalizedSessionsToPublish = require('../../../../lib/domain/usecases/find-finalized-sessions-to-publish'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findFinalizedSessionsToPublish } from '../../../../lib/domain/usecases/find-finalized-sessions-to-publish.js'; describe('Unit | UseCase | findFinalizedSessionsToPublish', function () { let finalizedSessionRepository; diff --git a/api/tests/unit/domain/usecases/find-finalized-sessions-with-required-action_test.js b/api/tests/unit/domain/usecases/find-finalized-sessions-with-required-action_test.js index c9a5726e1e4..aa0e96d6d98 100644 --- a/api/tests/unit/domain/usecases/find-finalized-sessions-with-required-action_test.js +++ b/api/tests/unit/domain/usecases/find-finalized-sessions-with-required-action_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const findFinalizedSessionsWithRequiredAction = require('../../../../lib/domain/usecases/find-finalized-sessions-with-required-action'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findFinalizedSessionsWithRequiredAction } from '../../../../lib/domain/usecases/find-finalized-sessions-with-required-action.js'; describe('Unit | UseCase | findFinalizedSessionsWithRequiredAction', function () { context('when there are finalized sessions with required actions', function () { diff --git a/api/tests/unit/domain/usecases/find-groups-by-organization_test.js b/api/tests/unit/domain/usecases/find-groups-by-organization_test.js index 2c1ba8657f8..100dc216947 100644 --- a/api/tests/unit/domain/usecases/find-groups-by-organization_test.js +++ b/api/tests/unit/domain/usecases/find-groups-by-organization_test.js @@ -1,6 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); - -const findDivisionsByOrganization = require('../../../../lib/domain/usecases/find-groups-by-organization'); +import { expect, sinon } from '../../../test-helper.js'; +import { findGroupsByOrganization } from '../../../../lib/domain/usecases/find-groups-by-organization.js'; describe('Unit | UseCase | find-groups-by-organization', function () { it('should return all groups', async function () { @@ -14,7 +13,7 @@ describe('Unit | UseCase | find-groups-by-organization', function () { .resolves([{ name: '3a' }, { name: '3b' }, { name: '5c' }]); // when - const groups = await findDivisionsByOrganization({ + const groups = await findGroupsByOrganization({ organizationId, groupRepository, }); diff --git a/api/tests/unit/domain/usecases/find-latest-ongoing-user-campaign-participation_test.js b/api/tests/unit/domain/usecases/find-latest-ongoing-user-campaign-participation_test.js index 3094cb5982d..1f0dd7ac11c 100644 --- a/api/tests/unit/domain/usecases/find-latest-ongoing-user-campaign-participation_test.js +++ b/api/tests/unit/domain/usecases/find-latest-ongoing-user-campaign-participation_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const findCampaignParticipationsRelatedToUser = require('../../../../lib/domain/usecases/find-latest-ongoing-user-campaign-participations'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findLatestOngoingUserCampaignParticipations as findCampaignParticipationsRelatedToUser } from '../../../../lib/domain/usecases/find-latest-ongoing-user-campaign-participations.js'; describe('Unit | UseCase | find-latest-user-campaign-participations', function () { let userId; diff --git a/api/tests/unit/domain/usecases/find-organization-places-lot_test.js b/api/tests/unit/domain/usecases/find-organization-places-lot_test.js index 095ea86d3a9..b48bc8691d1 100644 --- a/api/tests/unit/domain/usecases/find-organization-places-lot_test.js +++ b/api/tests/unit/domain/usecases/find-organization-places-lot_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const findOrganizationPlaceLot = require('../../../../lib/domain/usecases/find-organization-places-lot'); +import { expect, sinon } from '../../../test-helper.js'; +import { findOrganizationPlacesLot as findOrganizationPlaceLot } from '../../../../lib/domain/usecases/find-organization-places-lot.js'; describe('Unit | Domain | Use Cases | find-organization-places', function () { it('should get the organization places', async function () { diff --git a/api/tests/unit/domain/usecases/find-organization-target-profile-summaries-for-admin_test.js b/api/tests/unit/domain/usecases/find-organization-target-profile-summaries-for-admin_test.js index a19b93ee79a..dd56ae4154b 100644 --- a/api/tests/unit/domain/usecases/find-organization-target-profile-summaries-for-admin_test.js +++ b/api/tests/unit/domain/usecases/find-organization-target-profile-summaries-for-admin_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | find-organization-target-profile-summaries-for-admin', function () { it('should return the result of the repository call', async function () { diff --git a/api/tests/unit/domain/usecases/find-paginated-campaign-managments_test .js b/api/tests/unit/domain/usecases/find-paginated-campaign-managments_test .js index 566d043d33e..aa8fd7fe471 100644 --- a/api/tests/unit/domain/usecases/find-paginated-campaign-managments_test .js +++ b/api/tests/unit/domain/usecases/find-paginated-campaign-managments_test .js @@ -1,6 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); - -const findPaginatedCampaignManagements = require('../../../../lib/domain/usecases/find-paginated-campaign-managements'); +import { expect, sinon } from '../../../test-helper.js'; +import { findPaginatedCampaignManagements } from '../../../../lib/domain/usecases/find-paginated-campaign-managements.js'; describe('Unit | Domain | Use Cases | find-paginated-campaign-managments', function () { describe('#findPaginatedCampaignManagement', function () { diff --git a/api/tests/unit/domain/usecases/find-paginated-certification-center-session-summaries_test.js b/api/tests/unit/domain/usecases/find-paginated-certification-center-session-summaries_test.js index 33cac9c3cb1..db0dc4d1294 100644 --- a/api/tests/unit/domain/usecases/find-paginated-certification-center-session-summaries_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-certification-center-session-summaries_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const { ForbiddenAccess } = require('../../../../lib/domain/errors'); -const findPaginatedCertificationCenterSessionSummaries = require('../../../../lib/domain/usecases/find-paginated-certification-center-session-summaries'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { ForbiddenAccess } from '../../../../lib/domain/errors.js'; +import { findPaginatedCertificationCenterSessionSummaries } from '../../../../lib/domain/usecases/find-paginated-certification-center-session-summaries.js'; describe('Unit | Domain | Use Cases | find-paginated-certification-center-session-summaries', function () { const sessionSummaryRepository = { diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-certification-centers_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-certification-centers_test.js index 7e1b7b314e3..afe5ba98191 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-certification-centers_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-certification-centers_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const CertificationCenter = require('../../../../lib/domain/models/CertificationCenter'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { CertificationCenter } from '../../../../lib/domain/models/CertificationCenter.js'; describe('Unit | UseCase | find-paginated-filtered-certification-centers', function () { it('should result certification-centers with filtering and pagination', async function () { diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-organization-campaigns_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-organization-campaigns_test.js index 893bf9a0106..c5d96d49b2f 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-organization-campaigns_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-organization-campaigns_test.js @@ -1,6 +1,5 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); - -const findPaginatedFilteredOrganizationCampaigns = require('../../../../lib/domain/usecases/find-paginated-filtered-organization-campaigns'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { findPaginatedFilteredOrganizationCampaigns } from '../../../../lib/domain/usecases/find-paginated-filtered-organization-campaigns.js'; describe('Unit | Domain | Use Cases | find-paginated-filtered-organization-campaigns', function () { const campaignReportRepository = { findPaginatedFilteredByOrganizationId: () => undefined }; diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-organization-memberships_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-organization-memberships_test.js index 779b01782eb..2f7e6579133 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-organization-memberships_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-organization-memberships_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const Memberships = require('../../../../lib/domain/models/Membership'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Membership as Memberships } from '../../../../lib/domain/models/Membership.js'; describe('Unit | UseCase | find-paginated-filtered-organizations-memberships', function () { it('should result organizations with filtering and pagination', async function () { diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-organizations_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-organizations_test.js index abdcf0b9318..5e39eec1063 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-organizations_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-organizations_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const Organization = require('../../../../lib/domain/models/Organization'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; describe('Unit | UseCase | find-paginated-filtered-organizations', function () { it('should result organizations with filtering and pagination', async function () { diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-sco-participants_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-sco-participants_test.js index f9bfee24b69..3180f456a8f 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-sco-participants_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-sco-participants_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const findPaginatedFilteredScoParticipants = require('../../../../lib/domain/usecases/find-paginated-filtered-sco-participants'); +import { expect, sinon } from '../../../test-helper.js'; +import { findPaginatedFilteredScoParticipants } from '../../../../lib/domain/usecases/find-paginated-filtered-sco-participants.js'; describe('Unit | UseCase | findPaginatedFilteredScoParticipants', function () { let scoOrganizationParticipantRepository; diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-sup-participants_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-sup-participants_test.js index 03963c14b79..56f25489405 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-sup-participants_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-sup-participants_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const findPaginatedFilteredSupParticipants = require('../../../../lib/domain/usecases/find-paginated-filtered-sup-participants'); +import { expect, sinon } from '../../../test-helper.js'; +import { findPaginatedFilteredSupParticipants } from '../../../../lib/domain/usecases/find-paginated-filtered-sup-participants.js'; describe('Unit | UseCase | findPaginatedFilteredSupParticipants', function () { let supOrganizationParticipantRepository; diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-target-profile-summaries-for-admin_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-target-profile-summaries-for-admin_test.js index 7114c0b459c..fa1604a29b3 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-target-profile-summaries-for-admin_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-target-profile-summaries-for-admin_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | find-paginated-filtered-target-profile-summaries-for-admin', function () { it('should return the result of the repository call', async function () { diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-tutorials_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-tutorials_test.js index 9bd09d49741..275c89339a1 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-tutorials_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-tutorials_test.js @@ -1,6 +1,6 @@ -const { sinon, expect } = require('../../../test-helper'); -const findPaginatedFilteredTutorials = require('../../../../lib/domain/usecases/find-paginated-filtered-tutorials'); -const Tutorial = require('../../../../lib/domain/models/Tutorial'); +import { sinon, expect } from '../../../test-helper.js'; +import { findPaginatedFilteredTutorials } from '../../../../lib/domain/usecases/find-paginated-filtered-tutorials.js'; +import { Tutorial } from '../../../../lib/domain/models/Tutorial.js'; describe('Unit | UseCase | find-paginated-filtered-tutorials', function () { let tutorialRepository; diff --git a/api/tests/unit/domain/usecases/find-paginated-filtered-users_test.js b/api/tests/unit/domain/usecases/find-paginated-filtered-users_test.js index 461c0599e42..a8917c9b04f 100644 --- a/api/tests/unit/domain/usecases/find-paginated-filtered-users_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-filtered-users_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const User = require('../../../../lib/domain/models/User'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { User } from '../../../../lib/domain/models/User.js'; describe('Unit | UseCase | find-paginated-filtered-users', function () { it('should search users with filtering and pagination', async function () { diff --git a/api/tests/unit/domain/usecases/find-paginated-participations-for-campaign-management_test.js b/api/tests/unit/domain/usecases/find-paginated-participations-for-campaign-management_test.js index d09821f90c3..4b8925ddd7f 100644 --- a/api/tests/unit/domain/usecases/find-paginated-participations-for-campaign-management_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-participations-for-campaign-management_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const findPaginatedParticipationsForCampaignManagement = require('../../../../lib/domain/usecases/find-paginated-participations-for-campaign-management'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findPaginatedParticipationsForCampaignManagement } from '../../../../lib/domain/usecases/find-paginated-participations-for-campaign-management.js'; describe('Unit | UseCase | findPaginatedParticipationsForCampaignManagement', function () { const campaignId = 1; diff --git a/api/tests/unit/domain/usecases/find-paginated-target-profile-training-summaries_test.js b/api/tests/unit/domain/usecases/find-paginated-target-profile-training-summaries_test.js index 0e5aaa3bf1b..ba102afc1cf 100644 --- a/api/tests/unit/domain/usecases/find-paginated-target-profile-training-summaries_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-target-profile-training-summaries_test.js @@ -1,5 +1,5 @@ -const { sinon, expect } = require('../../../test-helper'); -const findTargetProfileSummariesForTraining = require('../../../../lib/domain/usecases/find-paginated-target-profile-training-summaries'); +import { sinon, expect } from '../../../test-helper.js'; +import { findPaginatedTargetProfileTrainingSummaries as findPaginatedTargetProfileTrainings } from '../../../../lib/domain/usecases/find-paginated-target-profile-training-summaries.js'; describe('Unit | UseCase | findPaginatedTargetProfileTrainingSummaries', function () { it('should call the repository with the right arguments and return summaries', async function () { @@ -13,7 +13,7 @@ describe('Unit | UseCase | findPaginatedTargetProfileTrainingSummaries', functio trainingRepository.findPaginatedSummariesByTargetProfileId.resolves(response); // when - const result = await findTargetProfileSummariesForTraining({ + const result = await findPaginatedTargetProfileTrainings({ targetProfileId, page, trainingRepository, diff --git a/api/tests/unit/domain/usecases/find-paginated-trainings-summary_test.js b/api/tests/unit/domain/usecases/find-paginated-trainings-summary_test.js index 8b4a760591d..bfc9ae10af6 100644 --- a/api/tests/unit/domain/usecases/find-paginated-trainings-summary_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-trainings-summary_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const findPaginatedTrainingSummaries = require('../../../../lib/domain/usecases/find-paginated-training-summaries'); +import { expect, sinon } from '../../../test-helper.js'; +import { findPaginatedTrainingSummaries } from '../../../../lib/domain/usecases/find-paginated-training-summaries.js'; describe('Unit | UseCase | find-paginated-training-summaries', function () { it('should find filtered training summaries with pagination', async function () { diff --git a/api/tests/unit/domain/usecases/find-paginated-user-recommended-trainings_test.js b/api/tests/unit/domain/usecases/find-paginated-user-recommended-trainings_test.js index 644715a375d..a528b74ac91 100644 --- a/api/tests/unit/domain/usecases/find-paginated-user-recommended-trainings_test.js +++ b/api/tests/unit/domain/usecases/find-paginated-user-recommended-trainings_test.js @@ -1,5 +1,5 @@ -const { sinon, expect } = require('../../../test-helper'); -const findPaginatedUserRecommendedTrainings = require('../../../../lib/domain/usecases/find-paginated-user-recommended-trainings'); +import { sinon, expect } from '../../../test-helper.js'; +import { findPaginatedUserRecommendedTrainings } from '../../../../lib/domain/usecases/find-paginated-user-recommended-trainings.js'; describe('Unit | UseCase | find-user-recommended-trainings', function () { it('should return paginated recommended trainings', async function () { diff --git a/api/tests/unit/domain/usecases/find-pending-organization-invitations_test.js b/api/tests/unit/domain/usecases/find-pending-organization-invitations_test.js index 7051367c248..f30306c5c14 100644 --- a/api/tests/unit/domain/usecases/find-pending-organization-invitations_test.js +++ b/api/tests/unit/domain/usecases/find-pending-organization-invitations_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const findPendingOrganizationInvitations = require('../../../../lib/domain/usecases/find-pending-organization-invitations'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findPendingOrganizationInvitations } from '../../../../lib/domain/usecases/find-pending-organization-invitations.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; describe('Unit | UseCase | find-pending-organization-invitations', function () { it('should succeed', async function () { diff --git a/api/tests/unit/domain/usecases/find-students-for-enrolment_test.js b/api/tests/unit/domain/usecases/find-students-for-enrolment_test.js index d082a9629ac..9c1fdf8507b 100644 --- a/api/tests/unit/domain/usecases/find-students-for-enrolment_test.js +++ b/api/tests/unit/domain/usecases/find-students-for-enrolment_test.js @@ -1,9 +1,8 @@ -const _ = require('lodash'); -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const StudentForEnrolment = require('../../../../lib/domain/read-models/StudentForEnrolment'); - -const findStudentsForEnrolment = require('../../../../lib/domain/usecases/find-students-for-enrolment'); +import _ from 'lodash'; +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { StudentForEnrolment } from '../../../../lib/domain/read-models/StudentForEnrolment.js'; +import { findStudentsForEnrolment } from '../../../../lib/domain/usecases/find-students-for-enrolment.js'; describe('Unit | UseCase | find-students-for-enrolment', function () { const certificationCenterId = 1; diff --git a/api/tests/unit/domain/usecases/find-target-profile-summaries-for-training_test.js b/api/tests/unit/domain/usecases/find-target-profile-summaries-for-training_test.js index b93fe11629f..c2a8840e977 100644 --- a/api/tests/unit/domain/usecases/find-target-profile-summaries-for-training_test.js +++ b/api/tests/unit/domain/usecases/find-target-profile-summaries-for-training_test.js @@ -1,5 +1,5 @@ -const { sinon, expect } = require('../../../test-helper'); -const findTargetProfileSummariesForTraining = require('../../../../lib/domain/usecases/find-target-profile-summaries-for-training'); +import { sinon, expect } from '../../../test-helper.js'; +import { findTargetProfileSummariesForTraining } from '../../../../lib/domain/usecases/find-target-profile-summaries-for-training.js'; describe('Unit | UseCase | find-target-profile-summaries-for-training', function () { it('should call the repository with the right arguments and return summaries', async function () { diff --git a/api/tests/unit/domain/usecases/find-tutorials_test.js b/api/tests/unit/domain/usecases/find-tutorials_test.js index 274155c1504..68eaa1ec5fc 100644 --- a/api/tests/unit/domain/usecases/find-tutorials_test.js +++ b/api/tests/unit/domain/usecases/find-tutorials_test.js @@ -1,8 +1,8 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); -const findTutorials = require('../../../../lib/domain/usecases/find-tutorials'); +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; +import { findTutorials } from '../../../../lib/domain/usecases/find-tutorials.js'; describe('Unit | UseCase | find-tutorials', function () { let authenticatedUserId; diff --git a/api/tests/unit/domain/usecases/find-user-authentication-methods.js b/api/tests/unit/domain/usecases/find-user-authentication-methods.js index 780194f03b2..b716c2ef0c3 100644 --- a/api/tests/unit/domain/usecases/find-user-authentication-methods.js +++ b/api/tests/unit/domain/usecases/find-user-authentication-methods.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const findUserAuthenticationMethods = require('../../../../lib/domain/usecases/find-user-authentication-methods'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findUserAuthenticationMethods } from '../../../../lib/domain/usecases/find-user-authentication-methods.js'; describe('Unit | UseCase | find-user-authentication-methods', function () { it('should find user authentication methods', async function () { diff --git a/api/tests/unit/domain/usecases/find-user-campaign-participation-overviews_test.js b/api/tests/unit/domain/usecases/find-user-campaign-participation-overviews_test.js index 3dcbfe718fb..99d3525a540 100644 --- a/api/tests/unit/domain/usecases/find-user-campaign-participation-overviews_test.js +++ b/api/tests/unit/domain/usecases/find-user-campaign-participation-overviews_test.js @@ -1,5 +1,5 @@ -const { sinon } = require('../../../test-helper'); -const findUserCampaignParticipationOverviews = require('../../../../lib/domain/usecases/find-user-campaign-participation-overviews'); +import { sinon } from '../../../test-helper.js'; +import { findUserCampaignParticipationOverviews } from '../../../../lib/domain/usecases/find-user-campaign-participation-overviews.js'; describe('Unit | UseCase | find-user-campaign-participation-overviews', function () { let campaignParticipationOverviewRepository; diff --git a/api/tests/unit/domain/usecases/find-user-for-oidc-reconciliation_test.js b/api/tests/unit/domain/usecases/find-user-for-oidc-reconciliation_test.js index bfa6b213b76..ecb2e71080a 100644 --- a/api/tests/unit/domain/usecases/find-user-for-oidc-reconciliation_test.js +++ b/api/tests/unit/domain/usecases/find-user-for-oidc-reconciliation_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const findUserForOidcReconciliation = require('../../../../lib/domain/usecases/find-user-for-oidc-reconciliation'); -const { AuthenticationKeyExpired, DifferentExternalIdentifierError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { findUserForOidcReconciliation } from '../../../../lib/domain/usecases/find-user-for-oidc-reconciliation.js'; +import { AuthenticationKeyExpired, DifferentExternalIdentifierError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | find-user-for-oidc-reconciliation', function () { let authenticationMethodRepository, userRepository, pixAuthenticationService, authenticationSessionService; diff --git a/api/tests/unit/domain/usecases/find-user-organizations-for-admin_test.js b/api/tests/unit/domain/usecases/find-user-organizations-for-admin_test.js index 4fe87cacfad..b76704ffe64 100644 --- a/api/tests/unit/domain/usecases/find-user-organizations-for-admin_test.js +++ b/api/tests/unit/domain/usecases/find-user-organizations-for-admin_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const findUserOrganizationsForAdmin = require('../../../../lib/domain/usecases/find-user-organizations-for-admin'); +import { expect, sinon } from '../../../test-helper.js'; +import { findUserOrganizationsForAdmin } from '../../../../lib/domain/usecases/find-user-organizations-for-admin.js'; describe('Unit | UseCase | findUserOrganizationsForAdmin', function () { it('should fetch user’s organization memberships', async function () { diff --git a/api/tests/unit/domain/usecases/find-user-private-certificates_test.js b/api/tests/unit/domain/usecases/find-user-private-certificates_test.js index faa10be7cb5..282f18d2c1b 100644 --- a/api/tests/unit/domain/usecases/find-user-private-certificates_test.js +++ b/api/tests/unit/domain/usecases/find-user-private-certificates_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const findUserPrivateCertificates = require('../../../../lib/domain/usecases/find-user-private-certificates'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { findUserPrivateCertificates } from '../../../../lib/domain/usecases/find-user-private-certificates.js'; describe('Unit | UseCase | find-user-private-certificates', function () { const certificateRepository = {}; diff --git a/api/tests/unit/domain/usecases/flag-session-results-as-sent-to-prescriber_test.js b/api/tests/unit/domain/usecases/flag-session-results-as-sent-to-prescriber_test.js index 0534e1f73c5..7f5b268e3f6 100644 --- a/api/tests/unit/domain/usecases/flag-session-results-as-sent-to-prescriber_test.js +++ b/api/tests/unit/domain/usecases/flag-session-results-as-sent-to-prescriber_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const flagSessionResultsAsSentToPrescriber = require('../../../../lib/domain/usecases/flag-session-results-as-sent-to-prescriber'); -const Session = require('../../../../lib/domain/models/Session'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { flagSessionResultsAsSentToPrescriber } from '../../../../lib/domain/usecases/flag-session-results-as-sent-to-prescriber.js'; +import { Session } from '../../../../lib/domain/models/Session.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | flag-session-results-as-sent-to-prescriber', function () { let sessionId; diff --git a/api/tests/unit/domain/usecases/generate-username-with-temporary-password_test.js b/api/tests/unit/domain/usecases/generate-username-with-temporary-password_test.js index bf3392c3260..a3aa032d43c 100644 --- a/api/tests/unit/domain/usecases/generate-username-with-temporary-password_test.js +++ b/api/tests/unit/domain/usecases/generate-username-with-temporary-password_test.js @@ -1,8 +1,6 @@ -const { sinon, expect, catchErr, domainBuilder } = require('../../../test-helper'); - -const { UserNotAuthorizedToGenerateUsernamePasswordError } = require('../../../../lib/domain/errors'); - -const generateUsernameWithTemporaryPassword = require('../../../../lib/domain/usecases/generate-username-with-temporary-password.js'); +import { sinon, expect, catchErr, domainBuilder } from '../../../test-helper.js'; +import { UserNotAuthorizedToGenerateUsernamePasswordError } from '../../../../lib/domain/errors.js'; +import { generateUsernameWithTemporaryPassword } from '../../../../lib/domain/usecases/generate-username-with-temporary-password.js'; describe('Unit | UseCase | generate-username-with-temporary-password', function () { const expectedUsername = 'john.harry0207'; diff --git a/api/tests/unit/domain/usecases/generate-username_test.js b/api/tests/unit/domain/usecases/generate-username_test.js index 21eb5554e8d..077ea9cf68d 100644 --- a/api/tests/unit/domain/usecases/generate-username_test.js +++ b/api/tests/unit/domain/usecases/generate-username_test.js @@ -1,12 +1,14 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { generateUsername } = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Student } from '../../../../lib/domain/models/Student.js'; -const Student = require('../../../../lib/domain/models/Student'); -const { +import { CampaignCodeError, OrganizationLearnerNotFound, OrganizationLearnerAlreadyLinkedToUserError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; + +const { generateUsername } = usecases; describe('Unit | UseCase | generate-username', function () { const organizationId = 1; diff --git a/api/tests/unit/domain/usecases/get-admin-member-details_test.js b/api/tests/unit/domain/usecases/get-admin-member-details_test.js index 0a07f4deaac..828e90749a7 100644 --- a/api/tests/unit/domain/usecases/get-admin-member-details_test.js +++ b/api/tests/unit/domain/usecases/get-admin-member-details_test.js @@ -1,6 +1,6 @@ -const { catchErr, expect, sinon, domainBuilder } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const getAdminMemberDetails = require('../../../../lib/domain/usecases/get-admin-member-details'); +import { catchErr, expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { getAdminMemberDetails } from '../../../../lib/domain/usecases/get-admin-member-details.js'; describe('Unit | UseCase | get-admin-member-details', function () { context('when it exists', function () { diff --git a/api/tests/unit/domain/usecases/get-admin-members_test.js b/api/tests/unit/domain/usecases/get-admin-members_test.js index 2214af80133..9dbe2117212 100644 --- a/api/tests/unit/domain/usecases/get-admin-members_test.js +++ b/api/tests/unit/domain/usecases/get-admin-members_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getAdminMembers = require('../../../../lib/domain/usecases/get-admin-members'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getAdminMembers } from '../../../../lib/domain/usecases/get-admin-members.js'; describe('Unit | UseCase | get-admin-members', function () { it('should return all admin members', async function () { diff --git a/api/tests/unit/domain/usecases/get-answer_test.js b/api/tests/unit/domain/usecases/get-answer_test.js index 6f6135241d0..82068574763 100644 --- a/api/tests/unit/domain/usecases/get-answer_test.js +++ b/api/tests/unit/domain/usecases/get-answer_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const getAnswer = require('../../../../lib/domain/usecases/get-answer'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon } from '../../../test-helper.js'; +import { getAnswer } from '../../../../lib/domain/usecases/get-answer.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-answer', function () { const answerId = 1; diff --git a/api/tests/unit/domain/usecases/get-assessment_test.js b/api/tests/unit/domain/usecases/get-assessment_test.js index 28b597a754e..fce5642c027 100644 --- a/api/tests/unit/domain/usecases/get-assessment_test.js +++ b/api/tests/unit/domain/usecases/get-assessment_test.js @@ -1,7 +1,6 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getAssessment = require('../../../../lib/domain/usecases/get-assessment'); - -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getAssessment } from '../../../../lib/domain/usecases/get-assessment.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Unit | UseCase | get-assessment', function () { let assessment; diff --git a/api/tests/unit/domain/usecases/get-attendance-sheet_test.js b/api/tests/unit/domain/usecases/get-attendance-sheet_test.js index d14cc1be64a..546d1c5226f 100644 --- a/api/tests/unit/domain/usecases/get-attendance-sheet_test.js +++ b/api/tests/unit/domain/usecases/get-attendance-sheet_test.js @@ -1,13 +1,15 @@ -const { expect, sinon } = require('../../../test-helper'); -const getAttendanceSheet = require('../../../../lib/domain/usecases/get-attendance-sheet'); -const { +import { expect, sinon } from '../../../test-helper.js'; +import { getAttendanceSheet } from '../../../../lib/domain/usecases/get-attendance-sheet.js'; + +import { ATTENDANCE_SHEET_SESSION_TEMPLATE_VALUES, NON_SCO_ATTENDANCE_SHEET_CANDIDATE_TEMPLATE_VALUES, SCO_ATTENDANCE_SHEET_CANDIDATE_TEMPLATE_VALUES, EXTRA_EMPTY_CANDIDATE_ROWS, -} = require('../../../../lib/infrastructure/files/attendance-sheet/attendance-sheet-placeholders'); -const _ = require('lodash'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); +} from '../../../../lib/infrastructure/files/attendance-sheet/attendance-sheet-placeholders.js'; + +import _ from 'lodash'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-attendance-sheet-in-ods-format', function () { describe('getAttendanceSheet', function () { diff --git a/api/tests/unit/domain/usecases/get-available-target-profiles-for-organization_test.js b/api/tests/unit/domain/usecases/get-available-target-profiles-for-organization_test.js index 03ef1c1f135..7d955488865 100644 --- a/api/tests/unit/domain/usecases/get-available-target-profiles-for-organization_test.js +++ b/api/tests/unit/domain/usecases/get-available-target-profiles-for-organization_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const getAvailableTargetProfilesForOrganization = require('../../../../lib/domain/usecases/get-available-target-profiles-for-organization'); +import { expect, sinon } from '../../../test-helper.js'; +import { getAvailableTargetProfilesForOrganization } from '../../../../lib/domain/usecases/get-available-target-profiles-for-organization.js'; describe('Unit | UseCase | get-available-target-profiles-for-organization', function () { it('returns the target profile available for the given organizations', async function () { diff --git a/api/tests/unit/domain/usecases/get-campaign-assessment-participation-result_test.js b/api/tests/unit/domain/usecases/get-campaign-assessment-participation-result_test.js index 8bb4aab9fa2..9817990a005 100644 --- a/api/tests/unit/domain/usecases/get-campaign-assessment-participation-result_test.js +++ b/api/tests/unit/domain/usecases/get-campaign-assessment-participation-result_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getCampaignAssessmentParticipationResult = require('../../../../lib/domain/usecases/get-campaign-assessment-participation-result'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getCampaignAssessmentParticipationResult } from '../../../../lib/domain/usecases/get-campaign-assessment-participation-result.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-campaign-assessment-participation-result', function () { let campaignRepository, campaignAssessmentParticipationResultRepository; diff --git a/api/tests/unit/domain/usecases/get-campaign-assessment-participation_test.js b/api/tests/unit/domain/usecases/get-campaign-assessment-participation_test.js index 532eac94b2e..dfc3bd0e703 100644 --- a/api/tests/unit/domain/usecases/get-campaign-assessment-participation_test.js +++ b/api/tests/unit/domain/usecases/get-campaign-assessment-participation_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getCampaignAssessmentParticipation = require('../../../../lib/domain/usecases/get-campaign-assessment-participation'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const CampaignAssessmentParticipation = require('../../../../lib/domain/read-models/CampaignAssessmentParticipation'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getCampaignAssessmentParticipation } from '../../../../lib/domain/usecases/get-campaign-assessment-participation.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { CampaignAssessmentParticipation } from '../../../../lib/domain/read-models/CampaignAssessmentParticipation.js'; describe('Unit | UseCase | get-campaign-assessment-participation', function () { let campaignRepository; diff --git a/api/tests/unit/domain/usecases/get-campaign-by-code_test.js b/api/tests/unit/domain/usecases/get-campaign-by-code_test.js index 01f1d4a6db1..b6416180545 100644 --- a/api/tests/unit/domain/usecases/get-campaign-by-code_test.js +++ b/api/tests/unit/domain/usecases/get-campaign-by-code_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | get-campaign-by-code', function () { const code = 'QWERTY123'; diff --git a/api/tests/unit/domain/usecases/get-campaign-profile_test.js b/api/tests/unit/domain/usecases/get-campaign-profile_test.js index 60433824e7e..d01708d277a 100644 --- a/api/tests/unit/domain/usecases/get-campaign-profile_test.js +++ b/api/tests/unit/domain/usecases/get-campaign-profile_test.js @@ -1,7 +1,9 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getCampaignProfile = require('../../../../lib/domain/usecases/get-campaign-profile'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const { FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getCampaignProfile } from '../../../../lib/domain/usecases/get-campaign-profile.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { FRENCH_SPOKEN } = LOCALE; describe('Unit | UseCase | get-campaign-profile', function () { let campaignRepository, campaignProfileRepository; diff --git a/api/tests/unit/domain/usecases/get-candidate-import-sheet-data_test.js b/api/tests/unit/domain/usecases/get-candidate-import-sheet-data_test.js index d09502b4911..f86cb5c1707 100644 --- a/api/tests/unit/domain/usecases/get-candidate-import-sheet-data_test.js +++ b/api/tests/unit/domain/usecases/get-candidate-import-sheet-data_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr, sinon, domainBuilder } = require('../../../test-helper'); -const getCandidateImportSheetData = require('../../../../lib/domain/usecases/get-candidate-import-sheet-data'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); +import { expect, catchErr, sinon, domainBuilder } from '../../../test-helper.js'; +import { getCandidateImportSheetData } from '../../../../lib/domain/usecases/get-candidate-import-sheet-data.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-candidate-import-sheet-data', function () { let sessionRepository; diff --git a/api/tests/unit/domain/usecases/get-certification-attestation_test.js b/api/tests/unit/domain/usecases/get-certification-attestation_test.js index f400b124161..5f1fdd21d30 100644 --- a/api/tests/unit/domain/usecases/get-certification-attestation_test.js +++ b/api/tests/unit/domain/usecases/get-certification-attestation_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const get = require('../../../../lib/domain/usecases/certificate/get-certification-attestation'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { getCertificationAttestation as get } from '../../../../lib/domain/usecases/certificate/get-certification-attestation.js'; describe('Unit | UseCase | get-certification-attestation', function () { const certificateRepository = { diff --git a/api/tests/unit/domain/usecases/get-certification-candidate-subscription_test.js b/api/tests/unit/domain/usecases/get-certification-candidate-subscription_test.js index 664e4dd716b..4fbaf435ce9 100644 --- a/api/tests/unit/domain/usecases/get-certification-candidate-subscription_test.js +++ b/api/tests/unit/domain/usecases/get-certification-candidate-subscription_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getCertificationCandidateSubscription = require('../../../../lib/domain/usecases/get-certification-candidate-subscription'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getCertificationCandidateSubscription } from '../../../../lib/domain/usecases/get-certification-candidate-subscription.js'; describe('Unit | UseCase | get-certification-candidate-subscription', function () { let certificationBadgesService; diff --git a/api/tests/unit/domain/usecases/get-certification-candidate_test.js b/api/tests/unit/domain/usecases/get-certification-candidate_test.js index 293269f347e..5cc6b1503bf 100644 --- a/api/tests/unit/domain/usecases/get-certification-candidate_test.js +++ b/api/tests/unit/domain/usecases/get-certification-candidate_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const getCertificationCandidate = require('../../../../lib/domain/usecases/get-certification-candidate'); +import { expect, sinon } from '../../../test-helper.js'; +import { getCertificationCandidate } from '../../../../lib/domain/usecases/get-certification-candidate.js'; describe('Unit | Domain | Use Cases | get-certification-candidate', function () { it('should get the certification candidate', async function () { diff --git a/api/tests/unit/domain/usecases/get-certification-center-for-admin_test.js b/api/tests/unit/domain/usecases/get-certification-center-for-admin_test.js index 8c8fa2a3f07..d34d49640a7 100644 --- a/api/tests/unit/domain/usecases/get-certification-center-for-admin_test.js +++ b/api/tests/unit/domain/usecases/get-certification-center-for-admin_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const getCertificationCenterForAdmin = require('../../../../lib/domain/usecases/get-certification-center-for-admin'); -const CertificationCenterForAdmin = require('../../../../lib/domain/models/CertificationCenterForAdmin'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { getCertificationCenterForAdmin } from '../../../../lib/domain/usecases/get-certification-center-for-admin.js'; +import { CertificationCenterForAdmin } from '../../../../lib/domain/models/CertificationCenterForAdmin.js'; describe('Unit | UseCase | get-certification-center-for-admin', function () { let certificationCenterForAdmin; diff --git a/api/tests/unit/domain/usecases/get-certification-center_test.js b/api/tests/unit/domain/usecases/get-certification-center_test.js index 284755fd5ef..99be7c4e695 100644 --- a/api/tests/unit/domain/usecases/get-certification-center_test.js +++ b/api/tests/unit/domain/usecases/get-certification-center_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, sinon } = require('../../../test-helper'); -const getCertificationCenter = require('../../../../lib/domain/usecases/get-certification-center'); -const CertificationCenter = require('../../../../lib/domain/models/CertificationCenter'); +import { expect, domainBuilder, sinon } from '../../../test-helper.js'; +import { getCertificationCenter } from '../../../../lib/domain/usecases/get-certification-center.js'; +import { CertificationCenter } from '../../../../lib/domain/models/CertificationCenter.js'; describe('Unit | UseCase | get-certification-center', function () { let certificationCenter; diff --git a/api/tests/unit/domain/usecases/get-certification-course_test.js b/api/tests/unit/domain/usecases/get-certification-course_test.js index f78da781e07..dd6e39750ca 100644 --- a/api/tests/unit/domain/usecases/get-certification-course_test.js +++ b/api/tests/unit/domain/usecases/get-certification-course_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const getCertificationCourse = require('../../../../lib/domain/usecases/get-certification-course'); -const CertificationCourse = require('../../../../lib/domain/models/CertificationCourse'); +import { expect, sinon } from '../../../test-helper.js'; +import { getCertificationCourse } from '../../../../lib/domain/usecases/get-certification-course.js'; +import { CertificationCourse } from '../../../../lib/domain/models/CertificationCourse.js'; describe('Unit | UseCase | get-certification-course', function () { let certificationCourse; diff --git a/api/tests/unit/domain/usecases/get-certification-details_test.js b/api/tests/unit/domain/usecases/get-certification-details_test.js index 918c425d164..1c68cf7df1b 100644 --- a/api/tests/unit/domain/usecases/get-certification-details_test.js +++ b/api/tests/unit/domain/usecases/get-certification-details_test.js @@ -1,7 +1,7 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const getCertificationDetails = require('../../../../lib/domain/usecases/get-certification-details'); -const CertificationDetails = require('../../../../lib/domain/read-models/CertificationDetails'); -const CertificationAssessmentStates = require('../../../../lib/domain/models/CertificationAssessment').states; +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { getCertificationDetails } from '../../../../lib/domain/usecases/get-certification-details.js'; +import { CertificationDetails } from '../../../../lib/domain/read-models/CertificationDetails.js'; +import { states as CertificationAssessmentStates } from '../../../../lib/domain/models/CertificationAssessment.js'; describe('Unit | UseCase | get-certification-details', function () { context('the certification assessment has not been completed', function () { diff --git a/api/tests/unit/domain/usecases/get-certification-point-of-contact_test.js b/api/tests/unit/domain/usecases/get-certification-point-of-contact_test.js index 9b34e428647..7e63df22034 100644 --- a/api/tests/unit/domain/usecases/get-certification-point-of-contact_test.js +++ b/api/tests/unit/domain/usecases/get-certification-point-of-contact_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getCertificationPointOfContact = require('../../../../lib/domain/usecases/get-certification-point-of-contact'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getCertificationPointOfContact } from '../../../../lib/domain/usecases/get-certification-point-of-contact.js'; describe('Unit | UseCase | get-certification-point-of-contact', function () { const userId = 123; diff --git a/api/tests/unit/domain/usecases/get-challenge-for-pix-auto-answer_test.js b/api/tests/unit/domain/usecases/get-challenge-for-pix-auto-answer_test.js index 524e6197032..41f6aff4ea3 100644 --- a/api/tests/unit/domain/usecases/get-challenge-for-pix-auto-answer_test.js +++ b/api/tests/unit/domain/usecases/get-challenge-for-pix-auto-answer_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getChallengeForPixAutoAnswer = require('../../../../lib/domain/usecases/get-challenge-for-pix-auto-answer'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getChallengeForPixAutoAnswer } from '../../../../lib/domain/usecases/get-challenge-for-pix-auto-answer.js'; describe('Unit | UseCase | get-challenge-answer-for-pix-button', function () { let assessment; diff --git a/api/tests/unit/domain/usecases/get-clea-certified-candidate-by-session_test.js b/api/tests/unit/domain/usecases/get-clea-certified-candidate-by-session_test.js index 20de9b5f118..a9b9b2b21a2 100644 --- a/api/tests/unit/domain/usecases/get-clea-certified-candidate-by-session_test.js +++ b/api/tests/unit/domain/usecases/get-clea-certified-candidate-by-session_test.js @@ -1,5 +1,5 @@ -const { sinon, domainBuilder, expect } = require('../../../test-helper'); -const getCleaCertifiedCandidateBySession = require('../../../../lib/domain/usecases/get-clea-certified-candidate-by-session'); +import { sinon, domainBuilder, expect } from '../../../test-helper.js'; +import { getCleaCertifiedCandidateBySession } from '../../../../lib/domain/usecases/get-clea-certified-candidate-by-session.js'; describe('Unit | UseCase | getCleaCertifiedCandidateBySession', function () { let cleaCertifiedCandidateRepository; diff --git a/api/tests/unit/domain/usecases/get-correction-for-answer_test.js b/api/tests/unit/domain/usecases/get-correction-for-answer_test.js index 9a6e98a5037..048f3653f00 100644 --- a/api/tests/unit/domain/usecases/get-correction-for-answer_test.js +++ b/api/tests/unit/domain/usecases/get-correction-for-answer_test.js @@ -1,8 +1,8 @@ -const getCorrectionForAnswer = require('../../../../lib/domain/usecases/get-correction-for-answer'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const Answer = require('../../../../lib/domain/models/Answer'); -const { AssessmentNotCompletedError, NotFoundError } = require('../../../../lib/domain/errors'); -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); +import { getCorrectionForAnswer } from '../../../../lib/domain/usecases/get-correction-for-answer.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { Answer } from '../../../../lib/domain/models/Answer.js'; +import { AssessmentNotCompletedError, NotFoundError } from '../../../../lib/domain/errors.js'; +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; describe('Unit | UseCase | getCorrectionForAnswer', function () { const assessmentRepository = { get: () => undefined }; diff --git a/api/tests/unit/domain/usecases/get-current-user_test.js b/api/tests/unit/domain/usecases/get-current-user_test.js index 4265356aa3e..95f271345c9 100644 --- a/api/tests/unit/domain/usecases/get-current-user_test.js +++ b/api/tests/unit/domain/usecases/get-current-user_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const getCurrentUser = require('../../../../lib/domain/usecases/get-current-user'); +import { expect, sinon } from '../../../test-helper.js'; +import { getCurrentUser } from '../../../../lib/domain/usecases/get-current-user.js'; describe('Unit | UseCase | get-current-user', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/get-external-authentication-redirection-url_test.js b/api/tests/unit/domain/usecases/get-external-authentication-redirection-url_test.js index bf9d0e4a0f1..ba967d90f36 100644 --- a/api/tests/unit/domain/usecases/get-external-authentication-redirection-url_test.js +++ b/api/tests/unit/domain/usecases/get-external-authentication-redirection-url_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const User = require('../../../../lib/domain/models/User'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const getExternalAuthenticationRedirectionUrl = require('../../../../lib/domain/usecases/get-external-authentication-redirection-url'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import { getExternalAuthenticationRedirectionUrl } from '../../../../lib/domain/usecases/get-external-authentication-redirection-url.js'; describe('Unit | UseCase | get-external-authentication-redirection-url', function () { let userRepository; @@ -53,7 +53,7 @@ describe('Unit | UseCase | get-external-authentication-redirection-url', functio userAttributes, userRepository, tokenService, - settings: samlSettings, + config: samlSettings, }); // then @@ -99,7 +99,7 @@ describe('Unit | UseCase | get-external-authentication-redirection-url', functio userRepository, authenticationMethodRepository, tokenService, - settings: samlSettings, + config: samlSettings, }); // then @@ -128,7 +128,7 @@ describe('Unit | UseCase | get-external-authentication-redirection-url', functio userRepository, authenticationMethodRepository, tokenService, - settings: samlSettings, + config: samlSettings, }); // then @@ -159,7 +159,7 @@ describe('Unit | UseCase | get-external-authentication-redirection-url', functio userRepository, authenticationMethodRepository, tokenService, - settings: samlSettings, + config: samlSettings, }); // then @@ -194,7 +194,7 @@ describe('Unit | UseCase | get-external-authentication-redirection-url', functio userRepository, authenticationMethodRepository, tokenService, - settings: samlSettings, + config: samlSettings, }); // then @@ -229,7 +229,7 @@ describe('Unit | UseCase | get-external-authentication-redirection-url', functio userRepository, authenticationMethodRepository, tokenService, - settings: samlSettings, + config: samlSettings, }); // then @@ -264,7 +264,7 @@ describe('Unit | UseCase | get-external-authentication-redirection-url', functio userRepository, authenticationMethodRepository, tokenService, - settings: samlSettings, + config: samlSettings, }); // then diff --git a/api/tests/unit/domain/usecases/get-framework-areas_test.js b/api/tests/unit/domain/usecases/get-framework-areas_test.js index 30c27bf8131..59ff5af4493 100644 --- a/api/tests/unit/domain/usecases/get-framework-areas_test.js +++ b/api/tests/unit/domain/usecases/get-framework-areas_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | get-framework-areas', function () { let expectedTubesResult, diff --git a/api/tests/unit/domain/usecases/get-frameworks_test.js b/api/tests/unit/domain/usecases/get-frameworks_test.js index 08e54383bad..3e6d77f5d29 100644 --- a/api/tests/unit/domain/usecases/get-frameworks_test.js +++ b/api/tests/unit/domain/usecases/get-frameworks_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | get-frameworks', function () { let frameworkRepository; diff --git a/api/tests/unit/domain/usecases/get-identity-providers_test.js b/api/tests/unit/domain/usecases/get-identity-providers_test.js index f94b9ba9a05..acb122aaa44 100644 --- a/api/tests/unit/domain/usecases/get-identity-providers_test.js +++ b/api/tests/unit/domain/usecases/get-identity-providers_test.js @@ -1,7 +1,7 @@ -const { expect, sinon } = require('../../../test-helper'); -const getIdentityProviders = require('../../../../lib/domain/usecases/get-identity-providers'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); -const config = require('../../../../lib/config'); +import { expect, sinon } from '../../../test-helper.js'; +import { getIdentityProviders } from '../../../../lib/domain/usecases/get-identity-providers.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; +import { config } from '../../../../lib/config.js'; describe('Unit | UseCase | get-identity-providers', function () { beforeEach(function () { @@ -33,7 +33,7 @@ describe('Unit | UseCase | get-identity-providers', function () { // then const expectedIdentityProviders = [OidcIdentityProviders.POLE_EMPLOI.service, OidcIdentityProviders.CNAV.service]; expect(identityProviders.length).to.equal(2); - expect(identityProviders).to.deep.equal(expectedIdentityProviders); + expect(identityProviders).to.include.members(expectedIdentityProviders); }); context('when an identity provider is not configured', function () { diff --git a/api/tests/unit/domain/usecases/get-import-session-complementary-certification-habilitations-labels_test.js b/api/tests/unit/domain/usecases/get-import-session-complementary-certification-habilitations-labels_test.js index 2e7a03ac7f8..657efdc8477 100644 --- a/api/tests/unit/domain/usecases/get-import-session-complementary-certification-habilitations-labels_test.js +++ b/api/tests/unit/domain/usecases/get-import-session-complementary-certification-habilitations-labels_test.js @@ -1,5 +1,5 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const getImportSessionComplementaryCertificationHabilitationsLabels = require('../../../../lib/domain/usecases/get-import-session-complementary-certification-habilitations-labels'); +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { getImportSessionComplementaryCertificationHabilitationsLabels } from '../../../../lib/domain/usecases/get-import-session-complementary-certification-habilitations-labels.js'; describe('Unit | Usecase | get-import-session-complementary-certification-habilitations-labels', function () { it('should return the certification center habilitations labels', async function () { diff --git a/api/tests/unit/domain/usecases/get-jury-certification_test.js b/api/tests/unit/domain/usecases/get-jury-certification_test.js index eab33195713..91e1b28afa1 100644 --- a/api/tests/unit/domain/usecases/get-jury-certification_test.js +++ b/api/tests/unit/domain/usecases/get-jury-certification_test.js @@ -1,5 +1,5 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const getJuryCertification = require('../../../../lib/domain/usecases/get-jury-certification'); +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { getJuryCertification } from '../../../../lib/domain/usecases/get-jury-certification.js'; describe('Unit | Usecase | get-jury-certification', function () { it('should return the jury certification', async function () { diff --git a/api/tests/unit/domain/usecases/get-jury-session_test.js b/api/tests/unit/domain/usecases/get-jury-session_test.js index 58e29417aae..2fbc434bc34 100644 --- a/api/tests/unit/domain/usecases/get-jury-session_test.js +++ b/api/tests/unit/domain/usecases/get-jury-session_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const getJurySession = require('../../../../lib/domain/usecases/get-jury-session'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { getJurySession } from '../../../../lib/domain/usecases/get-jury-session.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-jury-session', function () { let jurySessionRepository; diff --git a/api/tests/unit/domain/usecases/get-last-challenge-id-from-assessment-id_test.js b/api/tests/unit/domain/usecases/get-last-challenge-id-from-assessment-id_test.js index 8c6c41a3248..8b0168d9b8d 100644 --- a/api/tests/unit/domain/usecases/get-last-challenge-id-from-assessment-id_test.js +++ b/api/tests/unit/domain/usecases/get-last-challenge-id-from-assessment-id_test.js @@ -1,7 +1,6 @@ -const { catchErr, expect, sinon, domainBuilder } = require('../../../test-helper'); - -const getLastChallengeIdFromAssessmentId = require('../../../../lib/domain/usecases/get-last-challenge-id-from-assessment-id'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { catchErr, expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getLastChallengeIdFromAssessmentId } from '../../../../lib/domain/usecases/get-last-challenge-id-from-assessment-id.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-last-challenge-id-from-assessment-id', function () { let assessment; diff --git a/api/tests/unit/domain/usecases/get-learning-content-by-target-profile_test.js b/api/tests/unit/domain/usecases/get-learning-content-by-target-profile_test.js index bc0f9b3923c..966f6c13eda 100644 --- a/api/tests/unit/domain/usecases/get-learning-content-by-target-profile_test.js +++ b/api/tests/unit/domain/usecases/get-learning-content-by-target-profile_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getLearningContentByTargetProfile = require('../../../../lib/domain/usecases/get-learning-content-by-target-profile'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getLearningContentByTargetProfile } from '../../../../lib/domain/usecases/get-learning-content-by-target-profile.js'; describe('Unit | UseCase | get-learning-content-by-target-profile', function () { const learningContentRepository = {}; diff --git a/api/tests/unit/domain/usecases/get-next-challenge-for-campaign-assessment_test.js b/api/tests/unit/domain/usecases/get-next-challenge-for-campaign-assessment_test.js index 9ab2d20e381..1bc7af191fa 100644 --- a/api/tests/unit/domain/usecases/get-next-challenge-for-campaign-assessment_test.js +++ b/api/tests/unit/domain/usecases/get-next-challenge-for-campaign-assessment_test.js @@ -1,10 +1,9 @@ -const flash = require('../../../../lib/domain/services/algorithm-methods/flash'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); - -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getNextChallengeForCampaignAssessment = require('../../../../lib/domain/usecases/get-next-challenge-for-campaign-assessment'); -const { AssessmentEndedError } = require('../../../../lib/domain/errors'); -const config = require('../../../../lib/config'); +import * as flash from '../../../../lib/domain/services/algorithm-methods/flash.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getNextChallengeForCampaignAssessment } from '../../../../lib/domain/usecases/get-next-challenge-for-campaign-assessment.js'; +import { AssessmentEndedError } from '../../../../lib/domain/errors.js'; +import { config } from '../../../../lib/config.js'; describe('Unit | Domain | Use Cases | get-next-challenge-for-campaign-assessment', function () { describe('#get-next-challenge-for-campaign-assessment', function () { diff --git a/api/tests/unit/domain/usecases/get-next-challenge-for-certification_test.js b/api/tests/unit/domain/usecases/get-next-challenge-for-certification_test.js index 4a134900542..61dfdf667cb 100644 --- a/api/tests/unit/domain/usecases/get-next-challenge-for-certification_test.js +++ b/api/tests/unit/domain/usecases/get-next-challenge-for-certification_test.js @@ -1,7 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); - -const getNextChallengeForCertification = require('../../../../lib/domain/usecases/get-next-challenge-for-certification'); -const Assessment = require('../../../../lib/domain/models/Assessment'); +import { expect, sinon } from '../../../test-helper.js'; +import { getNextChallengeForCertification } from '../../../../lib/domain/usecases/get-next-challenge-for-certification.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; describe('Unit | Domain | Use Cases | get-next-challenge-for-certification', function () { describe('#getNextChallengeForCertification', function () { diff --git a/api/tests/unit/domain/usecases/get-next-challenge-for-competence-evaluation_test.js b/api/tests/unit/domain/usecases/get-next-challenge-for-competence-evaluation_test.js index 9e622a460ca..f5472efdd91 100644 --- a/api/tests/unit/domain/usecases/get-next-challenge-for-competence-evaluation_test.js +++ b/api/tests/unit/domain/usecases/get-next-challenge-for-competence-evaluation_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const getNextChallengeForCompetenceEvaluation = require('../../../../lib/domain/usecases/get-next-challenge-for-competence-evaluation'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { getNextChallengeForCompetenceEvaluation } from '../../../../lib/domain/usecases/get-next-challenge-for-competence-evaluation.js'; describe('Unit | Domain | Use Cases | get-next-challenge-for-competence-evaluation', function () { describe('#getNextChallengeForCompetenceEvaluation', function () { diff --git a/api/tests/unit/domain/usecases/get-next-challenge-for-demo_test.js b/api/tests/unit/domain/usecases/get-next-challenge-for-demo_test.js index 58a1cb71711..93ff556cd3c 100644 --- a/api/tests/unit/domain/usecases/get-next-challenge-for-demo_test.js +++ b/api/tests/unit/domain/usecases/get-next-challenge-for-demo_test.js @@ -1,8 +1,6 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); - -const { AssessmentEndedError } = require('../../../../lib/domain/errors'); - -const getNextChallengeForDemo = require('../../../../lib/domain/usecases/get-next-challenge-for-demo'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { AssessmentEndedError } from '../../../../lib/domain/errors.js'; +import { getNextChallengeForDemo } from '../../../../lib/domain/usecases/get-next-challenge-for-demo.js'; describe('Unit | Domain | Use Cases | get-next-challenge-for-demo', function () { describe('#get-next-challenge-for-demo', function () { diff --git a/api/tests/unit/domain/usecases/get-next-challenge-for-preview_test.js b/api/tests/unit/domain/usecases/get-next-challenge-for-preview_test.js index bdf45180af9..398b0eb7c2c 100644 --- a/api/tests/unit/domain/usecases/get-next-challenge-for-preview_test.js +++ b/api/tests/unit/domain/usecases/get-next-challenge-for-preview_test.js @@ -1,7 +1,6 @@ -const { expect } = require('../../../test-helper'); -const getNextChallengeForPreview = require('../../../../lib/domain/usecases/get-next-challenge-for-preview'); - -const { AssessmentEndedError } = require('../../../../lib/domain/errors'); +import { expect } from '../../../test-helper.js'; +import { getNextChallengeForPreview } from '../../../../lib/domain/usecases/get-next-challenge-for-preview.js'; +import { AssessmentEndedError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Use Cases | get-next-challenge-for-preview', function () { describe('#getNextChallengeForPreview', function () { diff --git a/api/tests/unit/domain/usecases/get-organization-details_test.js b/api/tests/unit/domain/usecases/get-organization-details_test.js index c2b6b68dad4..4a8c6bab958 100644 --- a/api/tests/unit/domain/usecases/get-organization-details_test.js +++ b/api/tests/unit/domain/usecases/get-organization-details_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getOrganizationDetails = require('../../../../lib/domain/usecases/organizations-administration/get-organization-details'); -const Organization = require('../../../../lib/domain/models/Organization'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getOrganizationDetails } from '../../../../lib/domain/usecases/organizations-administration/get-organization-details.js'; +import { Organization } from '../../../../lib/domain/models/Organization.js'; describe('Unit | UseCase | get-organization-details', function () { it('should return the Organization matching the given organization ID', async function () { diff --git a/api/tests/unit/domain/usecases/get-organization-invitation_test.js b/api/tests/unit/domain/usecases/get-organization-invitation_test.js index f8dbed8d606..cfd9cf090e2 100644 --- a/api/tests/unit/domain/usecases/get-organization-invitation_test.js +++ b/api/tests/unit/domain/usecases/get-organization-invitation_test.js @@ -1,11 +1,11 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getOrganizationInvitation = require('../../../../lib/domain/usecases/get-organization-invitation'); -const OrganizationInvitation = require('../../../../lib/domain/models/OrganizationInvitation'); -const { +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getOrganizationInvitation } from '../../../../lib/domain/usecases/get-organization-invitation.js'; +import { OrganizationInvitation } from '../../../../lib/domain/models/OrganizationInvitation.js'; +import { NotFoundError, AlreadyExistingInvitationError, CancelledInvitationError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-organization-invitation', function () { let organizationInvitationRepository; diff --git a/api/tests/unit/domain/usecases/get-organization-learner-activity_test.js b/api/tests/unit/domain/usecases/get-organization-learner-activity_test.js index 4276c9c2ebd..0b9d074baa5 100644 --- a/api/tests/unit/domain/usecases/get-organization-learner-activity_test.js +++ b/api/tests/unit/domain/usecases/get-organization-learner-activity_test.js @@ -1,7 +1,7 @@ -const { expect, sinon } = require('../../../test-helper'); -const getOrganizationLearnerActivity = require('../../../../lib/domain/usecases/get-organization-learner-activity'); -const OrganizationLearnerParticipation = require('../../../../lib/domain/read-models/OrganizationLearnerParticipation'); -const OrganizationLearnerActivity = require('../../../../lib/domain/read-models/OrganizationLearnerActivity'); +import { expect, sinon } from '../../../test-helper.js'; +import { getOrganizationLearnerActivity } from '../../../../lib/domain/usecases/get-organization-learner-activity.js'; +import { OrganizationLearnerParticipation } from '../../../../lib/domain/read-models/OrganizationLearnerParticipation.js'; +import { OrganizationLearnerActivity } from '../../../../lib/domain/read-models/OrganizationLearnerActivity.js'; describe('Unit | UseCase | get-organisation-learner-activity', function () { it('should return activity for the organization learner matching the given organizationLearnerId', async function () { diff --git a/api/tests/unit/domain/usecases/get-organization-learner_test.js b/api/tests/unit/domain/usecases/get-organization-learner_test.js index bb788c2d141..35ae56e4f0d 100644 --- a/api/tests/unit/domain/usecases/get-organization-learner_test.js +++ b/api/tests/unit/domain/usecases/get-organization-learner_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const getOrganizationLearner = require('../../../../lib/domain/usecases/get-organization-learner'); -const OrganizationLearner = require('../../../../lib/domain/read-models/organization-learner-follow-up/OrganizationLearner'); +import { expect, sinon } from '../../../test-helper.js'; +import { getOrganizationLearner } from '../../../../lib/domain/usecases/get-organization-learner.js'; +import { OrganizationLearner } from '../../../../lib/domain/read-models/organization-learner-follow-up/OrganizationLearner.js'; describe('Unit | UseCase | get-organisation-learner', function () { it('should return organization learner matching the given organizationLearnerId', async function () { diff --git a/api/tests/unit/domain/usecases/get-organization-learners-csv-template_test.js b/api/tests/unit/domain/usecases/get-organization-learners-csv-template_test.js index 0f3b57bb93c..7a3f0fe83ee 100644 --- a/api/tests/unit/domain/usecases/get-organization-learners-csv-template_test.js +++ b/api/tests/unit/domain/usecases/get-organization-learners-csv-template_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getOrganizationLearnersCsvTemplate = require('../../../../lib/domain/usecases/get-organization-learners-csv-template'); -const _ = require('lodash'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getOrganizationLearnersCsvTemplate } from '../../../../lib/domain/usecases/get-organization-learners-csv-template.js'; +import _ from 'lodash'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; describe('Unit | UseCase | get-organization-learners-csv-template', function () { // TODO: Fix this the next time the file is edited. diff --git a/api/tests/unit/domain/usecases/get-organization-members-identity_test.js b/api/tests/unit/domain/usecases/get-organization-members-identity_test.js index 352663eb1ff..0b7406fd6c5 100644 --- a/api/tests/unit/domain/usecases/get-organization-members-identity_test.js +++ b/api/tests/unit/domain/usecases/get-organization-members-identity_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const getOrganizationMemberIdentities = require('../../../../lib/domain/usecases/get-organization-members-identity'); -const OrganizationMemberIdentity = require('../../../../lib/domain/models/OrganizationMemberIdentity'); +import { expect, sinon } from '../../../test-helper.js'; +import { getOrganizationMemberIdentities } from '../../../../lib/domain/usecases/get-organization-members-identity.js'; +import { OrganizationMemberIdentity } from '../../../../lib/domain/models/OrganizationMemberIdentity.js'; describe('Unit | UseCase | get-organization-members', function () { let organizationMemberIdentityRepository; diff --git a/api/tests/unit/domain/usecases/get-paginated-participants-for-an-organization_test.js b/api/tests/unit/domain/usecases/get-paginated-participants-for-an-organization_test.js index 7a15f909c65..e5d15cf4d35 100644 --- a/api/tests/unit/domain/usecases/get-paginated-participants-for-an-organization_test.js +++ b/api/tests/unit/domain/usecases/get-paginated-participants-for-an-organization_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const getPaginatedParticipantsForAnOrganization = require('../../../../lib/domain/usecases/get-paginated-participants-for-an-organization'); +import { expect, sinon } from '../../../test-helper.js'; +import { getPaginatedParticipantsForAnOrganization } from '../../../../lib/domain/usecases/get-paginated-participants-for-an-organization.js'; describe('Unit | UseCase | get-participants-by-organization-id', function () { it('should call organizationParticipantRepository', async function () { diff --git a/api/tests/unit/domain/usecases/get-participations-count-by-mastery-rate_test.js b/api/tests/unit/domain/usecases/get-participations-count-by-mastery-rate_test.js index ef73c8bf5a8..036e8c3d765 100644 --- a/api/tests/unit/domain/usecases/get-participations-count-by-mastery-rate_test.js +++ b/api/tests/unit/domain/usecases/get-participations-count-by-mastery-rate_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const getParticipationsCountByMasteryRate = require('../../../../lib/domain/usecases/get-participations-count-by-mastery-rate'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { getParticipationsCountByMasteryRate } from '../../../../lib/domain/usecases/get-participations-count-by-mastery-rate.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | getParticipationsCountByMasteryRate', function () { context('when the user has access to the campaign', function () { diff --git a/api/tests/unit/domain/usecases/get-prescriber_test.js b/api/tests/unit/domain/usecases/get-prescriber_test.js index b51de841c35..f7982bff5cb 100644 --- a/api/tests/unit/domain/usecases/get-prescriber_test.js +++ b/api/tests/unit/domain/usecases/get-prescriber_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const getPrescriber = require('../../../../lib/domain/usecases/get-prescriber'); -const { UserNotMemberOfOrganizationError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { getPrescriber } from '../../../../lib/domain/usecases/get-prescriber.js'; +import { UserNotMemberOfOrganizationError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-prescriber', function () { const userId = 1; diff --git a/api/tests/unit/domain/usecases/get-private-certificate_test.js b/api/tests/unit/domain/usecases/get-private-certificate_test.js index bfcd2f3a97d..0f12238288a 100644 --- a/api/tests/unit/domain/usecases/get-private-certificate_test.js +++ b/api/tests/unit/domain/usecases/get-private-certificate_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const getPrivateCertificate = require('../../../../lib/domain/usecases/certificate/get-private-certificate'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import { getPrivateCertificate } from '../../../../lib/domain/usecases/certificate/get-private-certificate.js'; describe('Unit | UseCase | getPrivateCertificate', function () { const certificateRepository = { diff --git a/api/tests/unit/domain/usecases/get-progression_test.js b/api/tests/unit/domain/usecases/get-progression_test.js index a8e64ead3ec..85270b78059 100644 --- a/api/tests/unit/domain/usecases/get-progression_test.js +++ b/api/tests/unit/domain/usecases/get-progression_test.js @@ -1,9 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getProgression = require('../../../../lib/domain/usecases/get-progression'); - -const Assessment = require('../../../../lib/domain/models/Assessment'); - -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getProgression } from '../../../../lib/domain/usecases/get-progression.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | Domain | Use Cases | get-progression', function () { const assessmentId = 1234; diff --git a/api/tests/unit/domain/usecases/get-sco-certification-results-by-division_test.js b/api/tests/unit/domain/usecases/get-sco-certification-results-by-division_test.js index 24523f1a58f..3fd03a07dcf 100644 --- a/api/tests/unit/domain/usecases/get-sco-certification-results-by-division_test.js +++ b/api/tests/unit/domain/usecases/get-sco-certification-results-by-division_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getScoCertificationResultsByDivision = require('../../../../lib/domain/usecases/get-sco-certification-results-by-division'); -const { NoCertificationResultForDivision } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getScoCertificationResultsByDivision } from '../../../../lib/domain/usecases/get-sco-certification-results-by-division.js'; +import { NoCertificationResultForDivision } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-sco-certification-results-by-division', function () { const scoCertificationCandidateRepository = { findIdsByOrganizationIdAndDivision: null }; diff --git a/api/tests/unit/domain/usecases/get-scorecard_test.js b/api/tests/unit/domain/usecases/get-scorecard_test.js index 3e3adc734c9..46bb81cbd71 100644 --- a/api/tests/unit/domain/usecases/get-scorecard_test.js +++ b/api/tests/unit/domain/usecases/get-scorecard_test.js @@ -1,7 +1,7 @@ -const { sinon, expect } = require('../../../test-helper'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); -const getScorecard = require('../../../../lib/domain/usecases/get-scorecard'); +import { sinon, expect } from '../../../test-helper.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; +import { getScorecard } from '../../../../lib/domain/usecases/get-scorecard.js'; describe('Unit | UseCase | get-scorecard', function () { let scorecardService; diff --git a/api/tests/unit/domain/usecases/get-session-certification-candidates_test.js b/api/tests/unit/domain/usecases/get-session-certification-candidates_test.js index a9875a00047..f4d5c8335f9 100644 --- a/api/tests/unit/domain/usecases/get-session-certification-candidates_test.js +++ b/api/tests/unit/domain/usecases/get-session-certification-candidates_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const getSessionCertificationCandidates = require('../../../../lib/domain/usecases/get-session-certification-candidates'); +import { expect, sinon } from '../../../test-helper.js'; +import { getSessionCertificationCandidates } from '../../../../lib/domain/usecases/get-session-certification-candidates.js'; describe('Unit | Domain | Use Cases | get-session-certification-candidates', function () { const sessionId = 'sessionId'; diff --git a/api/tests/unit/domain/usecases/get-session-certification-reports_test.js b/api/tests/unit/domain/usecases/get-session-certification-reports_test.js index d87e051149a..bbccc095623 100644 --- a/api/tests/unit/domain/usecases/get-session-certification-reports_test.js +++ b/api/tests/unit/domain/usecases/get-session-certification-reports_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const getSessionCertificationReports = require('../../../../lib/domain/usecases/get-session-certification-reports'); +import { expect, sinon } from '../../../test-helper.js'; +import { getSessionCertificationReports } from '../../../../lib/domain/usecases/get-session-certification-reports.js'; describe('Unit | Domain | Use Cases | get-session-certification-reports', function () { it('should return the certification reports', async function () { diff --git a/api/tests/unit/domain/usecases/get-session-for-supervising_test.js b/api/tests/unit/domain/usecases/get-session-for-supervising_test.js index 91cf91b7173..80130931272 100644 --- a/api/tests/unit/domain/usecases/get-session-for-supervising_test.js +++ b/api/tests/unit/domain/usecases/get-session-for-supervising_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getSessionForSupervising = require('../../../../lib/domain/usecases/get-session-for-supervising'); -const { constants } = require('../../../../lib/domain/constants'); -const dayjs = require('dayjs'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getSessionForSupervising } from '../../../../lib/domain/usecases/get-session-for-supervising.js'; +import { constants } from '../../../../lib/domain/constants.js'; +import dayjs from 'dayjs'; const START_DATETIME_STUB = new Date('2022-10-01T13:00:00Z'); const COMPLEMENTARY_EXTRATIME_STUB = 45; diff --git a/api/tests/unit/domain/usecases/get-session-results-by-result-recipient-email_test.js b/api/tests/unit/domain/usecases/get-session-results-by-result-recipient-email_test.js index f3397da9c9c..9cb647df02a 100644 --- a/api/tests/unit/domain/usecases/get-session-results-by-result-recipient-email_test.js +++ b/api/tests/unit/domain/usecases/get-session-results-by-result-recipient-email_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getSessionResultsByResultRecipientEmail = require('../../../../lib/domain/usecases/get-session-results-by-result-recipient-email'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getSessionResultsByResultRecipientEmail } from '../../../../lib/domain/usecases/get-session-results-by-result-recipient-email.js'; describe('Unit | Domain | Use Cases | get-session-results-by-result-recipient-email', function () { const sessionRepository = { getWithCertificationCandidates: null }; diff --git a/api/tests/unit/domain/usecases/get-session-results_test.js b/api/tests/unit/domain/usecases/get-session-results_test.js index 187a05b8186..ba3d72933c7 100644 --- a/api/tests/unit/domain/usecases/get-session-results_test.js +++ b/api/tests/unit/domain/usecases/get-session-results_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getSessionResults = require('../../../../lib/domain/usecases/get-session-results'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getSessionResults } from '../../../../lib/domain/usecases/get-session-results.js'; describe('Unit | Domain | Use Cases | get-session-results', function () { const sessionRepository = { get: null }; diff --git a/api/tests/unit/domain/usecases/get-session_test.js b/api/tests/unit/domain/usecases/get-session_test.js index de43983ef94..0fe9d7e6840 100644 --- a/api/tests/unit/domain/usecases/get-session_test.js +++ b/api/tests/unit/domain/usecases/get-session_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const getSession = require('../../../../lib/domain/usecases/get-session'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { getSession } from '../../../../lib/domain/usecases/get-session.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-session', function () { let sessionRepository; diff --git a/api/tests/unit/domain/usecases/get-shareable-certificate_test.js b/api/tests/unit/domain/usecases/get-shareable-certificate_test.js index b120394aa90..298cb71016a 100644 --- a/api/tests/unit/domain/usecases/get-shareable-certificate_test.js +++ b/api/tests/unit/domain/usecases/get-shareable-certificate_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const getCertificationByVerificationCode = require('../../../../lib/domain/usecases/certificate/get-shareable-certificate'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { getShareableCertificate as getCertificationByVerificationCode } from '../../../../lib/domain/usecases/certificate/get-shareable-certificate.js'; describe('Unit | UseCase | get-shareable-certificate', function () { const certificateRepository = { diff --git a/api/tests/unit/domain/usecases/get-supervisor-kit-session-info_test.js b/api/tests/unit/domain/usecases/get-supervisor-kit-session-info_test.js index 80972819d2e..6248aa45dc3 100644 --- a/api/tests/unit/domain/usecases/get-supervisor-kit-session-info_test.js +++ b/api/tests/unit/domain/usecases/get-supervisor-kit-session-info_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getSupervisorKitSessionInfo = require('../../../../lib/domain/usecases/get-supervisor-kit-session-info'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const SessionForSupervisorKit = require('../../../../lib/domain/read-models/SessionForSupervisorKit'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getSupervisorKitSessionInfo } from '../../../../lib/domain/usecases/get-supervisor-kit-session-info.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { SessionForSupervisorKit } from '../../../../lib/domain/read-models/SessionForSupervisorKit.js'; describe('Unit | UseCase | get-supervisor-kit-main-info', function () { describe('getSupervisorKitSessionInfo', function () { diff --git a/api/tests/unit/domain/usecases/get-target-profile-content-as-json_test.js b/api/tests/unit/domain/usecases/get-target-profile-content-as-json_test.js index be04f26f4a6..682df7c3a64 100644 --- a/api/tests/unit/domain/usecases/get-target-profile-content-as-json_test.js +++ b/api/tests/unit/domain/usecases/get-target-profile-content-as-json_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder, MockDate } = require('../../../test-helper'); -const { ForbiddenAccess } = require('../../../../lib/domain/errors'); -const getTargetProfileContentAsJson = require('../../../../lib/domain/usecases/get-target-profile-content-as-json'); +import { expect, sinon, catchErr, domainBuilder, MockDate } from '../../../test-helper.js'; +import { ForbiddenAccess } from '../../../../lib/domain/errors.js'; +import { getTargetProfileContentAsJson } from '../../../../lib/domain/usecases/get-target-profile-content-as-json.js'; describe('Unit | UseCase | get-target-profile-content-as-json', function () { let targetProfileForAdminRepository; diff --git a/api/tests/unit/domain/usecases/get-target-profile-for-admin_test.js b/api/tests/unit/domain/usecases/get-target-profile-for-admin_test.js index 55229bbb617..b9be6512cbc 100644 --- a/api/tests/unit/domain/usecases/get-target-profile-for-admin_test.js +++ b/api/tests/unit/domain/usecases/get-target-profile-for-admin_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | get-target-profile-for-admin', function () { it('should get target profile for admin', async function () { diff --git a/api/tests/unit/domain/usecases/get-training_test.js b/api/tests/unit/domain/usecases/get-training_test.js index b8c9d3c8bc3..2a17caebec4 100644 --- a/api/tests/unit/domain/usecases/get-training_test.js +++ b/api/tests/unit/domain/usecases/get-training_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const getTraining = require('../../../../lib/domain/usecases/get-training'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { getTraining } from '../../../../lib/domain/usecases/get-training.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-training', function () { let trainingRepository; diff --git a/api/tests/unit/domain/usecases/get-user-by-reset-password-demand_test.js b/api/tests/unit/domain/usecases/get-user-by-reset-password-demand_test.js index b655f6aaee9..9ff7292b716 100644 --- a/api/tests/unit/domain/usecases/get-user-by-reset-password-demand_test.js +++ b/api/tests/unit/domain/usecases/get-user-by-reset-password-demand_test.js @@ -1,13 +1,13 @@ -const { catchErr, domainBuilder, expect, sinon } = require('../../../test-helper'); +import { catchErr, domainBuilder, expect, sinon } from '../../../test-helper.js'; +import { User } from '../../../../lib/domain/models/User.js'; -const User = require('../../../../lib/domain/models/User'); -const { +import { InvalidTemporaryKeyError, PasswordResetDemandNotFoundError, UserNotFoundError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; -const getUserByResetPasswordDemand = require('../../../../lib/domain/usecases/get-user-by-reset-password-demand'); +import { getUserByResetPasswordDemand } from '../../../../lib/domain/usecases/get-user-by-reset-password-demand.js'; describe('Unit | UseCase | get-user-by-reset-password-demand', function () { const temporaryKey = 'ABCDEF123'; diff --git a/api/tests/unit/domain/usecases/get-user-campaign-assessment-result_test.js b/api/tests/unit/domain/usecases/get-user-campaign-assessment-result_test.js index 46dd7f10848..61fd4677525 100644 --- a/api/tests/unit/domain/usecases/get-user-campaign-assessment-result_test.js +++ b/api/tests/unit/domain/usecases/get-user-campaign-assessment-result_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getUserCampaignAssessmentResult = require('../../../../lib/domain/usecases/get-user-campaign-assessment-result'); -const { NotFoundError, NoCampaignParticipationForUserAndCampaign } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getUserCampaignAssessmentResult } from '../../../../lib/domain/usecases/get-user-campaign-assessment-result.js'; +import { NotFoundError, NoCampaignParticipationForUserAndCampaign } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | get-user-campaign-assessment-result', function () { const locale = 'locale', diff --git a/api/tests/unit/domain/usecases/get-user-certification-eligibility_test.js b/api/tests/unit/domain/usecases/get-user-certification-eligibility_test.js index 8c1b6df5da4..90aa626ff53 100644 --- a/api/tests/unit/domain/usecases/get-user-certification-eligibility_test.js +++ b/api/tests/unit/domain/usecases/get-user-certification-eligibility_test.js @@ -1,5 +1,5 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const getUserCertificationEligibility = require('../../../../lib/domain/usecases/get-user-certification-eligibility'); +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { getUserCertificationEligibility } from '../../../../lib/domain/usecases/get-user-certification-eligibility.js'; describe('Unit | UseCase | get-user-certification-eligibility', function () { let clock; diff --git a/api/tests/unit/domain/usecases/get-user-details-for-admin_test.js b/api/tests/unit/domain/usecases/get-user-details-for-admin_test.js index df26ba9fee3..4db6e331c9e 100644 --- a/api/tests/unit/domain/usecases/get-user-details-for-admin_test.js +++ b/api/tests/unit/domain/usecases/get-user-details-for-admin_test.js @@ -1,6 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); - -const getUserDetailsForAdmin = require('../../../../lib/domain/usecases/get-user-details-for-admin'); +import { expect, sinon } from '../../../test-helper.js'; +import { getUserDetailsForAdmin } from '../../../../lib/domain/usecases/get-user-details-for-admin.js'; describe('Unit | UseCase | get-user-details-for-admin', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/get-user-profile-shared-for-campaign_test.js b/api/tests/unit/domain/usecases/get-user-profile-shared-for-campaign_test.js index 7a44e438c75..52e951b5098 100644 --- a/api/tests/unit/domain/usecases/get-user-profile-shared-for-campaign_test.js +++ b/api/tests/unit/domain/usecases/get-user-profile-shared-for-campaign_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const getUserProfileSharedForCampaign = require('../../../../lib/domain/usecases/get-user-profile-shared-for-campaign'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); -const { NoCampaignParticipationForUserAndCampaign } = require('../../../../lib/domain/errors'); -const { constants } = require('../../../../lib/domain/constants'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { getUserProfileSharedForCampaign } from '../../../../lib/domain/usecases/get-user-profile-shared-for-campaign.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; +import { NoCampaignParticipationForUserAndCampaign } from '../../../../lib/domain/errors.js'; +import { constants } from '../../../../lib/domain/constants.js'; describe('Unit | UseCase | get-user-profile-shared-for-campaign', function () { const sharedAt = new Date('2020-02-01'); diff --git a/api/tests/unit/domain/usecases/get-user-profile_test.js b/api/tests/unit/domain/usecases/get-user-profile_test.js index 8b81cfa21cb..20e077d131f 100644 --- a/api/tests/unit/domain/usecases/get-user-profile_test.js +++ b/api/tests/unit/domain/usecases/get-user-profile_test.js @@ -1,8 +1,8 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); -const getUserProfile = require('../../../../lib/domain/usecases/get-user-profile'); -const { constants } = require('../../../../lib/domain/constants'); -const _ = require('lodash'); +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; +import { getUserProfile } from '../../../../lib/domain/usecases/get-user-profile.js'; +import { constants } from '../../../../lib/domain/constants.js'; +import _ from 'lodash'; function assertScorecard(userScorecard, expectedUserScorecard) { expect(userScorecard.earnedPix).to.equal(expectedUserScorecard.earnedPix); diff --git a/api/tests/unit/domain/usecases/handle-badge-acquisition_test.js b/api/tests/unit/domain/usecases/handle-badge-acquisition_test.js index e6d9c04caff..6441b391288 100644 --- a/api/tests/unit/domain/usecases/handle-badge-acquisition_test.js +++ b/api/tests/unit/domain/usecases/handle-badge-acquisition_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const handleBadgeAcquisition = require('../../../../lib/domain/usecases/handle-badge-acquisition'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { handleBadgeAcquisition } from '../../../../lib/domain/usecases/handle-badge-acquisition.js'; describe('Unit | UseCase | handle-badge-acquisition', function () { let domainTransaction; diff --git a/api/tests/unit/domain/usecases/handle-training-recommendation_test.js b/api/tests/unit/domain/usecases/handle-training-recommendation_test.js index a60b8ffa28b..01a180f0aab 100644 --- a/api/tests/unit/domain/usecases/handle-training-recommendation_test.js +++ b/api/tests/unit/domain/usecases/handle-training-recommendation_test.js @@ -1,5 +1,5 @@ -const handleTrainingRecommendation = require('../../../../lib/domain/usecases/handle-training-recommendation'); -const { expect, sinon, domainBuilder } = require('../../../test-helper'); +import { handleTrainingRecommendation } from '../../../../lib/domain/usecases/handle-training-recommendation.js'; +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; describe('Unit | UseCase | handle-training-recommendation', function () { let trainingRepository; diff --git a/api/tests/unit/domain/usecases/import-certification-candidates-from-candidates-import-sheet_test.js b/api/tests/unit/domain/usecases/import-certification-candidates-from-candidates-import-sheet_test.js index afdf6b4d581..d289ec3f555 100644 --- a/api/tests/unit/domain/usecases/import-certification-candidates-from-candidates-import-sheet_test.js +++ b/api/tests/unit/domain/usecases/import-certification-candidates-from-candidates-import-sheet_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { CertificationCandidateAlreadyLinkedToUserError } = require('../../../../lib/domain/errors'); -const importCertificationCandidatesFromCandidatesImportSheet = require('../../../../lib/domain/usecases/import-certification-candidates-from-candidates-import-sheet'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { CertificationCandidateAlreadyLinkedToUserError } from '../../../../lib/domain/errors.js'; +import { importCertificationCandidatesFromCandidatesImportSheet } from '../../../../lib/domain/usecases/import-certification-candidates-from-candidates-import-sheet.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; const i18n = getI18n(); describe('Unit | UseCase | import-certification-candidates-from-attendance-sheet', function () { diff --git a/api/tests/unit/domain/usecases/import-organization-learners-from-siecle_test.js b/api/tests/unit/domain/usecases/import-organization-learners-from-siecle_test.js index b3ee9db5392..62aab381fba 100644 --- a/api/tests/unit/domain/usecases/import-organization-learners-from-siecle_test.js +++ b/api/tests/unit/domain/usecases/import-organization-learners-from-siecle_test.js @@ -1,13 +1,11 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const importOrganizationLearnersFromSIECLEFormat = require('../../../../lib/domain/usecases/import-organization-learners-from-siecle'); -const { FileValidationError, SiecleXmlImportError } = require('../../../../lib/domain/errors'); -const DomainTransaction = require('../../../../lib/infrastructure/DomainTransaction'); - -const OrganizationLearner = require('../../../../lib/domain/models/OrganizationLearner'); - -const fs = require('fs').promises; - -const { getI18n } = require('../../../tooling/i18n/i18n'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { importOrganizationLearnersFromSIECLEFormat } from '../../../../lib/domain/usecases/import-organization-learners-from-siecle.js'; +import { FileValidationError, SiecleXmlImportError } from '../../../../lib/domain/errors.js'; +import { DomainTransaction } from '../../../../lib/infrastructure/DomainTransaction.js'; +import { OrganizationLearner } from '../../../../lib/domain/models/OrganizationLearner.js'; +import fs from 'fs/promises'; + +import { getI18n } from '../../../tooling/i18n/i18n.js'; const i18n = getI18n(); describe('Unit | UseCase | import-organization-learners-from-siecle', function () { diff --git a/api/tests/unit/domain/usecases/improve-competence-evaluation_test.js b/api/tests/unit/domain/usecases/improve-competence-evaluation_test.js index 6e4db6ff8ef..bcd4c34bf6d 100644 --- a/api/tests/unit/domain/usecases/improve-competence-evaluation_test.js +++ b/api/tests/unit/domain/usecases/improve-competence-evaluation_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const improveCompetenceEvaluation = require('../../../../lib/domain/usecases/improve-competence-evaluation'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const { MAX_REACHABLE_LEVEL } = require('../../../../lib/domain/constants'); -const { ImproveCompetenceEvaluationForbiddenError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { improveCompetenceEvaluation } from '../../../../lib/domain/usecases/improve-competence-evaluation.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { MAX_REACHABLE_LEVEL } from '../../../../lib/domain/constants.js'; +import { ImproveCompetenceEvaluationForbiddenError } from '../../../../lib/domain/errors.js'; const domainTransaction = Symbol('DomainTransaction'); diff --git a/api/tests/unit/domain/usecases/link-user-to-session-certification-candidate_test.js b/api/tests/unit/domain/usecases/link-user-to-session-certification-candidate_test.js index 1c8e4e97977..dbae63ba0e8 100644 --- a/api/tests/unit/domain/usecases/link-user-to-session-certification-candidate_test.js +++ b/api/tests/unit/domain/usecases/link-user-to-session-certification-candidate_test.js @@ -1,15 +1,17 @@ -const { catchErr, expect, sinon, domainBuilder } = require('../../../test-helper'); -const linkUserToSessionCertificationCandidate = require('../../../../lib/domain/usecases/link-user-to-session-certification-candidate'); -const { +import { catchErr, expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { linkUserToSessionCertificationCandidate } from '../../../../lib/domain/usecases/link-user-to-session-certification-candidate.js'; + +import { CertificationCandidateByPersonalInfoNotFoundError, MatchingReconciledStudentNotFoundError, CertificationCandidateByPersonalInfoTooManyMatchesError, UserAlreadyLinkedToCandidateInSessionError, SessionNotAccessible, UnexpectedUserAccountError, -} = require('../../../../lib/domain/errors'); -const UserLinkedToCertificationCandidate = require('../../../../lib/domain/events/UserLinkedToCertificationCandidate'); -const UserAlreadyLinkedToCertificationCandidate = require('../../../../lib/domain/events/UserAlreadyLinkedToCertificationCandidate'); +} from '../../../../lib/domain/errors.js'; + +import { UserLinkedToCertificationCandidate } from '../../../../lib/domain/events/UserLinkedToCertificationCandidate.js'; +import { UserAlreadyLinkedToCertificationCandidate } from '../../../../lib/domain/events/UserAlreadyLinkedToCertificationCandidate.js'; describe('Unit | Domain | Use Cases | link-user-to-session-certification-candidate', function () { const sessionId = 42; diff --git a/api/tests/unit/domain/usecases/manually-resolve-certification-issue-report_test.js b/api/tests/unit/domain/usecases/manually-resolve-certification-issue-report_test.js index 489a04ecebb..273dcaafab8 100644 --- a/api/tests/unit/domain/usecases/manually-resolve-certification-issue-report_test.js +++ b/api/tests/unit/domain/usecases/manually-resolve-certification-issue-report_test.js @@ -1,8 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const manuallyResolveCertificationIssueReport = require('../../../../lib/domain/usecases/manually-resolve-certification-issue-report'); -const { - CertificationIssueReportAutomaticallyResolvedShouldNotBeUpdatedManually, -} = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { manuallyResolveCertificationIssueReport } from '../../../../lib/domain/usecases/manually-resolve-certification-issue-report.js'; +import { CertificationIssueReportAutomaticallyResolvedShouldNotBeUpdatedManually } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | manually-resolve-certification-issue-report', function () { describe('when certification issue report is not resolved', function () { diff --git a/api/tests/unit/domain/usecases/mark-target-profile-as-simplified-access_test.js b/api/tests/unit/domain/usecases/mark-target-profile-as-simplified-access_test.js index 447f1c02fa3..a0cc8276735 100644 --- a/api/tests/unit/domain/usecases/mark-target-profile-as-simplified-access_test.js +++ b/api/tests/unit/domain/usecases/mark-target-profile-as-simplified-access_test.js @@ -1,5 +1,7 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const { markTargetProfileAsSimplifiedAccess } = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; + +const { markTargetProfileAsSimplifiedAccess } = usecases; describe('Unit | UseCase | mark-target-profile-as-simplified-access', function () { it('should call repository method to update "isSimplifiedAccess" in target profile', async function () { diff --git a/api/tests/unit/domain/usecases/neutralize-challenge_test.js b/api/tests/unit/domain/usecases/neutralize-challenge_test.js index ba2e796a327..327c2776754 100644 --- a/api/tests/unit/domain/usecases/neutralize-challenge_test.js +++ b/api/tests/unit/domain/usecases/neutralize-challenge_test.js @@ -1,7 +1,7 @@ -const { sinon, expect, domainBuilder } = require('../../../test-helper'); -const CertificationAssessment = require('../../../../lib/domain/models/CertificationAssessment'); -const neutralizeChallenge = require('../../../../lib/domain/usecases/neutralize-challenge'); -const ChallengeNeutralized = require('../../../../lib/domain/events/ChallengeNeutralized'); +import { sinon, expect, domainBuilder } from '../../../test-helper.js'; +import { CertificationAssessment } from '../../../../lib/domain/models/CertificationAssessment.js'; +import { neutralizeChallenge } from '../../../../lib/domain/usecases/neutralize-challenge.js'; +import { ChallengeNeutralized } from '../../../../lib/domain/events/ChallengeNeutralized.js'; describe('Unit | UseCase | neutralize-challenge', function () { it('neutralizes a challenge by its recId', async function () { diff --git a/api/tests/unit/domain/usecases/organizations-administration/update-organization-information_test.js b/api/tests/unit/domain/usecases/organizations-administration/update-organization-information_test.js index 6c75051ccd8..06873d469dd 100644 --- a/api/tests/unit/domain/usecases/organizations-administration/update-organization-information_test.js +++ b/api/tests/unit/domain/usecases/organizations-administration/update-organization-information_test.js @@ -1,10 +1,11 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../../test-helper'); -const { updateOrganizationInformation } = require('../../../../../lib/domain/usecases/index.js'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); -const Tag = require('../../../../../lib/domain/models/Tag'); -const OrganizationTag = require('../../../../../lib/domain/models/OrganizationTag'); -const OrganizationForAdmin = require('../../../../../lib/domain/models/organizations-administration/Organization'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); +import { expect, sinon, catchErr, domainBuilder } from '../../../../test-helper.js'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; +import { Tag } from '../../../../../lib/domain/models/Tag.js'; +import { OrganizationTag } from '../../../../../lib/domain/models/OrganizationTag.js'; +import { OrganizationForAdmin } from '../../../../../lib/domain/models/organizations-administration/Organization.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; +import { usecases } from '../../../../../lib/domain/usecases/index.js'; +const { updateOrganizationInformation } = usecases; describe('Unit | UseCase | organizations-administration | update-organization-information', function () { let dataProtectionOfficerRepository; @@ -31,7 +32,7 @@ describe('Unit | UseCase | organizations-administration | update-organization-in }; organizationTagRepository = { create: sinon.stub(), - delete: sinon.stub(), + remove: sinon.stub(), findOneByOrganizationIdAndTagId: sinon.stub(), }; tagRepository = { @@ -436,7 +437,7 @@ describe('Unit | UseCase | organizations-administration | update-organization-in // given const organizationTagToAdd = new OrganizationTag({ organizationId, tagId }); expect(organizationTagRepository.create).to.have.been.calledWith(organizationTagToAdd); - expect(organizationTagRepository.delete).to.have.not.been.called; + expect(organizationTagRepository.remove).to.have.not.been.called; }); it('should allow to unassign a tag to organization', async function () { @@ -477,7 +478,7 @@ describe('Unit | UseCase | organizations-administration | update-organization-in }); // given - expect(organizationTagRepository.delete).to.have.been.calledWith({ + expect(organizationTagRepository.remove).to.have.been.calledWith({ organizationTagId: organizationTagToRemove.id, }); expect(organizationTagRepository.create).to.have.not.been.called; diff --git a/api/tests/unit/domain/usecases/outdate-target-profile_test.js b/api/tests/unit/domain/usecases/outdate-target-profile_test.js index b0c638804f6..1b5758614a1 100644 --- a/api/tests/unit/domain/usecases/outdate-target-profile_test.js +++ b/api/tests/unit/domain/usecases/outdate-target-profile_test.js @@ -1,5 +1,7 @@ -const { expect, sinon } = require('../../../test-helper'); -const { outdateTargetProfile } = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; + +const { outdateTargetProfile } = usecases; describe('Unit | UseCase | outdate-target-profile', function () { it('should call repository method to update a target profile name', async function () { diff --git a/api/tests/unit/domain/usecases/publish-session_test.js b/api/tests/unit/domain/usecases/publish-session_test.js index 37197da1e70..bd25eeb5dcb 100644 --- a/api/tests/unit/domain/usecases/publish-session_test.js +++ b/api/tests/unit/domain/usecases/publish-session_test.js @@ -1,6 +1,5 @@ -const { sinon, expect } = require('../../../test-helper'); - -const publishSession = require('../../../../lib/domain/usecases/publish-session'); +import { sinon, expect } from '../../../test-helper.js'; +import { publishSession } from '../../../../lib/domain/usecases/publish-session.js'; describe('Unit | UseCase | publish-session', function () { it('delegates the action to the session-publication-service and return the session', async function () { diff --git a/api/tests/unit/domain/usecases/publish-sessions-in-batch_test.js b/api/tests/unit/domain/usecases/publish-sessions-in-batch_test.js index 0fbda06363a..6138153bb47 100644 --- a/api/tests/unit/domain/usecases/publish-sessions-in-batch_test.js +++ b/api/tests/unit/domain/usecases/publish-sessions-in-batch_test.js @@ -1,6 +1,5 @@ -const { sinon, expect } = require('../../../test-helper'); - -const publishSessionsInBatch = require('../../../../lib/domain/usecases/publish-sessions-in-batch'); +import { sinon, expect } from '../../../test-helper.js'; +import { publishSessionsInBatch } from '../../../../lib/domain/usecases/publish-sessions-in-batch.js'; describe('Unit | UseCase | publish-sessions-in-batch', function () { let sessionPublicationService; diff --git a/api/tests/unit/domain/usecases/reassign-authentication-method-to-another-user_test.js b/api/tests/unit/domain/usecases/reassign-authentication-method-to-another-user_test.js index 6ff4f5cfb95..3ae34974bc8 100644 --- a/api/tests/unit/domain/usecases/reassign-authentication-method-to-another-user_test.js +++ b/api/tests/unit/domain/usecases/reassign-authentication-method-to-another-user_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const reassignAuthenticationMethodToAnotherUser = require('../../../../lib/domain/usecases/reassign-authentication-method-to-another-user'); -const { AuthenticationMethodAlreadyExistsError, UserNotFoundError } = require('../../../../lib/domain/errors'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { reassignAuthenticationMethodToAnotherUser } from '../../../../lib/domain/usecases/reassign-authentication-method-to-another-user.js'; +import { AuthenticationMethodAlreadyExistsError, UserNotFoundError } from '../../../../lib/domain/errors.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; describe('Unit | UseCase | reassign-authentication-method-to-another-user', function () { let authenticationMethodRepository, userRepository; diff --git a/api/tests/unit/domain/usecases/reconcile-oidc-user_test.js b/api/tests/unit/domain/usecases/reconcile-oidc-user_test.js index 7844a3df1b1..959ea023890 100644 --- a/api/tests/unit/domain/usecases/reconcile-oidc-user_test.js +++ b/api/tests/unit/domain/usecases/reconcile-oidc-user_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const reconcileOidcUser = require('../../../../lib/domain/usecases/reconcile-oidc-user'); -const { AuthenticationKeyExpired, MissingUserAccountError } = require('../../../../lib/domain/errors'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { reconcileOidcUser } from '../../../../lib/domain/usecases/reconcile-oidc-user.js'; +import { AuthenticationKeyExpired, MissingUserAccountError } from '../../../../lib/domain/errors.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; describe('Unit | UseCase | reconcile-oidc-user', function () { let authenticationMethodRepository, userRepository, authenticationSessionService, oidcAuthenticationService; diff --git a/api/tests/unit/domain/usecases/reconcile-sco-organization-learner-automatically_test.js b/api/tests/unit/domain/usecases/reconcile-sco-organization-learner-automatically_test.js index 8a2dc35e340..68575c5c877 100644 --- a/api/tests/unit/domain/usecases/reconcile-sco-organization-learner-automatically_test.js +++ b/api/tests/unit/domain/usecases/reconcile-sco-organization-learner-automatically_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const reconcileScoOrganizationLearnerAutomatically = require('../../../../lib/domain/usecases/reconcile-sco-organization-learner-automatically.js'); -const OrganizationLearner = require('../../../../lib/domain/models/OrganizationLearner'); -const { CampaignCodeError, UserCouldNotBeReconciledError } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { reconcileScoOrganizationLearnerAutomatically } from '../../../../lib/domain/usecases/reconcile-sco-organization-learner-automatically.js'; +import { OrganizationLearner } from '../../../../lib/domain/models/OrganizationLearner.js'; +import { CampaignCodeError, UserCouldNotBeReconciledError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | reconcile-sco-organization-learner-automatically', function () { let reconcileUserByNationalStudentIdAndOrganizationIdStub; diff --git a/api/tests/unit/domain/usecases/reconcile-sco-organization-learner-manually_test.js b/api/tests/unit/domain/usecases/reconcile-sco-organization-learner-manually_test.js index bf10ba30f98..c18c329e041 100644 --- a/api/tests/unit/domain/usecases/reconcile-sco-organization-learner-manually_test.js +++ b/api/tests/unit/domain/usecases/reconcile-sco-organization-learner-manually_test.js @@ -1,13 +1,13 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const OrganizationLearner = require('../../../../lib/domain/models/OrganizationLearner'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { OrganizationLearner } from '../../../../lib/domain/models/OrganizationLearner.js'; -const { +import { CampaignCodeError, NotFoundError, OrganizationLearnerAlreadyLinkedToUserError, UserShouldNotBeReconciledOnAnotherAccountError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | reconcile-sco-organization-learner-manually', function () { let campaignCode; diff --git a/api/tests/unit/domain/usecases/remember-user-has-seen-assessment-instructions_test.js b/api/tests/unit/domain/usecases/remember-user-has-seen-assessment-instructions_test.js index a97ceda563b..15f0d99f0eb 100644 --- a/api/tests/unit/domain/usecases/remember-user-has-seen-assessment-instructions_test.js +++ b/api/tests/unit/domain/usecases/remember-user-has-seen-assessment-instructions_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const rememberUserHasSeenAssessmentInstructions = require('../../../../lib/domain/usecases/remember-user-has-seen-assessment-instructions'); +import { expect, sinon } from '../../../test-helper.js'; +import { rememberUserHasSeenAssessmentInstructions } from '../../../../lib/domain/usecases/remember-user-has-seen-assessment-instructions.js'; describe('Unit | UseCase | remember-user-has-seen-assessment-instructions', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/remember-user-has-seen-last-data-protection-policy-information_test.js b/api/tests/unit/domain/usecases/remember-user-has-seen-last-data-protection-policy-information_test.js index 958324f99ef..d501690ae75 100644 --- a/api/tests/unit/domain/usecases/remember-user-has-seen-last-data-protection-policy-information_test.js +++ b/api/tests/unit/domain/usecases/remember-user-has-seen-last-data-protection-policy-information_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const rememberUserHasSeenLastDataProtectionPolicyInformation = require('../../../../lib/domain/usecases/remember-user-has-seen-last-data-protection-policy-information'); -const User = require('../../../../lib/domain/models/User'); +import { expect, sinon } from '../../../test-helper.js'; +import { rememberUserHasSeenLastDataProtectionPolicyInformation } from '../../../../lib/domain/usecases/remember-user-has-seen-last-data-protection-policy-information.js'; +import { User } from '../../../../lib/domain/models/User.js'; describe('Unit | UseCase | remember-user-has-seen-data-protection-policy-information', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/remove-authentication-method_test.js b/api/tests/unit/domain/usecases/remove-authentication-method_test.js index 5bfdd725639..d52ed0e3a77 100644 --- a/api/tests/unit/domain/usecases/remove-authentication-method_test.js +++ b/api/tests/unit/domain/usecases/remove-authentication-method_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const removeAuthenticationMethod = require('../../../../lib/domain/usecases/remove-authentication-method'); -const { UserNotAuthorizedToRemoveAuthenticationMethod } = require('../../../../lib/domain/errors'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const OidcIdentityProviders = require('../../../../lib/domain/constants/oidc-identity-providers'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { removeAuthenticationMethod } from '../../../../lib/domain/usecases/remove-authentication-method.js'; +import { UserNotAuthorizedToRemoveAuthenticationMethod } from '../../../../lib/domain/errors.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import * as OidcIdentityProviders from '../../../../lib/domain/constants/oidc-identity-providers.js'; describe('Unit | UseCase | remove-authentication-method', function () { let userRepository; diff --git a/api/tests/unit/domain/usecases/replace-sup-organization-learners_test.js b/api/tests/unit/domain/usecases/replace-sup-organization-learners_test.js index 840421393ec..120e3d07d75 100644 --- a/api/tests/unit/domain/usecases/replace-sup-organization-learners_test.js +++ b/api/tests/unit/domain/usecases/replace-sup-organization-learners_test.js @@ -1,6 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); - -const replaceSupOrganizationLearners = require('../../../../lib/domain/usecases/replace-sup-organization-learner'); +import { expect, sinon } from '../../../test-helper.js'; +import { replaceSupOrganizationLearners } from '../../../../lib/domain/usecases/replace-sup-organization-learner.js'; describe('Unit | UseCase | ImportSupOrganizationLearner', function () { it('parses the csv received and replace the SupOrganizationLearner', async function () { diff --git a/api/tests/unit/domain/usecases/resend-organization-invitation_test.js b/api/tests/unit/domain/usecases/resend-organization-invitation_test.js index 24a245ef16a..d6c1822fe97 100644 --- a/api/tests/unit/domain/usecases/resend-organization-invitation_test.js +++ b/api/tests/unit/domain/usecases/resend-organization-invitation_test.js @@ -1,6 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); - -const resendOrganizationInvitation = require('../../../../lib/domain/usecases/resend-organization-invitation'); +import { expect, sinon } from '../../../test-helper.js'; +import { resendOrganizationInvitation } from '../../../../lib/domain/usecases/resend-organization-invitation.js'; describe('Unit | UseCase | resend-organization-invitation', function () { describe('#resendOrganizationInvitation', function () { diff --git a/api/tests/unit/domain/usecases/reset-scorecard_test.js b/api/tests/unit/domain/usecases/reset-scorecard_test.js index a1ac5f51781..2a3baf08913 100644 --- a/api/tests/unit/domain/usecases/reset-scorecard_test.js +++ b/api/tests/unit/domain/usecases/reset-scorecard_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const Scorecard = require('../../../../lib/domain/models/Scorecard'); -const resetScorecard = require('../../../../lib/domain/usecases/reset-scorecard'); -const { CompetenceResetError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { Scorecard } from '../../../../lib/domain/models/Scorecard.js'; +import { resetScorecard } from '../../../../lib/domain/usecases/reset-scorecard.js'; +import { CompetenceResetError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | reset-scorecard', function () { let knowledgeElements, resetScorecardResult, scorecard; diff --git a/api/tests/unit/domain/usecases/retrieve-last-or-create-certification-course_test.js b/api/tests/unit/domain/usecases/retrieve-last-or-create-certification-course_test.js index e00f3ec57b2..c666c4d7064 100644 --- a/api/tests/unit/domain/usecases/retrieve-last-or-create-certification-course_test.js +++ b/api/tests/unit/domain/usecases/retrieve-last-or-create-certification-course_test.js @@ -1,17 +1,19 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; + +import { UserNotAuthorizedToCertifyError, NotFoundError, SessionNotAccessible, CandidateNotAuthorizedToJoinSessionError, CandidateNotAuthorizedToResumeCertificationTestError, UnexpectedUserAccountError, -} = require('../../../../lib/domain/errors'); -const retrieveLastOrCreateCertificationCourse = require('../../../../lib/domain/usecases/retrieve-last-or-create-certification-course'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const CertificationCourse = require('../../../../lib/domain/models/CertificationCourse'); -const ComplementaryCertificationCourse = require('../../../../lib/domain/models/ComplementaryCertificationCourse'); -const _ = require('lodash'); +} from '../../../../lib/domain/errors.js'; + +import { retrieveLastOrCreateCertificationCourse } from '../../../../lib/domain/usecases/retrieve-last-or-create-certification-course.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { CertificationCourse } from '../../../../lib/domain/models/CertificationCourse.js'; +import { ComplementaryCertificationCourse } from '../../../../lib/domain/models/ComplementaryCertificationCourse.js'; +import _ from 'lodash'; describe('Unit | UseCase | retrieve-last-or-create-certification-course', function () { let clock; diff --git a/api/tests/unit/domain/usecases/revoke-refresh-token_test.js b/api/tests/unit/domain/usecases/revoke-refresh-token_test.js index ea17b2e45b2..6e9a2dd4f5c 100644 --- a/api/tests/unit/domain/usecases/revoke-refresh-token_test.js +++ b/api/tests/unit/domain/usecases/revoke-refresh-token_test.js @@ -1,5 +1,5 @@ -const revokeRefreshToken = require('../../../../lib/domain/usecases/revoke-refresh-token'); -const { expect, sinon } = require('../../../test-helper'); +import { revokeRefreshToken } from '../../../../lib/domain/usecases/revoke-refresh-token.js'; +import { expect, sinon } from '../../../test-helper.js'; describe('Unit | UseCase | revoke-refresh-token', function () { it('should revoke refresh token', async function () { diff --git a/api/tests/unit/domain/usecases/save-admin-member_test.js b/api/tests/unit/domain/usecases/save-admin-member_test.js index b6023fe904c..e7db6ced5e9 100644 --- a/api/tests/unit/domain/usecases/save-admin-member_test.js +++ b/api/tests/unit/domain/usecases/save-admin-member_test.js @@ -1,8 +1,11 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const saveAdminMember = require('../../../../lib/domain/usecases/save-admin-member'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; -const { AlreadyExistingAdminMemberError, UserNotFoundError } = require('../../../../lib/domain/errors'); -const AdminMember = require('../../../../lib/domain/models/AdminMember'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { saveAdminMember } from '../../../../lib/domain/usecases/save-admin-member.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; + +import { AlreadyExistingAdminMemberError, UserNotFoundError } from '../../../../lib/domain/errors.js'; +import { AdminMember } from '../../../../lib/domain/models/AdminMember.js'; describe('Unit | UseCase | save-admin-member', function () { context('when admin member email is not found', function () { diff --git a/api/tests/unit/domain/usecases/save-certification-issue-report_test.js b/api/tests/unit/domain/usecases/save-certification-issue-report_test.js index bbd39b26960..a3558b51b85 100644 --- a/api/tests/unit/domain/usecases/save-certification-issue-report_test.js +++ b/api/tests/unit/domain/usecases/save-certification-issue-report_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const saveCertificationIssueReport = require('../../../../lib/domain/usecases/save-certification-issue-report'); -const CertificationIssueReport = require('../../../../lib/domain/models/CertificationIssueReport'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { saveCertificationIssueReport } from '../../../../lib/domain/usecases/save-certification-issue-report.js'; +import { CertificationIssueReport } from '../../../../lib/domain/models/CertificationIssueReport.js'; describe('Unit | UseCase | save-certification-issue-report', function () { describe('#saveCertificationIssueReport', function () { diff --git a/api/tests/unit/domain/usecases/save-computed-campaign-participation-result_test.js b/api/tests/unit/domain/usecases/save-computed-campaign-participation-result_test.js index e395073e926..5b970f8ca98 100644 --- a/api/tests/unit/domain/usecases/save-computed-campaign-participation-result_test.js +++ b/api/tests/unit/domain/usecases/save-computed-campaign-participation-result_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const saveComputedCampaignParticipationResult = require('../../../../lib/domain/usecases/save-computed-campaign-participation-result'); +import { expect, sinon } from '../../../test-helper.js'; +import { saveComputedCampaignParticipationResult } from '../../../../lib/domain/usecases/save-computed-campaign-participation-result.js'; describe('Unit | Domain | UseCases | SaveComputedCompaignParticipationResult', function () { it('should compute results and save', async function () { diff --git a/api/tests/unit/domain/usecases/save-jury-complementary-certification-course-result_test.js b/api/tests/unit/domain/usecases/save-jury-complementary-certification-course-result_test.js index 24537749123..1550068741e 100644 --- a/api/tests/unit/domain/usecases/save-jury-complementary-certification-course-result_test.js +++ b/api/tests/unit/domain/usecases/save-jury-complementary-certification-course-result_test.js @@ -1,8 +1,7 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); - -const saveJuryComplementaryCertificationCourseResult = require('../../../../lib/domain/usecases/save-jury-complementary-certification-course-result'); -const { NotFoundError, InvalidJuryLevelError } = require('../../../../lib/domain/errors'); -const ComplementaryCertificationCourseResult = require('../../../../lib/domain/models/ComplementaryCertificationCourseResult'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { saveJuryComplementaryCertificationCourseResult } from '../../../../lib/domain/usecases/save-jury-complementary-certification-course-result.js'; +import { NotFoundError, InvalidJuryLevelError } from '../../../../lib/domain/errors.js'; +import { ComplementaryCertificationCourseResult } from '../../../../lib/domain/models/ComplementaryCertificationCourseResult.js'; describe('Unit | UseCase | save-jury-complementary-certification-course-results', function () { describe('#saveJuryComplementaryCertificationCourseResult', function () { diff --git a/api/tests/unit/domain/usecases/send-sco-invitation_test.js b/api/tests/unit/domain/usecases/send-sco-invitation_test.js index abcb7e2787a..6e5e50c4948 100644 --- a/api/tests/unit/domain/usecases/send-sco-invitation_test.js +++ b/api/tests/unit/domain/usecases/send-sco-invitation_test.js @@ -1,11 +1,12 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const sendScoInvitation = require('../../../../lib/domain/usecases/send-sco-invitation.js'); -const { +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { sendScoInvitation } from '../../../../lib/domain/usecases/send-sco-invitation.js'; + +import { OrganizationNotFoundError, OrganizationWithoutEmailError, ManyOrganizationsFoundError, OrganizationArchivedError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | send-sco-invitation', function () { let organizationRepository, organizationInvitationRepository, organizationInvitationService; diff --git a/api/tests/unit/domain/usecases/send-shared-participation-results-to-pole-emploi_test.js b/api/tests/unit/domain/usecases/send-shared-participation-results-to-pole-emploi_test.js index c96ea2a9b6a..3bb86f5f996 100644 --- a/api/tests/unit/domain/usecases/send-shared-participation-results-to-pole-emploi_test.js +++ b/api/tests/unit/domain/usecases/send-shared-participation-results-to-pole-emploi_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const PoleEmploiSending = require('../../../../lib/domain/models/PoleEmploiSending'); -const PoleEmploiPayload = require('../../../../lib/infrastructure/externals/pole-emploi/PoleEmploiPayload'); -const sendSharedParticipationResultsToPoleEmploi = require('../../../../lib/domain/usecases/send-shared-participation-results-to-pole-emploi'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { PoleEmploiSending } from '../../../../lib/domain/models/PoleEmploiSending.js'; +import { PoleEmploiPayload } from '../../../../lib/infrastructure/externals/pole-emploi/PoleEmploiPayload.js'; +import { sendSharedParticipationResultsToPoleEmploi } from '../../../../lib/domain/usecases/send-shared-participation-results-to-pole-emploi.js'; describe('Unit | Domain | UseCase | send-shared-participation-results-to-pole-emploi', function () { let dependencies, expectedResults; diff --git a/api/tests/unit/domain/usecases/send-verification-code_test.js b/api/tests/unit/domain/usecases/send-verification-code_test.js index bafc4f02e8a..440acdb8e82 100644 --- a/api/tests/unit/domain/usecases/send-verification-code_test.js +++ b/api/tests/unit/domain/usecases/send-verification-code_test.js @@ -1,13 +1,14 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; + +import { AlreadyRegisteredEmailError, InvalidPasswordForUpdateEmailError, UserNotAuthorizedToUpdateEmailError, -} = require('../../../../lib/domain/errors'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +} from '../../../../lib/domain/errors.js'; -const usecases = require('../../../../lib/domain/usecases/index.js'); +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; describe('Unit | UseCase | send-verification-code', function () { let authenticationMethodRepository; diff --git a/api/tests/unit/domain/usecases/sessions-mass-import/create-sessions_test.js b/api/tests/unit/domain/usecases/sessions-mass-import/create-sessions_test.js index bb745c92755..fe4655417a2 100644 --- a/api/tests/unit/domain/usecases/sessions-mass-import/create-sessions_test.js +++ b/api/tests/unit/domain/usecases/sessions-mass-import/create-sessions_test.js @@ -1,8 +1,8 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../../test-helper'); -const { NotFoundError } = require('../../../../../lib/domain/errors'); -const createSessions = require('../../../../../lib/domain/usecases/sessions-mass-import/create-sessions'); -const DomainTransaction = require('../../../../../lib/infrastructure/DomainTransaction'); -const Session = require('../../../../../lib/domain/models/Session'); +import { expect, sinon, catchErr, domainBuilder } from '../../../../test-helper.js'; +import { NotFoundError } from '../../../../../lib/domain/errors.js'; +import { createSessions } from '../../../../../lib/domain/usecases/sessions-mass-import/create-sessions.js'; +import { DomainTransaction } from '../../../../../lib/infrastructure/DomainTransaction.js'; +import { Session } from '../../../../../lib/domain/models/Session.js'; describe('Unit | UseCase | sessions-mass-import | create-sessions', function () { let certificationCandidateRepository; @@ -13,7 +13,10 @@ describe('Unit | UseCase | sessions-mass-import | create-sessions', function () beforeEach(function () { certificationCandidateRepository = { saveInSession: sinon.stub(), deleteBySessionId: sinon.stub() }; sessionRepository = { save: sinon.stub() }; - temporarySessionsStorageForMassImportService = { getByKeyAndUserId: sinon.stub(), delete: sinon.stub() }; + temporarySessionsStorageForMassImportService = { + getByKeyAndUserId: sinon.stub(), + remove: sinon.stub(), + }; dependencies = { certificationCandidateRepository, @@ -188,7 +191,7 @@ describe('Unit | UseCase | sessions-mass-import | create-sessions', function () }); // then - expect(temporarySessionsStorageForMassImportService.delete).to.have.been.calledOnceWith({ + expect(temporarySessionsStorageForMassImportService.remove).to.have.been.calledOnceWith({ cachedValidatedSessionsKey, userId, }); diff --git a/api/tests/unit/domain/usecases/sessions-mass-import/validate-sessions_test.js b/api/tests/unit/domain/usecases/sessions-mass-import/validate-sessions_test.js index 33ba895ec46..4fd28e5fd61 100644 --- a/api/tests/unit/domain/usecases/sessions-mass-import/validate-sessions_test.js +++ b/api/tests/unit/domain/usecases/sessions-mass-import/validate-sessions_test.js @@ -1,11 +1,11 @@ -const { domainBuilder, expect, sinon } = require('../../../../test-helper'); -const validateSessions = require('../../../../../lib/domain/usecases/sessions-mass-import/validate-sessions'); -const Session = require('../../../../../lib/domain/models/Session'); -const { CpfBirthInformationValidation } = require('../../../../../lib/domain/services/certification-cpf-service'); -const CertificationCandidate = require('../../../../../lib/domain/models/CertificationCandidate'); -const { CERTIFICATION_SESSIONS_ERRORS } = require('../../../../../lib/domain/constants/sessions-errors'); -const SessionMassImportReport = require('../../../../../lib/domain/models/SessionMassImportReport'); -const { getI18n } = require('../../../../tooling/i18n/i18n'); +import { domainBuilder, expect, sinon } from '../../../../test-helper.js'; +import { validateSessions } from '../../../../../lib/domain/usecases/sessions-mass-import/validate-sessions.js'; +import { Session } from '../../../../../lib/domain/models/Session.js'; +import { CpfBirthInformationValidation } from '../../../../../lib/domain/services/certification-cpf-service.js'; +import { CertificationCandidate } from '../../../../../lib/domain/models/CertificationCandidate.js'; +import { CERTIFICATION_SESSIONS_ERRORS } from '../../../../../lib/domain/constants/sessions-errors.js'; +import { SessionMassImportReport } from '../../../../../lib/domain/models/SessionMassImportReport.js'; +import { getI18n } from '../../../../tooling/i18n/i18n.js'; describe('Unit | UseCase | sessions-mass-import | validate-sessions', function () { let accessCode; @@ -13,13 +13,11 @@ describe('Unit | UseCase | sessions-mass-import | validate-sessions', function ( let certificationCenterName; let certificationCenter; let certificationCenterRepository; - let certificationCandidateRepository; let certificationCourseRepository; let complementaryCertificationRepository; // eslint-disable-next-line mocha/no-setup-in-describe const i18n = getI18n(); let sessionCodeService; - let sessionsImportValidationService; let temporarySessionsStorageForMassImportService; @@ -216,7 +214,6 @@ describe('Unit | UseCase | sessions-mass-import | validate-sessions', function ( userId, certificationCenterId, certificationCenterRepository, - certificationCandidateRepository, certificationCourseRepository, sessionCodeService, i18n, @@ -384,11 +381,13 @@ describe('Unit | UseCase | sessions-mass-import | validate-sessions', function ( ], }); + certificationCenterRepository.get.withArgs(certificationCenterId).resolves(certificationCenter); + // when const sessionsMassImportReport = await validateSessions({ sessions, - certificationCenterId, certificationCenterRepository, + certificationCenterId, sessionCodeService, i18n, sessionsImportValidationService, diff --git a/api/tests/unit/domain/usecases/share-campaign-result_test.js b/api/tests/unit/domain/usecases/share-campaign-result_test.js index fbdbcbcfd92..075b711a05e 100644 --- a/api/tests/unit/domain/usecases/share-campaign-result_test.js +++ b/api/tests/unit/domain/usecases/share-campaign-result_test.js @@ -1,7 +1,7 @@ -const { sinon, expect, domainBuilder, catchErr } = require('../../../test-helper'); -const { UserNotAuthorizedToAccessEntityError } = require('../../../../lib/domain/errors'); -const CampaignParticipationResultsShared = require('../../../../lib/domain/events/CampaignParticipationResultsShared'); -const shareCampaignResult = require('../../../../lib/domain/usecases/share-campaign-result'); +import { sinon, expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { UserNotAuthorizedToAccessEntityError } from '../../../../lib/domain/errors.js'; +import { CampaignParticipationResultsShared } from '../../../../lib/domain/events/CampaignParticipationResultsShared.js'; +import { shareCampaignResult } from '../../../../lib/domain/usecases/share-campaign-result.js'; describe('Unit | UseCase | share-campaign-result', function () { let campaignParticipationRepository; diff --git a/api/tests/unit/domain/usecases/start-campaign-participation_test.js b/api/tests/unit/domain/usecases/start-campaign-participation_test.js index f475a64981d..6c3c3d7432f 100644 --- a/api/tests/unit/domain/usecases/start-campaign-participation_test.js +++ b/api/tests/unit/domain/usecases/start-campaign-participation_test.js @@ -1,7 +1,7 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const startCampaignParticipation = require('../../../../lib/domain/usecases/start-campaign-participation'); -const CampaignParticipationStarted = require('../../../../lib/domain/events/CampaignParticipationStarted'); -const CampaignParticipant = require('../../../../lib/domain/models/CampaignParticipant'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { startCampaignParticipation } from '../../../../lib/domain/usecases/start-campaign-participation.js'; +import { CampaignParticipationStarted } from '../../../../lib/domain/events/CampaignParticipationStarted.js'; +import { CampaignParticipant } from '../../../../lib/domain/models/CampaignParticipant.js'; describe('Unit | UseCase | start-campaign-participation', function () { const userId = 19837482; diff --git a/api/tests/unit/domain/usecases/start-or-resume-competence-evaluation_test.js b/api/tests/unit/domain/usecases/start-or-resume-competence-evaluation_test.js index 99d7fcf8ab8..84761d778ab 100644 --- a/api/tests/unit/domain/usecases/start-or-resume-competence-evaluation_test.js +++ b/api/tests/unit/domain/usecases/start-or-resume-competence-evaluation_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const CompetenceEvaluation = require('../../../../lib/domain/models/CompetenceEvaluation'); -const usecases = require('../../../../lib/domain/usecases/index.js'); -const { NotFoundError } = require('../../../../lib/domain/errors'); -const _ = require('lodash'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { CompetenceEvaluation } from '../../../../lib/domain/models/CompetenceEvaluation.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; +import _ from 'lodash'; describe('Unit | UseCase | start-or-resume-competence-evaluation', function () { const userId = 123; diff --git a/api/tests/unit/domain/usecases/start-writing-campaign-assessment-results-to-stream_test.js b/api/tests/unit/domain/usecases/start-writing-campaign-assessment-results-to-stream_test.js index b242512fd59..399d61b8c43 100644 --- a/api/tests/unit/domain/usecases/start-writing-campaign-assessment-results-to-stream_test.js +++ b/api/tests/unit/domain/usecases/start-writing-campaign-assessment-results-to-stream_test.js @@ -1,10 +1,13 @@ -const { PassThrough } = require('stream'); -const { expect, sinon, domainBuilder, streamToPromise, catchErr } = require('../../../test-helper'); -const startWritingCampaignAssessmentResultsToStream = require('../../../../lib/domain/usecases/start-writing-campaign-assessment-results-to-stream'); -const { UserNotAuthorizedToGetCampaignResultsError, CampaignTypeError } = require('../../../../lib/domain/errors'); -const campaignCsvExportService = require('../../../../lib/domain/services/campaign-csv-export-service'); -const { getI18n } = require('../../../tooling/i18n/i18n'); -const StageCollection = require('../../../../lib/domain/models/user-campaign-results/StageCollection'); +import stream from 'stream'; + +const { PassThrough } = stream; + +import { expect, sinon, domainBuilder, streamToPromise, catchErr } from '../../../test-helper.js'; +import { startWritingCampaignAssessmentResultsToStream } from '../../../../lib/domain/usecases/start-writing-campaign-assessment-results-to-stream.js'; +import { UserNotAuthorizedToGetCampaignResultsError, CampaignTypeError } from '../../../../lib/domain/errors.js'; +import * as campaignCsvExportService from '../../../../lib/domain/services/campaign-csv-export-service.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; +import { StageCollection } from '../../../../lib/domain/models/user-campaign-results/StageCollection.js'; describe('Unit | Domain | Use Cases | start-writing-campaign-assessment-results-to-stream', function () { const campaignRepository = { get: () => undefined }; diff --git a/api/tests/unit/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream_test.js b/api/tests/unit/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream_test.js index 07cb0faebe7..bd04af843e7 100644 --- a/api/tests/unit/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream_test.js +++ b/api/tests/unit/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream_test.js @@ -1,9 +1,12 @@ -const { PassThrough } = require('stream'); -const { expect, sinon, domainBuilder, streamToPromise, catchErr } = require('../../../test-helper'); -const startWritingCampaignProfilesCollectionResultsToStream = require('../../../../lib/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream'); -const { UserNotAuthorizedToGetCampaignResultsError, CampaignTypeError } = require('../../../../lib/domain/errors'); -const CampaignProfilesCollectionExport = require('../../../../lib/infrastructure/serializers/csv/campaign-profiles-collection-export'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import stream from 'stream'; + +const { PassThrough } = stream; + +import { expect, sinon, domainBuilder, streamToPromise, catchErr } from '../../../test-helper.js'; +import { startWritingCampaignProfilesCollectionResultsToStream } from '../../../../lib/domain/usecases/start-writing-campaign-profiles-collection-results-to-stream.js'; +import { UserNotAuthorizedToGetCampaignResultsError, CampaignTypeError } from '../../../../lib/domain/errors.js'; +import { CampaignProfilesCollectionExport } from '../../../../lib/infrastructure/serializers/csv/campaign-profiles-collection-export.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; describe('Unit | Domain | Use Cases | start-writing-campaign-profiles-collection-results-to-stream', function () { const campaignRepository = { get: () => undefined }; diff --git a/api/tests/unit/domain/usecases/supervise-session_test.js b/api/tests/unit/domain/usecases/supervise-session_test.js index 7c2c5d1df83..3044608629e 100644 --- a/api/tests/unit/domain/usecases/supervise-session_test.js +++ b/api/tests/unit/domain/usecases/supervise-session_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, domainBuilder, catchErr } = require('../../../test-helper'); -const superviseSession = require('../../../../lib/domain/usecases/supervise-session'); -const { InvalidSessionSupervisingLoginError, SessionNotAccessible } = require('../../../../lib/domain/errors'); +import { expect, sinon, domainBuilder, catchErr } from '../../../test-helper.js'; +import { superviseSession } from '../../../../lib/domain/usecases/supervise-session.js'; +import { InvalidSessionSupervisingLoginError, SessionNotAccessible } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | supervise-session', function () { let sessionRepository; diff --git a/api/tests/unit/domain/usecases/unarchive-campaign_test.js b/api/tests/unit/domain/usecases/unarchive-campaign_test.js index 201bdcf0681..849a9dafab4 100644 --- a/api/tests/unit/domain/usecases/unarchive-campaign_test.js +++ b/api/tests/unit/domain/usecases/unarchive-campaign_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const unarchiveCampaign = require('../../../../lib/domain/usecases/unarchive-campaign'); -const Campaign = require('../../../../lib/domain/models/CampaignForArchiving'); +import { expect, sinon } from '../../../test-helper.js'; +import { unarchiveCampaign } from '../../../../lib/domain/usecases/unarchive-campaign.js'; +import { CampaignForArchiving as Campaign } from '../../../../lib/domain/models/CampaignForArchiving.js'; describe('Unit | UseCase | unarchive-campaign', function () { let campaignForArchivingRepository; diff --git a/api/tests/unit/domain/usecases/uncancel-certification-course_test.js b/api/tests/unit/domain/usecases/uncancel-certification-course_test.js index 62639891f30..4bd8095b288 100644 --- a/api/tests/unit/domain/usecases/uncancel-certification-course_test.js +++ b/api/tests/unit/domain/usecases/uncancel-certification-course_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const uncancelCertificationCourse = require('../../../../lib/domain/usecases/uncancel-certification-course'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { uncancelCertificationCourse } from '../../../../lib/domain/usecases/uncancel-certification-course.js'; describe('Unit | UseCase | uncancel-certification-course', function () { it('should uncancel the certification course', async function () { diff --git a/api/tests/unit/domain/usecases/unpublish-session_test.js b/api/tests/unit/domain/usecases/unpublish-session_test.js index a97ad23dd8a..e05939e2ac7 100644 --- a/api/tests/unit/domain/usecases/unpublish-session_test.js +++ b/api/tests/unit/domain/usecases/unpublish-session_test.js @@ -1,6 +1,6 @@ -const { domainBuilder, sinon, expect } = require('../../../test-helper'); -const unpublishSession = require('../../../../lib/domain/usecases/unpublish-session'); -const FinalizedSession = require('../../../../lib/domain/models/FinalizedSession'); +import { domainBuilder, sinon, expect } from '../../../test-helper.js'; +import { unpublishSession } from '../../../../lib/domain/usecases/unpublish-session.js'; +import { FinalizedSession } from '../../../../lib/domain/models/FinalizedSession.js'; describe('Unit | UseCase | unpublish-session', function () { let certificationRepository; diff --git a/api/tests/unit/domain/usecases/update-admin-member_test.js b/api/tests/unit/domain/usecases/update-admin-member_test.js index a5eb7a79520..aa6e8b54071 100644 --- a/api/tests/unit/domain/usecases/update-admin-member_test.js +++ b/api/tests/unit/domain/usecases/update-admin-member_test.js @@ -1,6 +1,8 @@ -const { expect, sinon } = require('../../../test-helper'); -const updateAdminMember = require('../../../../lib/domain/usecases/update-admin-member'); -const { ROLES } = require('../../../../lib/domain/constants').PIX_ADMIN; +import { expect, sinon } from '../../../test-helper.js'; +import { updateAdminMember } from '../../../../lib/domain/usecases/update-admin-member.js'; +import { PIX_ADMIN } from '../../../../lib/domain/constants.js'; + +const { ROLES } = PIX_ADMIN; describe('Unit | UseCase | update-admin-member', function () { it('should update the given admin member', async function () { diff --git a/api/tests/unit/domain/usecases/update-campaign-details-management_test.js b/api/tests/unit/domain/usecases/update-campaign-details-management_test.js index cc882cfc883..875dacb9c7c 100644 --- a/api/tests/unit/domain/usecases/update-campaign-details-management_test.js +++ b/api/tests/unit/domain/usecases/update-campaign-details-management_test.js @@ -1,7 +1,7 @@ -const { expect, catchErr, domainBuilder } = require('../../../test-helper'); -const updateCampaignDetailsManagement = require('../../../../lib/domain/usecases/update-campaign-details-management'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); -const sinon = require('sinon'); +import { expect, catchErr, domainBuilder } from '../../../test-helper.js'; +import { updateCampaignDetailsManagement } from '../../../../lib/domain/usecases/update-campaign-details-management.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import sinon from 'sinon'; describe('Unit | UseCase | update-campaign-details-management', function () { let campaignManagementRepository; diff --git a/api/tests/unit/domain/usecases/update-campaign_test.js b/api/tests/unit/domain/usecases/update-campaign_test.js index 1fd5b2b1111..8c9fb63cc07 100644 --- a/api/tests/unit/domain/usecases/update-campaign_test.js +++ b/api/tests/unit/domain/usecases/update-campaign_test.js @@ -1,6 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const updateCampaign = require('../../../../lib/domain/usecases/update-campaign'); -const { UserNotAuthorizedToUpdateResourceError, EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { updateCampaign } from '../../../../lib/domain/usecases/update-campaign.js'; +import { UserNotAuthorizedToUpdateResourceError, EntityValidationError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | update-campaign', function () { let originalCampaign; diff --git a/api/tests/unit/domain/usecases/update-certification-center-referer_test.js b/api/tests/unit/domain/usecases/update-certification-center-referer_test.js index 955684accc3..4dcff72f432 100644 --- a/api/tests/unit/domain/usecases/update-certification-center-referer_test.js +++ b/api/tests/unit/domain/usecases/update-certification-center-referer_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const updateCertificationCenterReferer = require('../../../../lib/domain/usecases/update-certification-center-referer'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import { updateCertificationCenterReferer } from '../../../../lib/domain/usecases/update-certification-center-referer.js'; describe('Unit | UseCase | update-certification-center-referer', function () { context('when there is already a referer', function () { diff --git a/api/tests/unit/domain/usecases/update-expired-password_test.js b/api/tests/unit/domain/usecases/update-expired-password_test.js index 3a7e1522bf7..ca169139f89 100644 --- a/api/tests/unit/domain/usecases/update-expired-password_test.js +++ b/api/tests/unit/domain/usecases/update-expired-password_test.js @@ -1,9 +1,8 @@ -const { sinon, expect, domainBuilder, catchErr } = require('../../../test-helper'); - -const { ForbiddenAccess, UserNotFoundError } = require('../../../../lib/domain/errors'); -const AuthenticationMethod = require('../../../../lib/domain/models/AuthenticationMethod'); -const updateExpiredPassword = require('../../../../lib/domain/usecases/update-expired-password'); -const logger = require('../../../../lib/infrastructure/logger'); +import { sinon, expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { ForbiddenAccess, UserNotFoundError } from '../../../../lib/domain/errors.js'; +import { AuthenticationMethod } from '../../../../lib/domain/models/AuthenticationMethod.js'; +import { updateExpiredPassword } from '../../../../lib/domain/usecases/update-expired-password.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; describe('Unit | UseCase | update-expired-password', function () { const passwordResetToken = 'PASSWORD_RESET_TOKEN'; diff --git a/api/tests/unit/domain/usecases/update-last-question-state_test.js b/api/tests/unit/domain/usecases/update-last-question-state_test.js index 5532caec85d..334ca9ad4d0 100644 --- a/api/tests/unit/domain/usecases/update-last-question-state_test.js +++ b/api/tests/unit/domain/usecases/update-last-question-state_test.js @@ -1,6 +1,6 @@ -const { sinon, domainBuilder } = require('../../../test-helper'); -const Assessment = require('../../../../lib/domain/models/Assessment'); -const updateLastQuestionState = require('../../../../lib/domain/usecases/update-last-question-state'); +import { sinon, domainBuilder } from '../../../test-helper.js'; +import { Assessment } from '../../../../lib/domain/models/Assessment.js'; +import { updateLastQuestionState } from '../../../../lib/domain/usecases/update-last-question-state.js'; describe('Unit | UseCase | update-last-question-state', function () { const assessmentId = 'assessmentId'; diff --git a/api/tests/unit/domain/usecases/update-membership_test.js b/api/tests/unit/domain/usecases/update-membership_test.js index 0ff22a65d35..89f91836a68 100644 --- a/api/tests/unit/domain/usecases/update-membership_test.js +++ b/api/tests/unit/domain/usecases/update-membership_test.js @@ -1,7 +1,9 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { updateMembership } = require('../../../../lib/domain/usecases/index.js'); -const Membership = require('../../../../lib/domain/models/Membership'); -const { InvalidMembershipOrganizationRoleError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; +import { Membership } from '../../../../lib/domain/models/Membership.js'; +import { InvalidMembershipOrganizationRoleError } from '../../../../lib/domain/errors.js'; + +const { updateMembership } = usecases; describe('Unit | UseCase | update-membership', function () { let membershipRepository; diff --git a/api/tests/unit/domain/usecases/update-organization-learner-dependent-user-password_test.js b/api/tests/unit/domain/usecases/update-organization-learner-dependent-user-password_test.js index c0f61363fee..a15aff28e25 100644 --- a/api/tests/unit/domain/usecases/update-organization-learner-dependent-user-password_test.js +++ b/api/tests/unit/domain/usecases/update-organization-learner-dependent-user-password_test.js @@ -1,8 +1,6 @@ -const { sinon, expect, catchErr } = require('../../../test-helper'); - -const { UserNotFoundError, UserNotAuthorizedToUpdatePasswordError } = require('../../../../lib/domain/errors'); - -const updateOrganizationLearnerDependentUserPassword = require('../../../../lib/domain/usecases/update-organization-learner-dependent-user-password'); +import { sinon, expect, catchErr } from '../../../test-helper.js'; +import { UserNotFoundError, UserNotAuthorizedToUpdatePasswordError } from '../../../../lib/domain/errors.js'; +import { updateOrganizationLearnerDependentUserPassword } from '../../../../lib/domain/usecases/update-organization-learner-dependent-user-password.js'; describe('Unit | UseCase | update-organization-learner-dependent-user-password', function () { const userId = 1; diff --git a/api/tests/unit/domain/usecases/update-participant-external-id_test.js b/api/tests/unit/domain/usecases/update-participant-external-id_test.js index 61c968af4df..5d44ffae871 100644 --- a/api/tests/unit/domain/usecases/update-participant-external-id_test.js +++ b/api/tests/unit/domain/usecases/update-participant-external-id_test.js @@ -1,5 +1,7 @@ -const { expect, sinon } = require('../../../test-helper'); -const { updateParticipantExternalId } = require('../../../../lib/domain/usecases/index.js'); +import { expect, sinon } from '../../../test-helper.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; + +const { updateParticipantExternalId } = usecases; describe('Unit | UseCase | update-participation-external-id', function () { it('should call repository method to update the external id for a participation', async function () { diff --git a/api/tests/unit/domain/usecases/update-session_test.js b/api/tests/unit/domain/usecases/update-session_test.js index a59aa2d38e3..af3853aed63 100644 --- a/api/tests/unit/domain/usecases/update-session_test.js +++ b/api/tests/unit/domain/usecases/update-session_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const updateSession = require('../../../../lib/domain/usecases/update-session'); +import { expect, sinon } from '../../../test-helper.js'; +import { updateSession } from '../../../../lib/domain/usecases/update-session.js'; describe('Unit | UseCase | update-session', function () { let originalSession; diff --git a/api/tests/unit/domain/usecases/update-student-number_test.js b/api/tests/unit/domain/usecases/update-student-number_test.js index f99166b4b34..7ccde5c0d4a 100644 --- a/api/tests/unit/domain/usecases/update-student-number_test.js +++ b/api/tests/unit/domain/usecases/update-student-number_test.js @@ -1,8 +1,6 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); - -const { AlreadyExistingEntityError } = require('../../../../lib/domain/errors'); - -const updateStudentNumber = require('../../../../lib/domain/usecases/update-student-number'); +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; +import { AlreadyExistingEntityError } from '../../../../lib/domain/errors.js'; +import { updateStudentNumber } from '../../../../lib/domain/usecases/update-student-number.js'; describe('Unit | UseCase | update-student-number', function () { const organizationId = 2; diff --git a/api/tests/unit/domain/usecases/update-target-profile_test.js b/api/tests/unit/domain/usecases/update-target-profile_test.js index 222a6386e2e..3cbfc46b464 100644 --- a/api/tests/unit/domain/usecases/update-target-profile_test.js +++ b/api/tests/unit/domain/usecases/update-target-profile_test.js @@ -1,6 +1,8 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const { updateTargetProfile } = require('../../../../lib/domain/usecases/index.js'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import { usecases } from '../../../../lib/domain/usecases/index.js'; + +const { updateTargetProfile } = usecases; describe('Unit | UseCase | update-target-profile', function () { let targetProfileForUpdateRepository = null; diff --git a/api/tests/unit/domain/usecases/update-training_test.js b/api/tests/unit/domain/usecases/update-training_test.js index a01c2a44246..0c9f6c62a1d 100644 --- a/api/tests/unit/domain/usecases/update-training_test.js +++ b/api/tests/unit/domain/usecases/update-training_test.js @@ -1,6 +1,6 @@ -const { catchErr, expect, sinon } = require('../../../test-helper'); -const updateTraining = require('../../../../lib/domain/usecases/update-training'); -const { NotFoundError } = require('../../../../lib/domain/errors'); +import { catchErr, expect, sinon } from '../../../test-helper.js'; +import { updateTraining } from '../../../../lib/domain/usecases/update-training.js'; +import { NotFoundError } from '../../../../lib/domain/errors.js'; describe('Unit | UseCase | update-training', function () { let trainingRepository; diff --git a/api/tests/unit/domain/usecases/update-user-details-for-administration_test.js b/api/tests/unit/domain/usecases/update-user-details-for-administration_test.js index 1c4c6436a10..7bde2370604 100644 --- a/api/tests/unit/domain/usecases/update-user-details-for-administration_test.js +++ b/api/tests/unit/domain/usecases/update-user-details-for-administration_test.js @@ -1,12 +1,13 @@ -const { catchErr, domainBuilder, expect, sinon } = require('../../../test-helper'); -const { +import { catchErr, domainBuilder, expect, sinon } from '../../../test-helper.js'; + +import { AlreadyRegisteredEmailAndUsernameError, AlreadyRegisteredEmailError, AlreadyRegisteredUsernameError, -} = require('../../../../lib/domain/errors'); -const User = require('../../../../lib/domain/models/User'); +} from '../../../../lib/domain/errors.js'; -const updateUserDetailsForAdministration = require('../../../../lib/domain/usecases/update-user-details-for-administration'); +import { User } from '../../../../lib/domain/models/User.js'; +import { updateUserDetailsForAdministration } from '../../../../lib/domain/usecases/update-user-details-for-administration.js'; describe('Unit | UseCase | update-user-details-for-administration', function () { const userId = 1; diff --git a/api/tests/unit/domain/usecases/update-user-email-with-validation_test.js b/api/tests/unit/domain/usecases/update-user-email-with-validation_test.js index a43ebc17444..f04d7454fd2 100644 --- a/api/tests/unit/domain/usecases/update-user-email-with-validation_test.js +++ b/api/tests/unit/domain/usecases/update-user-email-with-validation_test.js @@ -1,13 +1,14 @@ -const { expect, sinon, catchErr, domainBuilder } = require('../../../test-helper'); -const { +import { expect, sinon, catchErr, domainBuilder } from '../../../test-helper.js'; + +import { AlreadyRegisteredEmailError, InvalidVerificationCodeError, UserNotAuthorizedToUpdateEmailError, EmailModificationDemandNotFoundOrExpiredError, -} = require('../../../../lib/domain/errors'); +} from '../../../../lib/domain/errors.js'; -const EmailModificationDemand = require('../../../../lib/domain/models/EmailModificationDemand'); -const updateUserEmailWithValidation = require('../../../../lib/domain/usecases/update-user-email-with-validation'); +import { EmailModificationDemand } from '../../../../lib/domain/models/EmailModificationDemand.js'; +import { updateUserEmailWithValidation } from '../../../../lib/domain/usecases/update-user-email-with-validation.js'; describe('Unit | UseCase | update-user-email-with-validation', function () { let userEmailRepository; diff --git a/api/tests/unit/domain/usecases/update-user-password_test.js b/api/tests/unit/domain/usecases/update-user-password_test.js index 16e2291bdaf..80a9c509c3d 100644 --- a/api/tests/unit/domain/usecases/update-user-password_test.js +++ b/api/tests/unit/domain/usecases/update-user-password_test.js @@ -1,12 +1,10 @@ -const { catchErr, expect, sinon } = require('../../../test-helper'); - -const User = require('../../../../lib/domain/models/User'); -const { +import { catchErr, expect, sinon } from '../../../test-helper.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { PasswordResetDemandNotFoundError, UserNotAuthorizedToUpdatePasswordError, -} = require('../../../../lib/domain/errors'); - -const updateUserPassword = require('../../../../lib/domain/usecases/update-user-password'); +} from '../../../../lib/domain/errors.js'; +import { updateUserPassword } from '../../../../lib/domain/usecases/update-user-password.js'; describe('Unit | UseCase | update-user-password', function () { const userId = 1; diff --git a/api/tests/unit/domain/validators/campaign-validator_test.js b/api/tests/unit/domain/validators/campaign-validator_test.js index 8dc8b5e2f28..fefe7ecbde4 100644 --- a/api/tests/unit/domain/validators/campaign-validator_test.js +++ b/api/tests/unit/domain/validators/campaign-validator_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const campaignValidator = require('../../../../lib/domain/validators/campaign-validator'); -const CampaignTypes = require('../../../../lib/domain/models/CampaignTypes'); +import { expect } from '../../../test-helper.js'; +import * as campaignValidator from '../../../../lib/domain/validators/campaign-validator.js'; +import { CampaignTypes } from '../../../../lib/domain/models/CampaignTypes.js'; const MISSING_VALUE = null; const EMPTY_VALUE = ''; diff --git a/api/tests/unit/domain/validators/certification-center-creation-validator_test.js b/api/tests/unit/domain/validators/certification-center-creation-validator_test.js index 48854ab96fe..b1170ba709f 100644 --- a/api/tests/unit/domain/validators/certification-center-creation-validator_test.js +++ b/api/tests/unit/domain/validators/certification-center-creation-validator_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const certificationCenterCreationValidator = require('../../../../lib/domain/validators/certification-center-creation-validator'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect } from '../../../test-helper.js'; +import * as certificationCenterCreationValidator from '../../../../lib/domain/validators/certification-center-creation-validator.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; const MISSING_VALUE = ''; diff --git a/api/tests/unit/domain/validators/entity-validator_test.js b/api/tests/unit/domain/validators/entity-validator_test.js index 3d44bf18955..fa7cc97ecec 100644 --- a/api/tests/unit/domain/validators/entity-validator_test.js +++ b/api/tests/unit/domain/validators/entity-validator_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../test-helper'); -const { ObjectValidationError } = require('../../../../lib/domain/errors'); -const Joi = require('joi'); -const { validateEntity } = require('../../../../lib/domain/validators/entity-validator'); +import { expect } from '../../../test-helper.js'; +import { ObjectValidationError } from '../../../../lib/domain/errors.js'; +import Joi from 'joi'; +import { validateEntity } from '../../../../lib/domain/validators/entity-validator.js'; describe('Unit | Domain | Validators | entity-validator', function () { describe('#validateEntity', function () { diff --git a/api/tests/unit/domain/validators/organization-creation-validator_test.js b/api/tests/unit/domain/validators/organization-creation-validator_test.js index d0c6861fd65..7b76f94fdaa 100644 --- a/api/tests/unit/domain/validators/organization-creation-validator_test.js +++ b/api/tests/unit/domain/validators/organization-creation-validator_test.js @@ -1,6 +1,6 @@ -const { expect, catchErr } = require('../../../test-helper'); -const organizationCreationValidator = require('../../../../lib/domain/validators/organization-creation-validator'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); +import { expect, catchErr } from '../../../test-helper.js'; +import * as organizationCreationValidator from '../../../../lib/domain/validators/organization-creation-validator.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; const MISSING_VALUE = ''; diff --git a/api/tests/unit/domain/validators/organization-learner-validator_test.js b/api/tests/unit/domain/validators/organization-learner-validator_test.js index db3dc6665b9..00e605974fc 100644 --- a/api/tests/unit/domain/validators/organization-learner-validator_test.js +++ b/api/tests/unit/domain/validators/organization-learner-validator_test.js @@ -1,8 +1,8 @@ -const { expect, catchErr } = require('../../../test-helper'); -const { +import { expect, catchErr } from '../../../test-helper.js'; +import { checkValidation, FRANCE_COUNTRY_CODE, -} = require('../../../../lib/domain/validators/organization-learner-validator'); +} from '../../../../lib/domain/validators/organization-learner-validator.js'; describe('Unit | Domain | Organization Learner validator', function () { context('#checkValidation', function () { diff --git a/api/tests/unit/domain/validators/password-validator_test.js b/api/tests/unit/domain/validators/password-validator_test.js index 0118da9f922..f58d5b4308c 100644 --- a/api/tests/unit/domain/validators/password-validator_test.js +++ b/api/tests/unit/domain/validators/password-validator_test.js @@ -1,7 +1,6 @@ -const { expect, catchErr } = require('../../../test-helper'); - -const { EntityValidationError } = require('../../../../lib/domain/errors'); -const passwordValidator = require('../../../../lib/domain/validators/password-validator'); +import { expect, catchErr } from '../../../test-helper.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import * as passwordValidator from '../../../../lib/domain/validators/password-validator.js'; function _assertErrorMatchesWithExpectedOne(entityValidationErrors, expectedError) { expect(entityValidationErrors).to.be.instanceOf(EntityValidationError); diff --git a/api/tests/unit/domain/validators/session-validator_test.js b/api/tests/unit/domain/validators/session-validator_test.js index a82ff205429..e78aa0ba534 100644 --- a/api/tests/unit/domain/validators/session-validator_test.js +++ b/api/tests/unit/domain/validators/session-validator_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder, catchErr } = require('../../../test-helper'); -const { statuses } = require('../../../../lib/domain/models/Session'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); -const sessionValidator = require('../../../../lib/domain/validators/session-validator'); +import { expect, domainBuilder, catchErr } from '../../../test-helper.js'; +import { statuses } from '../../../../lib/domain/models/Session.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import * as sessionValidator from '../../../../lib/domain/validators/session-validator.js'; const MISSING_VALUE = ''; diff --git a/api/tests/unit/domain/validators/target-profile/creation-command-validation_test.js b/api/tests/unit/domain/validators/target-profile/creation-command-validation_test.js index 05be0a5e596..68c82449979 100644 --- a/api/tests/unit/domain/validators/target-profile/creation-command-validation_test.js +++ b/api/tests/unit/domain/validators/target-profile/creation-command-validation_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../test-helper'); -const creationCommandValidator = require('../../../../../lib/domain/validators/target-profile/creation-command-validation'); -const { EntityValidationError } = require('../../../../../lib/domain/errors'); -const { categories } = require('../../../../../lib/domain/models/TargetProfile'); +import { expect } from '../../../../test-helper.js'; +import * as creationCommandValidator from '../../../../../lib/domain/validators/target-profile/creation-command-validation.js'; +import { EntityValidationError } from '../../../../../lib/domain/errors.js'; +import { categories } from '../../../../../lib/domain/models/TargetProfile.js'; describe('Unit | Domain | Validators | target-profile/creationCommandValidator', function () { describe('#validate', function () { diff --git a/api/tests/unit/domain/validators/user-validator_test.js b/api/tests/unit/domain/validators/user-validator_test.js index 6a63cbb453a..cc573e2211d 100644 --- a/api/tests/unit/domain/validators/user-validator_test.js +++ b/api/tests/unit/domain/validators/user-validator_test.js @@ -1,9 +1,7 @@ -const { expect, catchErr } = require('../../../test-helper'); - -const User = require('../../../../lib/domain/models/User'); -const { EntityValidationError } = require('../../../../lib/domain/errors'); - -const userValidator = require('../../../../lib/domain/validators/user-validator'); +import { expect, catchErr } from '../../../test-helper.js'; +import { User } from '../../../../lib/domain/models/User.js'; +import { EntityValidationError } from '../../../../lib/domain/errors.js'; +import * as userValidator from '../../../../lib/domain/validators/user-validator.js'; const MISSING_VALUE = ''; diff --git a/api/tests/unit/infrastructure/adapters/answer-status-database-adapter_test.js b/api/tests/unit/infrastructure/adapters/answer-status-database-adapter_test.js index bcfebfcff8a..8e03565a86a 100644 --- a/api/tests/unit/infrastructure/adapters/answer-status-database-adapter_test.js +++ b/api/tests/unit/infrastructure/adapters/answer-status-database-adapter_test.js @@ -1,7 +1,9 @@ -const AnswerStatusDatabaseAdapter = require('../../../../lib/infrastructure/adapters/answer-status-database-adapter'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); +import * as AnswerStatusDatabaseAdapter from '../../../../lib/infrastructure/adapters/answer-status-database-adapter.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; -const { expect } = require('chai'); +import chai from 'chai'; + +const { expect } = chai; describe('AnswerStatusDatabaseAdapter', function () { describe('#adapt', function () { diff --git a/api/tests/unit/infrastructure/adapters/answer-status-json-api-adapter_test.js b/api/tests/unit/infrastructure/adapters/answer-status-json-api-adapter_test.js index bfe42b07221..8314670d2ee 100644 --- a/api/tests/unit/infrastructure/adapters/answer-status-json-api-adapter_test.js +++ b/api/tests/unit/infrastructure/adapters/answer-status-json-api-adapter_test.js @@ -1,7 +1,9 @@ -const AnswerStatusJsonApiAdapter = require('../../../../lib/infrastructure/adapters/answer-status-json-api-adapter'); -const AnswerStatus = require('../../../../lib/domain/models/AnswerStatus'); +import { AnswerStatusJsonApiAdapter } from '../../../../lib/infrastructure/adapters/answer-status-json-api-adapter.js'; +import { AnswerStatus } from '../../../../lib/domain/models/AnswerStatus.js'; -const { expect } = require('chai'); +import chai from 'chai'; + +const { expect } = chai; describe('AnswerStatusJsonApiAdapter', function () { describe('#adapt', function () { diff --git a/api/tests/unit/infrastructure/adapters/skill-adapter_test.js b/api/tests/unit/infrastructure/adapters/skill-adapter_test.js index 7aec824242e..0fd3e428317 100644 --- a/api/tests/unit/infrastructure/adapters/skill-adapter_test.js +++ b/api/tests/unit/infrastructure/adapters/skill-adapter_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const skillAdapter = require('../../../../lib/infrastructure/adapters/skill-adapter'); -const Skill = require('../../../../lib/domain/models/Skill'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import * as skillAdapter from '../../../../lib/infrastructure/adapters/skill-adapter.js'; +import { Skill } from '../../../../lib/domain/models/Skill.js'; describe('Unit | Infrastructure | Adapter | skillAdapter', function () { describe('#fromDatasourceObject', function () { diff --git a/api/tests/unit/infrastructure/adapters/solution-adapter_test.js b/api/tests/unit/infrastructure/adapters/solution-adapter_test.js index 2fc504f3abf..b3f0b73ae1b 100644 --- a/api/tests/unit/infrastructure/adapters/solution-adapter_test.js +++ b/api/tests/unit/infrastructure/adapters/solution-adapter_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const solutionAdapter = require('../../../../lib/infrastructure/adapters/solution-adapter'); -const Solution = require('../../../../lib/domain/models/Solution'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import * as solutionAdapter from '../../../../lib/infrastructure/adapters/solution-adapter.js'; +import { Solution } from '../../../../lib/domain/models/Solution.js'; describe('Unit | Adapter | Solution', function () { describe('#fromDatasourceObject', function () { diff --git a/api/tests/unit/infrastructure/adapters/target-profile-adapter_test.js b/api/tests/unit/infrastructure/adapters/target-profile-adapter_test.js index 35dddc0a5f2..40142a4b385 100644 --- a/api/tests/unit/infrastructure/adapters/target-profile-adapter_test.js +++ b/api/tests/unit/infrastructure/adapters/target-profile-adapter_test.js @@ -1,8 +1,8 @@ -const { sinon, databaseBuilder, expect, domainBuilder } = require('../../../test-helper'); -const BookshelfTargetProfile = require('../../../../lib/infrastructure/orm-models/TargetProfile'); -const BookshelfTargetProfileShare = require('../../../../lib/infrastructure/orm-models/TargetProfileShare'); -const TargetProfile = require('../../../../lib/domain/models/TargetProfile'); -const targetProfileAdapter = require('../../../../lib/infrastructure/adapters/target-profile-adapter'); +import { sinon, databaseBuilder, expect, domainBuilder } from '../../../test-helper.js'; +import { BookshelfTargetProfile } from '../../../../lib/infrastructure/orm-models/TargetProfile.js'; +import { BookshelfTargetProfileShare } from '../../../../lib/infrastructure/orm-models/TargetProfileShare.js'; +import { TargetProfile } from '../../../../lib/domain/models/TargetProfile.js'; +import * as targetProfileAdapter from '../../../../lib/infrastructure/adapters/target-profile-adapter.js'; describe('Unit | Infrastructure | Adapter | targetProfileAdapter', function () { it('should adapt TargetProfile object to domain', function () { diff --git a/api/tests/unit/infrastructure/caches/Cache_test.js b/api/tests/unit/infrastructure/caches/Cache_test.js index c29bef3467b..86941bfa342 100644 --- a/api/tests/unit/infrastructure/caches/Cache_test.js +++ b/api/tests/unit/infrastructure/caches/Cache_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const Cache = require('../../../../lib/infrastructure/caches/Cache'); +import { expect } from '../../../test-helper.js'; +import { Cache } from '../../../../lib/infrastructure/caches/Cache.js'; describe('Unit | Infrastructure | Caches | Cache', function () { const cacheInstance = new Cache(); diff --git a/api/tests/unit/infrastructure/caches/DistributedCache_test.js b/api/tests/unit/infrastructure/caches/DistributedCache_test.js index 947656907e6..715695c7328 100644 --- a/api/tests/unit/infrastructure/caches/DistributedCache_test.js +++ b/api/tests/unit/infrastructure/caches/DistributedCache_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const DistributedCache = require('../../../../lib/infrastructure/caches/DistributedCache'); +import { expect, sinon } from '../../../test-helper.js'; +import { DistributedCache } from '../../../../lib/infrastructure/caches/DistributedCache.js'; describe('Unit | Infrastructure | Caches | DistributedCache', function () { let distributedCacheInstance; diff --git a/api/tests/unit/infrastructure/caches/InMemoryCache_test.js b/api/tests/unit/infrastructure/caches/InMemoryCache_test.js index f586b99aa97..4f280be5332 100644 --- a/api/tests/unit/infrastructure/caches/InMemoryCache_test.js +++ b/api/tests/unit/infrastructure/caches/InMemoryCache_test.js @@ -1,6 +1,6 @@ -const NodeCache = require('node-cache'); -const { expect, sinon } = require('../../../test-helper'); -const InMemoryCache = require('../../../../lib/infrastructure/caches/InMemoryCache'); +import NodeCache from 'node-cache'; +import { expect, sinon } from '../../../test-helper.js'; +import { InMemoryCache } from '../../../../lib/infrastructure/caches/InMemoryCache.js'; describe('Unit | Infrastructure | Cache | in-memory-cache', function () { let inMemoryCache; diff --git a/api/tests/unit/infrastructure/caches/LayeredCache_test.js b/api/tests/unit/infrastructure/caches/LayeredCache_test.js index f4914765853..985bf6b8110 100644 --- a/api/tests/unit/infrastructure/caches/LayeredCache_test.js +++ b/api/tests/unit/infrastructure/caches/LayeredCache_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const LayeredCache = require('../../../../lib/infrastructure/caches/LayeredCache'); +import { expect, sinon } from '../../../test-helper.js'; +import { LayeredCache } from '../../../../lib/infrastructure/caches/LayeredCache.js'; describe('Unit | Infrastructure | Caches | LayeredCache', function () { const layeredCacheInstance = new LayeredCache(); diff --git a/api/tests/unit/infrastructure/caches/RedisCache_test.js b/api/tests/unit/infrastructure/caches/RedisCache_test.js index 85029b711bf..513a5637b67 100644 --- a/api/tests/unit/infrastructure/caches/RedisCache_test.js +++ b/api/tests/unit/infrastructure/caches/RedisCache_test.js @@ -1,7 +1,7 @@ -const Redlock = require('redlock'); -const { expect, sinon } = require('../../../test-helper'); -const settings = require('../../../../lib/config'); -const RedisCache = require('../../../../lib/infrastructure/caches/RedisCache'); +import Redlock from 'redlock'; +import { expect, sinon } from '../../../test-helper.js'; +import { config as settings } from '../../../../lib/config.js'; +import { RedisCache } from '../../../../lib/infrastructure/caches/RedisCache.js'; describe('Unit | Infrastructure | Cache | redis-cache', function () { let stubbedClient; diff --git a/api/tests/unit/infrastructure/datasources/learning-content/area-datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/area-datasource_test.js index cf4c11ad5a9..0a0c496b8cc 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/area-datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/area-datasource_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../../test-helper'); -const { areaDatasource } = require('../../../../../lib/infrastructure/datasources/learning-content/area-datasource'); -const lcms = require('../../../../../lib/infrastructure/lcms'); +import { expect, sinon } from '../../../../test-helper.js'; +import { areaDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/area-datasource.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; describe('Unit | Infrastructure | Datasource | Learning Content | AreaDatasource', function () { describe('#findByRecordIds', function () { diff --git a/api/tests/unit/infrastructure/datasources/learning-content/challenge-datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/challenge-datasource_test.js index 544a8b0ae4b..7d060f6bd28 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/challenge-datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/challenge-datasource_test.js @@ -1,10 +1,8 @@ -const _ = require('lodash'); -const { expect, sinon } = require('../../../../test-helper'); -const lcms = require('../../../../../lib/infrastructure/lcms'); -const { - challengeDatasource, -} = require('../../../../../lib/infrastructure/datasources/learning-content/challenge-datasource'); -const { learningContentCache } = require('../../../../../lib/infrastructure/caches/learning-content-cache'); +import _ from 'lodash'; +import { expect, sinon } from '../../../../test-helper.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; +import { challengeDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/challenge-datasource.js'; +import { learningContentCache } from '../../../../../lib/infrastructure/caches/learning-content-cache.js'; describe('Unit | Infrastructure | Datasource | Learning Content | ChallengeDatasource', function () { let competence1, diff --git a/api/tests/unit/infrastructure/datasources/learning-content/competence-datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/competence-datasource_test.js index bf42ce45d33..013c58bf214 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/competence-datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/competence-datasource_test.js @@ -1,9 +1,7 @@ -const { expect, sinon } = require('../../../../test-helper'); -const { - competenceDatasource, -} = require('../../../../../lib/infrastructure/datasources/learning-content/competence-datasource'); -const lcms = require('../../../../../lib/infrastructure/lcms'); -const { learningContentCache } = require('../../../../../lib/infrastructure/caches/learning-content-cache'); +import { expect, sinon } from '../../../../test-helper.js'; +import { competenceDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/competence-datasource.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; +import { learningContentCache } from '../../../../../lib/infrastructure/caches/learning-content-cache.js'; describe('Unit | Infrastructure | Datasource | Learning Content | CompetenceDatasource', function () { beforeEach(function () { diff --git a/api/tests/unit/infrastructure/datasources/learning-content/datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/datasource_test.js index 6d80521968c..b0d37eb0170 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/datasource_test.js @@ -1,8 +1,8 @@ -const { expect, sinon } = require('../../../../test-helper'); -const dataSource = require('../../../../../lib/infrastructure/datasources/learning-content/datasource'); -const lcms = require('../../../../../lib/infrastructure/lcms'); -const LearningContentResourceNotFound = require('../../../../../lib/infrastructure/datasources/learning-content/LearningContentResourceNotFound'); -const { learningContentCache } = require('../../../../../lib/infrastructure/caches/learning-content-cache'); +import { expect, sinon } from '../../../../test-helper.js'; +import * as dataSource from '../../../../../lib/infrastructure/datasources/learning-content/datasource.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; +import { LearningContentResourceNotFound } from '../../../../../lib/infrastructure/datasources/learning-content/LearningContentResourceNotFound.js'; +import { learningContentCache } from '../../../../../lib/infrastructure/caches/learning-content-cache.js'; describe('Unit | Infrastructure | Datasource | Learning Content | datasource', function () { let someDatasource; diff --git a/api/tests/unit/infrastructure/datasources/learning-content/framework-datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/framework-datasource_test.js index 075fb6a23c4..d6a810b9586 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/framework-datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/framework-datasource_test.js @@ -1,8 +1,6 @@ -const { expect, sinon } = require('../../../../test-helper'); -const { - frameworkDatasource, -} = require('../../../../../lib/infrastructure/datasources/learning-content/framework-datasource'); -const lcms = require('../../../../../lib/infrastructure/lcms'); +import { expect, sinon } from '../../../../test-helper.js'; +import { frameworkDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/framework-datasource.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; describe('Unit | Infrastructure | Datasource | Learning Content | FrameworkDatasource', function () { describe('#list', function () { diff --git a/api/tests/unit/infrastructure/datasources/learning-content/skill-datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/skill-datasource_test.js index d0db9ff6701..97ab595f0c2 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/skill-datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/skill-datasource_test.js @@ -1,8 +1,8 @@ -const { expect, sinon } = require('../../../../test-helper'); -const _ = require('lodash'); -const { skillDatasource } = require('../../../../../lib/infrastructure/datasources/learning-content/skill-datasource'); -const lcms = require('../../../../../lib/infrastructure/lcms'); -const { learningContentCache } = require('../../../../../lib/infrastructure/caches/learning-content-cache'); +import { expect, sinon } from '../../../../test-helper.js'; +import _ from 'lodash'; +import { skillDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/skill-datasource.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; +import { learningContentCache } from '../../../../../lib/infrastructure/caches/learning-content-cache.js'; describe('Unit | Infrastructure | Datasource | LearningContent | SkillDatasource', function () { beforeEach(function () { diff --git a/api/tests/unit/infrastructure/datasources/learning-content/thematic-datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/thematic-datasource_test.js index 412c67c58e1..0d28e78f315 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/thematic-datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/thematic-datasource_test.js @@ -1,8 +1,6 @@ -const { sinon, expect } = require('../../../../test-helper'); -const lcms = require('../../../../../lib/infrastructure/lcms'); -const { - thematicDatasource, -} = require('../../../../../lib/infrastructure/datasources/learning-content/thematic-datasource'); +import { sinon, expect } from '../../../../test-helper.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; +import { thematicDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/thematic-datasource.js'; describe('Unit | Infrastructure | Datasource | Learning Content | ThematicDatasource', function () { describe('#findByCompetenceIds', function () { diff --git a/api/tests/unit/infrastructure/datasources/learning-content/tube-datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/tube-datasource_test.js index 92d7a3bdc5e..405fca16314 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/tube-datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/tube-datasource_test.js @@ -1,8 +1,8 @@ -const _ = require('lodash'); -const { expect, sinon } = require('../../../../test-helper'); -const lcms = require('../../../../../lib/infrastructure/lcms'); -const { tubeDatasource } = require('../../../../../lib/infrastructure/datasources/learning-content/tube-datasource'); -const { learningContentCache } = require('../../../../../lib/infrastructure/caches/learning-content-cache'); +import _ from 'lodash'; +import { expect, sinon } from '../../../../test-helper.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; +import { tubeDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/tube-datasource.js'; +import { learningContentCache } from '../../../../../lib/infrastructure/caches/learning-content-cache.js'; describe('Unit | Infrastructure | Datasource | Learning Content | TubeDatasource', function () { beforeEach(function () { diff --git a/api/tests/unit/infrastructure/datasources/learning-content/tutorial-datasource_test.js b/api/tests/unit/infrastructure/datasources/learning-content/tutorial-datasource_test.js index 257cf23f970..bb199588860 100644 --- a/api/tests/unit/infrastructure/datasources/learning-content/tutorial-datasource_test.js +++ b/api/tests/unit/infrastructure/datasources/learning-content/tutorial-datasource_test.js @@ -1,10 +1,8 @@ -const _ = require('lodash'); -const { expect, sinon } = require('../../../../test-helper'); -const lcms = require('../../../../../lib/infrastructure/lcms'); -const { - tutorialDatasource, -} = require('../../../../../lib/infrastructure/datasources/learning-content/tutorial-datasource'); -const { learningContentCache } = require('../../../../../lib/infrastructure/caches/learning-content-cache'); +import _ from 'lodash'; +import { expect, sinon } from '../../../../test-helper.js'; +import { lcms } from '../../../../../lib/infrastructure/lcms.js'; +import { tutorialDatasource } from '../../../../../lib/infrastructure/datasources/learning-content/tutorial-datasource.js'; +import { learningContentCache } from '../../../../../lib/infrastructure/caches/learning-content-cache.js'; describe('Unit | Infrastructure | Datasource | Learning Content | TutorialDatasource', function () { beforeEach(function () { diff --git a/api/tests/unit/infrastructure/events/EventBus_test.js b/api/tests/unit/infrastructure/events/EventBus_test.js index 0c4813d989b..a01f892c0bb 100644 --- a/api/tests/unit/infrastructure/events/EventBus_test.js +++ b/api/tests/unit/infrastructure/events/EventBus_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const Event = require('../../../../lib/domain/events/Event'); -const EventBus = require('../../../../lib/infrastructure/events/EventBus'); +import { expect, sinon } from '../../../test-helper.js'; +import { Event } from '../../../../lib/domain/events/Event.js'; +import { EventBus } from '../../../../lib/infrastructure/events/EventBus.js'; describe('Unit | Infrastructure | Events | EventBus', function () { describe('#publish', function () { diff --git a/api/tests/unit/infrastructure/events/handlers/LogEvent_test.js b/api/tests/unit/infrastructure/events/handlers/LogEvent_test.js index ad0cc2dc249..90526eeea24 100644 --- a/api/tests/unit/infrastructure/events/handlers/LogEvent_test.js +++ b/api/tests/unit/infrastructure/events/handlers/LogEvent_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../../test-helper'); -const Event = require('../../../../../lib/domain/events/Event'); -const LogEvent = require('../../../../../lib/infrastructure/events/subscribers/LogEvent'); +import { expect, sinon } from '../../../../test-helper.js'; +import { Event } from '../../../../../lib/domain/events/Event.js'; +import { LogEvent } from '../../../../../lib/infrastructure/events/subscribers/LogEvent.js'; describe('Unit | Infrastructure | Events | Handler | LogEvent', function () { describe('#handle', function () { diff --git a/api/tests/unit/infrastructure/events/handlers/ScheduleParticipationResultCalculationJob_test.js b/api/tests/unit/infrastructure/events/handlers/ScheduleParticipationResultCalculationJob_test.js index 6c728b013f2..8477a575646 100644 --- a/api/tests/unit/infrastructure/events/handlers/ScheduleParticipationResultCalculationJob_test.js +++ b/api/tests/unit/infrastructure/events/handlers/ScheduleParticipationResultCalculationJob_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../../test-helper'); -const Event = require('../../../../../lib/domain/events/Event'); -const ScheduleParticipationResultCalculationJob = require('../../../../../lib/infrastructure/events/subscribers/ScheduleParticipationResultCalculationJob'); +import { expect, sinon } from '../../../../test-helper.js'; +import { Event } from '../../../../../lib/domain/events/Event.js'; +import { ScheduleParticipationResultCalculationJob } from '../../../../../lib/infrastructure/events/subscribers/ScheduleParticipationResultCalculationJob.js'; describe('Unit | Infrastructure | Events | Handler | ParticipationResultCalculation', function () { describe('#handle', function () { diff --git a/api/tests/unit/infrastructure/events/handlers/ScheduleSendSharedParticipationResultsToPoleEmploiJob_test.js b/api/tests/unit/infrastructure/events/handlers/ScheduleSendSharedParticipationResultsToPoleEmploiJob_test.js index 2b382f3d5e9..ef729a48fc3 100644 --- a/api/tests/unit/infrastructure/events/handlers/ScheduleSendSharedParticipationResultsToPoleEmploiJob_test.js +++ b/api/tests/unit/infrastructure/events/handlers/ScheduleSendSharedParticipationResultsToPoleEmploiJob_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../../test-helper'); -const Event = require('../../../../../lib/domain/events/Event'); -const ScheduleSendSharedParticipationResultsToPoleEmploiJob = require('../../../../../lib/infrastructure/events/subscribers/ScheduleSendSharedParticipationResultsToPoleEmploiJob'); +import { expect, sinon } from '../../../../test-helper.js'; +import { Event } from '../../../../../lib/domain/events/Event.js'; +import { ScheduleSendSharedParticipationResultsToPoleEmploiJob } from '../../../../../lib/infrastructure/events/subscribers/ScheduleSendSharedParticipationResultsToPoleEmploiJob.js'; describe('Unit | Infrastructure | Events | Handler | SharedParticipationResultsToPoleEmploi', function () { describe('#handle', function () { diff --git a/api/tests/unit/infrastructure/exports/campaigns/campaign-profile-collection-result-line_test.js b/api/tests/unit/infrastructure/exports/campaigns/campaign-profile-collection-result-line_test.js index a0d39352d92..9519b9c41d1 100644 --- a/api/tests/unit/infrastructure/exports/campaigns/campaign-profile-collection-result-line_test.js +++ b/api/tests/unit/infrastructure/exports/campaigns/campaign-profile-collection-result-line_test.js @@ -1,8 +1,7 @@ -const { domainBuilder, expect, sinon } = require('../../../../test-helper'); - -const CampaignProfilesCollectionResultLine = require('../../../../../lib/infrastructure/exports/campaigns/campaign-profiles-collection-result-line'); -const PlacementProfile = require('../../../../../lib/domain/models/PlacementProfile'); -const { getI18n } = require('../../../../tooling/i18n/i18n'); +import { domainBuilder, expect, sinon } from '../../../../test-helper.js'; +import { CampaignProfilesCollectionResultLine } from '../../../../../lib/infrastructure/exports/campaigns/campaign-profiles-collection-result-line.js'; +import { PlacementProfile } from '../../../../../lib/domain/models/PlacementProfile.js'; +import { getI18n } from '../../../../tooling/i18n/i18n.js'; describe('Unit | Serializer | CSV | campaign-profiles-collection-result-line', function () { describe('#toCsvLine', function () { diff --git a/api/tests/unit/infrastructure/external-storage/cpf-external-storage_test.js b/api/tests/unit/infrastructure/external-storage/cpf-external-storage_test.js index d0b110f11ca..c6b6f5555d4 100644 --- a/api/tests/unit/infrastructure/external-storage/cpf-external-storage_test.js +++ b/api/tests/unit/infrastructure/external-storage/cpf-external-storage_test.js @@ -1,7 +1,9 @@ -const { expect, sinon } = require('../../../test-helper'); -const cpfExternalStorage = require('../../../../lib/infrastructure/external-storage/cpf-external-storage'); -const { cpf } = require('../../../../lib/config'); -const _ = require('lodash'); +import { expect, sinon } from '../../../test-helper.js'; +import * as cpfExternalStorage from '../../../../lib/infrastructure/external-storage/cpf-external-storage.js'; +import { config } from '../../../../lib/config.js'; +import _ from 'lodash'; + +const { cpf } = config; describe('Unit | Infrastructure | external-storage | cpf-external-storage', function () { let s3Utils; diff --git a/api/tests/unit/infrastructure/externals/pole-emploi/PoleEmploiPayload_test.js b/api/tests/unit/infrastructure/externals/pole-emploi/PoleEmploiPayload_test.js index cb184b5c7d8..4fe0a079014 100644 --- a/api/tests/unit/infrastructure/externals/pole-emploi/PoleEmploiPayload_test.js +++ b/api/tests/unit/infrastructure/externals/pole-emploi/PoleEmploiPayload_test.js @@ -1,5 +1,5 @@ -const PoleEmploiPayload = require('../../../../../lib/infrastructure/externals/pole-emploi/PoleEmploiPayload'); -const { expect, domainBuilder } = require('../../../../test-helper'); +import { PoleEmploiPayload } from '../../../../../lib/infrastructure/externals/pole-emploi/PoleEmploiPayload.js'; +import { expect, domainBuilder } from '../../../../test-helper.js'; describe('Unit | Infrastructure | Externals | Pole-Emploi | PoleEmploiPayload', function () { let user; diff --git a/api/tests/unit/infrastructure/externals/pole-emploi/diabled-pole-emploi-notifier_test.js b/api/tests/unit/infrastructure/externals/pole-emploi/diabled-pole-emploi-notifier_test.js index 7ef559ce2d1..06cafcf9f59 100644 --- a/api/tests/unit/infrastructure/externals/pole-emploi/diabled-pole-emploi-notifier_test.js +++ b/api/tests/unit/infrastructure/externals/pole-emploi/diabled-pole-emploi-notifier_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const { notify } = require('../../../../../lib/infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier'); +import { expect } from '../../../../test-helper.js'; +import { notify } from '../../../../../lib/infrastructure/externals/pole-emploi/disabled-pole-emploi-notifier.js'; describe('Unit | Infrastructure | Externals/Pole-Emploi | pole-emploi-notifier', function () { describe('#notify', function () { diff --git a/api/tests/unit/infrastructure/externals/pole-emploi/pole-emploi-notifier_test.js b/api/tests/unit/infrastructure/externals/pole-emploi/pole-emploi-notifier_test.js deleted file mode 100644 index 474117d0dea..00000000000 --- a/api/tests/unit/infrastructure/externals/pole-emploi/pole-emploi-notifier_test.js +++ /dev/null @@ -1,348 +0,0 @@ -const querystring = require('querystring'); -const dayjs = require('dayjs'); -const { expect, sinon, catchErr, domainBuilder } = require('../../../../test-helper'); -const settings = require('../../../../../lib/config'); -const { UnexpectedUserAccountError } = require('../../../../../lib/domain/errors'); -const AuthenticationMethod = require('../../../../../lib/domain/models/AuthenticationMethod'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); -const { notify } = require('../../../../../lib/infrastructure/externals/pole-emploi/pole-emploi-notifier'); -const httpAgent = require('../../../../../lib/infrastructure/http/http-agent'); -const authenticationMethodRepository = require('../../../../../lib/infrastructure/repositories/authentication-method-repository'); -const monitoringTools = require('../../../../../lib/infrastructure/monitoring-tools'); - -describe('Unit | Infrastructure | Externals/Pole-Emploi | pole-emploi-notifier', function () { - describe('#notify', function () { - let clock; - - // TODO: Fix this the next time the file is edited. - // eslint-disable-next-line mocha/no-setup-in-describe - const originPoleEmploiSendingUrl = settings.poleEmploi.sendingUrl; - // TODO: Fix this the next time the file is edited. - // eslint-disable-next-line mocha/no-setup-in-describe - const originPoleEmploiTokenUrl = settings.poleEmploi.tokenUrl; - - const userId = 123; - let payload; - const code = 'someCode'; - const data = { - access_token: 'accessToken', - refresh_token: 'refreshToken', - expires_in: 10, - }; - - const accessToken = 'someAccessToken'; - const refreshToken = 'someRefreshToken'; - const expiredDate = new Date('2021-01-01'); - const authenticationMethod = { authenticationComplement: { accessToken, expiredDate, refreshToken } }; - - // TODO: Fix this the next time the file is edited. - // eslint-disable-next-line mocha/no-setup-in-describe - const poleEmploiSending = domainBuilder.buildPoleEmploiSending(); - - beforeEach(function () { - clock = sinon.useFakeTimers(Date.now()); - sinon.stub(httpAgent, 'post'); - sinon.stub(authenticationMethodRepository, 'findOneByUserIdAndIdentityProvider'); - sinon.stub(authenticationMethodRepository, 'updateAuthenticationComplementByUserIdAndIdentityProvider'); - sinon.stub(monitoringTools, 'logErrorWithCorrelationIds'); - sinon.stub(monitoringTools, 'logInfoWithCorrelationIds'); - - settings.poleEmploi.tokenUrl = 'someTokenUrlToPoleEmploi'; - settings.poleEmploi.sendingUrl = 'someSendingUrlToPoleEmploi'; - payload = { test: { progression: 0 } }; - }); - - afterEach(function () { - clock.restore(); - settings.poleEmploi.sendingUrl = originPoleEmploiSendingUrl; - settings.poleEmploi.tokenUrl = originPoleEmploiTokenUrl; - - httpAgent.post.restore(); - authenticationMethodRepository.findOneByUserIdAndIdentityProvider.restore(); - authenticationMethodRepository.updateAuthenticationComplementByUserIdAndIdentityProvider.restore(); - }); - - it('should throw an error if the user is not known as PoleEmploi user', async function () { - // given - authenticationMethodRepository.findOneByUserIdAndIdentityProvider - .withArgs({ userId, identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code }) - .resolves(null); - - // when - const error = await catchErr(notify)(userId, payload); - - // then - expect(error).to.be.instanceOf(UnexpectedUserAccountError); - expect(error.message).to.equal("Le compte utilisateur n'est pas rattaché à l'organisation Pôle Emploi"); - }); - - context('when access token is valid', function () { - it('should send the notification to Pole Emploi', async function () { - // given - const expiredDate = dayjs().add(10, 'm').toDate(); - const authenticationMethod = { authenticationComplement: { accessToken, expiredDate, refreshToken } }; - - const expectedHearders = { - Authorization: `Bearer ${authenticationMethod.authenticationComplement.accessToken}`, - 'Content-type': 'application/json', - Accept: 'application/json', - 'Service-source': 'Pix', - }; - - authenticationMethodRepository.findOneByUserIdAndIdentityProvider - .withArgs({ userId, identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code }) - .resolves(authenticationMethod); - httpAgent.post.resolves({ isSuccessful: true, code }); - - // when - await notify(userId, payload, poleEmploiSending); - - // then - expect(httpAgent.post).to.have.been.calledWithExactly({ - url: settings.poleEmploi.sendingUrl, - payload, - headers: expectedHearders, - timeout: settings.partner.fetchTimeOut, - }); - }); - - it('should log the notification to Pole Emploi', async function () { - // given - payload = { test: { progression: 100 } }; - const expiredDate = dayjs().add(10, 'm').toDate(); - const authenticationMethod = { authenticationComplement: { accessToken, expiredDate, refreshToken } }; - - authenticationMethodRepository.findOneByUserIdAndIdentityProvider - .withArgs({ userId, identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code }) - .resolves(authenticationMethod); - httpAgent.post.resolves({ isSuccessful: true, code }); - // when - await notify(userId, payload, poleEmploiSending); - - // then - expect(monitoringTools.logInfoWithCorrelationIds).to.have.been.calledWith({ - event: 'participation-send-pole-emploi', - 'pole-emploi-action': 'send-results', - 'participation-state': 'PARTICIPATION_COMPLETED', - }); - }); - }); - - context('when access token is invalid', function () { - it('should try to refresh the access token', async function () { - // given - const expectedHeaders = { 'content-type': 'application/x-www-form-urlencoded' }; - authenticationMethodRepository.findOneByUserIdAndIdentityProvider - .withArgs({ userId, identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code }) - .resolves(authenticationMethod); - const params = { - grant_type: 'refresh_token', - refresh_token: refreshToken, - client_secret: settings.poleEmploi.clientSecret, - client_id: settings.poleEmploi.clientId, - }; - httpAgent.post.resolves({ isSuccessful: true, code, data }); - - // when - await notify(userId, payload, poleEmploiSending); - - // then - expect(httpAgent.post).to.have.been.calledWithExactly({ - url: settings.poleEmploi.tokenUrl, - payload: querystring.stringify(params), - headers: expectedHeaders, - timeout: settings.partner.fetchTimeOut, - }); - }); - - it('logs the attempt to refresh the access token', async function () { - // given - authenticationMethodRepository.findOneByUserIdAndIdentityProvider - .withArgs({ userId, identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code }) - .resolves(authenticationMethod); - httpAgent.post.resolves({ isSuccessful: true, code, data }); - - // when - await notify(userId, payload, poleEmploiSending); - - // then - expect(monitoringTools.logInfoWithCorrelationIds).to.have.been.calledWith({ - event: 'participation-send-pole-emploi', - 'pole-emploi-action': 'refresh-token', - 'participation-state': 'PARTICIPATION_STARTED', - 'expired-date': expiredDate, - }); - }); - - context('when it succeeds', function () { - it('should update the authentication method', async function () { - // given - authenticationMethodRepository.findOneByUserIdAndIdentityProvider - .withArgs({ userId, identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code }) - .resolves(authenticationMethod); - httpAgent.post.resolves({ isSuccessful: true, code, data }); - const authenticationComplement = new AuthenticationMethod.OidcAuthenticationComplement({ - accessToken: data['access_token'], - refreshToken: data['refresh_token'], - expiredDate: dayjs().add(data['expires_in'], 's').toDate(), - }); - - // when - await notify(userId, payload, poleEmploiSending); - - // then - expect( - authenticationMethodRepository.updateAuthenticationComplementByUserIdAndIdentityProvider - ).to.have.been.calledWith({ - authenticationComplement, - userId, - identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code, - }); - }); - - it('should send the notification to Pole Emploi', async function () { - // given - const authenticationComplement = new AuthenticationMethod.OidcAuthenticationComplement({ - accessToken: data['access_token'], - refreshToken: data['refresh_token'], - expiredDate: dayjs().add(data['expires_in'], 's').toDate(), - }); - - const expectedHeaders = { - Authorization: `Bearer ${authenticationComplement.accessToken}`, - 'Content-type': 'application/json', - Accept: 'application/json', - 'Service-source': 'Pix', - }; - - authenticationMethodRepository.updateAuthenticationComplementByUserIdAndIdentityProvider - .withArgs({ authenticationComplement, userId }) - .resolves(); - - authenticationMethodRepository.findOneByUserIdAndIdentityProvider - .withArgs({ userId, identityProvider: OidcIdentityProviders.POLE_EMPLOI.service.code }) - .resolves(authenticationMethod); - - httpAgent.post - .onFirstCall() - .resolves({ isSuccessful: true, code, data }) - .onSecondCall() - .resolves({ isSuccessful: true, code }); - - // when - await notify(userId, payload, poleEmploiSending); - - // then - expect(httpAgent.post).to.have.been.calledWithExactly({ - url: settings.poleEmploi.sendingUrl, - payload, - headers: expectedHeaders, - timeout: settings.partner.fetchTimeOut, - }); - }); - }); - - context('when it fails', function () { - it('should log error and return httpResponse with error if retrieve PE tokens fails', async function () { - // given - const errorData = { - error: 'invalid_client', - error_description: 'Invalid authentication method for accessing this endpoint.', - }; - const tokenResponse = { - isSuccessful: false, - code: 400, - data: errorData, - }; - - authenticationMethodRepository.findOneByUserIdAndIdentityProvider.resolves(authenticationMethod); - - httpAgent.post - .withArgs({ - url: settings.poleEmploi.tokenUrl, - headers: sinon.match.any, - payload: sinon.match.any, - timeout: settings.partner.fetchTimeOut, - }) - .resolves(tokenResponse); - - monitoringTools.logErrorWithCorrelationIds.resolves(); - - const expectedLoggerMessage = JSON.stringify(tokenResponse.data); - const expectedResult = { - code: tokenResponse.code, - isSuccessful: tokenResponse.isSuccessful, - }; - - // when - const result = await notify(userId, payload, poleEmploiSending); - - // then - expect(monitoringTools.logErrorWithCorrelationIds).to.have.been.calledWith({ - event: 'participation-send-pole-emploi', - 'pole-emploi-action': 'refresh-token', - 'participation-state': 'PARTICIPATION_STARTED', - message: expectedLoggerMessage, - }); - expect(result).to.deep.equal(expectedResult); - }); - - it('should log error and return httpResponse with error if sending to PE fails', async function () { - // given - payload = { test: { dateValidation: new Date() } }; - - const tokenResponse = { - isSuccessful: true, - data: { - access_token: 'TOKEN', - }, - }; - const httpResponse = { - isSuccessful: false, - code: 429, - data: 'Too Many Requests', - }; - - authenticationMethodRepository.findOneByUserIdAndIdentityProvider.resolves(authenticationMethod); - authenticationMethodRepository.updateAuthenticationComplementByUserIdAndIdentityProvider.resolves(); - - httpAgent.post - .withArgs({ - url: settings.poleEmploi.tokenUrl, - headers: sinon.match.any, - payload: sinon.match.any, - timeout: settings.partner.fetchTimeOut, - }) - .resolves(tokenResponse) - .withArgs({ - url: settings.poleEmploi.sendingUrl, - headers: sinon.match.any, - payload: sinon.match.any, - timeout: settings.partner.fetchTimeOut, - }) - .resolves(httpResponse); - - monitoringTools.logErrorWithCorrelationIds.resolves(); - - const expectedLoggerMessage = httpResponse.data; - const expectedResult = { - code: httpResponse.code, - isSuccessful: httpResponse.isSuccessful, - }; - - // when - const result = await notify(userId, payload, poleEmploiSending); - - // then - expect(monitoringTools.logErrorWithCorrelationIds).to.have.been.calledWith({ - event: 'participation-send-pole-emploi', - 'pole-emploi-action': 'send-results', - 'participation-state': 'PARTICIPATION_SHARED', - message: expectedLoggerMessage, - }); - expect(result).to.deep.equal(expectedResult); - }); - }); - }); - }); -}); diff --git a/api/tests/unit/infrastructure/helpers/csv.js b/api/tests/unit/infrastructure/helpers/csv.js index 015672df812..4e8cf4564c1 100644 --- a/api/tests/unit/infrastructure/helpers/csv.js +++ b/api/tests/unit/infrastructure/helpers/csv.js @@ -1,7 +1,12 @@ -const { expect, catchErr } = require('../../../test-helper'); -const { FileValidationError } = require('../../../../lib/domain/errors'); -const { parseCsvWithHeader, checkCsvHeader } = require('../../../../lib/infrastructure/helpers/csv'); -const { isEmpty } = require('lodash'); +import { expect, catchErr } from '../../../test-helper.js'; +import { FileValidationError } from '../../../../lib/domain/errors.js'; +import { parseCsvWithHeader, checkCsvHeader } from '../../../../lib/infrastructure/helpers/csv.js'; +import lodash from 'lodash'; + +const { isEmpty } = lodash; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Unit | Infrastructure | Helpers | csv.js', function () { const emptyFilePath = `${__dirname}/files/organizations-empty-file.csv`; diff --git a/api/tests/unit/infrastructure/http/errors-helper_test.js b/api/tests/unit/infrastructure/http/errors-helper_test.js index 130ebbd0525..ecf3db6bcc6 100644 --- a/api/tests/unit/infrastructure/http/errors-helper_test.js +++ b/api/tests/unit/infrastructure/http/errors-helper_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../../test-helper'); - -const { serializeHttpErrorResponse } = require('../../../../lib/infrastructure/http/errors-helper'); +import { expect } from '../../../test-helper.js'; +import { serializeHttpErrorResponse } from '../../../../lib/infrastructure/http/errors-helper.js'; describe('serializeHttpErrorResponse', function () { describe('when http error data is null', function () { diff --git a/api/tests/unit/infrastructure/http/http-agent_test.js b/api/tests/unit/infrastructure/http/http-agent_test.js index ab06b1418ad..58e030c6d29 100644 --- a/api/tests/unit/infrastructure/http/http-agent_test.js +++ b/api/tests/unit/infrastructure/http/http-agent_test.js @@ -1,14 +1,12 @@ -const { expect, sinon } = require('../../../test-helper'); -const axios = require('axios'); -const { post, get } = require('../../../../lib/infrastructure/http/http-agent'); -const monitoringTools = require('../../../../lib/infrastructure/monitoring-tools'); +import { expect, sinon } from '../../../test-helper.js'; +import axios from 'axios'; +import { httpAgent } from '../../../../lib/infrastructure/http/http-agent.js'; +import { monitoringTools } from '../../../../lib/infrastructure/monitoring-tools.js'; + +const { post, get } = httpAgent; describe('Unit | Infrastructure | http | http-agent', function () { describe('#post', function () { - afterEach(function () { - axios.post.restore(); - }); - it('should return the response status and success from the http call when successful', async function () { // given const url = 'someUrl'; @@ -122,9 +120,6 @@ describe('Unit | Infrastructure | http | http-agent', function () { }); }); describe('#get', function () { - afterEach(function () { - axios.get.restore(); - }); it('should return the response status and success from the http call when successful', async function () { // given const url = 'someUrl'; diff --git a/api/tests/unit/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler_test.js b/api/tests/unit/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler_test.js index 465e9a531f1..c2bcdd6f4c4 100644 --- a/api/tests/unit/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler_test.js +++ b/api/tests/unit/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler_test.js @@ -1,7 +1,7 @@ -const { expect, sinon } = require('../../../../test-helper'); -const CampaignParticipationResultsShared = require('../../../../../lib/domain/events/CampaignParticipationResultsShared'); -const usecases = require('../../../../../lib/domain/usecases/index.js'); -const ParticipationResultCalculationJobHandler = require('../../../../../lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler'); +import { expect, sinon } from '../../../../test-helper.js'; +import { CampaignParticipationResultsShared } from '../../../../../lib/domain/events/CampaignParticipationResultsShared.js'; +import { usecases } from '../../../../../lib/domain/usecases/index.js'; +import { ParticipationResultCalculationJobHandler } from '../../../../../lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler.js'; describe('Unit | Infrastructure | Jobs | saveComputedCampaignParticipationResult', function () { context('#handle', function () { diff --git a/api/tests/unit/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler_test.js b/api/tests/unit/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler_test.js index 375ef5a63c1..2456aae12a4 100644 --- a/api/tests/unit/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler_test.js +++ b/api/tests/unit/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler_test.js @@ -1,7 +1,7 @@ -const { expect, sinon } = require('../../../../test-helper'); -const CampaignParticipationResultsShared = require('../../../../../lib/domain/events/CampaignParticipationResultsShared'); -const SendSharedParticipationResultsToPoleEmploiHandler = require('../../../../../lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler'); -const usecases = require('../../../../../lib/domain/usecases/index.js'); +import { expect, sinon } from '../../../../test-helper.js'; +import { CampaignParticipationResultsShared } from '../../../../../lib/domain/events/CampaignParticipationResultsShared.js'; +import { SendSharedParticipationResultsToPoleEmploiHandler } from '../../../../../lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler.js'; +import { usecases } from '../../../../../lib/domain/usecases/index.js'; describe('Unit | Infrastructure | Jobs | SendSharedParticipationResultsToPoleEmploiHandler', function () { let event; diff --git a/api/tests/unit/infrastructure/jobs/cpf-export/handlers/create-and-upload_test.js b/api/tests/unit/infrastructure/jobs/cpf-export/handlers/create-and-upload_test.js index 4f089df86a9..9ddc0131e5f 100644 --- a/api/tests/unit/infrastructure/jobs/cpf-export/handlers/create-and-upload_test.js +++ b/api/tests/unit/infrastructure/jobs/cpf-export/handlers/create-and-upload_test.js @@ -1,10 +1,15 @@ -const { domainBuilder, expect, sinon } = require('../../../../../test-helper'); -const createAndUpload = require('../../../../../../lib/infrastructure/jobs/cpf-export/handlers/create-and-upload'); -const { PassThrough, Readable } = require('stream'); -const noop = require('lodash/noop'); -const dayjs = require('dayjs'); -const utc = require('dayjs/plugin/utc'); -const timezone = require('dayjs/plugin/timezone'); +import { domainBuilder, expect, sinon } from '../../../../../test-helper.js'; +import { createAndUpload } from '../../../../../../lib/infrastructure/jobs/cpf-export/handlers/create-and-upload.js'; +import stream from 'stream'; +import * as uuidService from 'uuid'; + +const { PassThrough, Readable } = stream; + +import lodash from 'lodash'; +const { noop } = lodash; +import dayjs from 'dayjs'; +import utc from 'dayjs/plugin/utc.js'; +import timezone from 'dayjs/plugin/timezone.js'; dayjs.extend(utc); dayjs.extend(timezone); @@ -66,6 +71,7 @@ describe('Unit | Infrastructure | jobs | cpf-export | create-and-upload', functi expect(cpfCertificationXmlExportService.buildXmlExport).to.have.been.calledWith({ cpfCertificationResults, writableStream: sinon.match(PassThrough), + uuidService, }); expect(cpfExternalStorage.upload).to.have.been.calledWith({ filename: 'pix-cpf-export-20220101-114327.xml.gz', diff --git a/api/tests/unit/infrastructure/jobs/cpf-export/handlers/planner_test.js b/api/tests/unit/infrastructure/jobs/cpf-export/handlers/planner_test.js index f9fea2f0766..616a73bae8f 100644 --- a/api/tests/unit/infrastructure/jobs/cpf-export/handlers/planner_test.js +++ b/api/tests/unit/infrastructure/jobs/cpf-export/handlers/planner_test.js @@ -1,9 +1,13 @@ -const { expect, sinon } = require('../../../../../test-helper'); -const planner = require('../../../../../../lib/infrastructure/jobs/cpf-export/handlers/planner'); -const dayjs = require('dayjs'); -const { cpf } = require('../../../../../../lib/config'); -const utc = require('dayjs/plugin/utc'); -const { noop } = require('lodash'); +import { expect, sinon } from '../../../../../test-helper.js'; +import { planner } from '../../../../../../lib/infrastructure/jobs/cpf-export/handlers/planner.js'; +import dayjs from 'dayjs'; +import { config } from '../../../../../../lib/config.js'; +const { cpf } = config; +import utc from 'dayjs/plugin/utc.js'; +import lodash from 'lodash'; + +const { noop } = lodash; + dayjs.extend(utc); describe('Unit | Infrastructure | jobs | cpf-export | planner', function () { diff --git a/api/tests/unit/infrastructure/jobs/cpf-export/handlers/send-email_test.js b/api/tests/unit/infrastructure/jobs/cpf-export/handlers/send-email_test.js index 92eff6ce445..92257278134 100644 --- a/api/tests/unit/infrastructure/jobs/cpf-export/handlers/send-email_test.js +++ b/api/tests/unit/infrastructure/jobs/cpf-export/handlers/send-email_test.js @@ -1,8 +1,8 @@ -const { expect, sinon } = require('../../../../../test-helper'); -const sendEmail = require('../../../../../../lib/infrastructure/jobs/cpf-export/handlers/send-email'); -const cronParser = require('cron-parser'); -const { cpf } = require('../../../../../../lib/config'); - +import { expect, sinon } from '../../../../../test-helper.js'; +import { sendEmail } from '../../../../../../lib/infrastructure/jobs/cpf-export/handlers/send-email.js'; +import cronParser from 'cron-parser'; +import { config } from '../../../../../../lib/config.js'; +const { cpf } = config; describe('Unit | Infrastructure | jobs | cpf-export | send-email', function () { let cpfExternalStorage; let mailService; diff --git a/api/tests/unit/infrastructure/lcms_test.js b/api/tests/unit/infrastructure/lcms_test.js index 10972b0fe2b..2c978c92593 100644 --- a/api/tests/unit/infrastructure/lcms_test.js +++ b/api/tests/unit/infrastructure/lcms_test.js @@ -1,6 +1,5 @@ -const { expect, nock, catchErr } = require('../../test-helper'); - -const lcms = require('../../../lib/infrastructure/lcms'); +import { expect, nock, catchErr } from '../../test-helper.js'; +import { lcms } from '../../../lib/infrastructure/lcms.js'; describe('Unit | Infrastructure | LCMS', function () { describe('#getLatestRelease', function () { diff --git a/api/tests/unit/infrastructure/mailers/MailingProvider_test.js b/api/tests/unit/infrastructure/mailers/MailingProvider_test.js index 00f98391bac..74be83470c1 100644 --- a/api/tests/unit/infrastructure/mailers/MailingProvider_test.js +++ b/api/tests/unit/infrastructure/mailers/MailingProvider_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const MailingProvider = require('../../../../lib/infrastructure/mailers/MailingProvider'); +import { expect } from '../../../test-helper.js'; +import { MailingProvider } from '../../../../lib/infrastructure/mailers/MailingProvider.js'; describe('Unit | Infrastructure | Mailers | MailingProvider', function () { describe('#sendEmail', function () { diff --git a/api/tests/unit/infrastructure/mailers/SendinblueProvider_test.js b/api/tests/unit/infrastructure/mailers/SendinblueProvider_test.js index e7f559db20e..72866956d71 100644 --- a/api/tests/unit/infrastructure/mailers/SendinblueProvider_test.js +++ b/api/tests/unit/infrastructure/mailers/SendinblueProvider_test.js @@ -1,10 +1,8 @@ -const { sinon, expect, nock, catchErr } = require('../../../test-helper'); -const { mailing } = require('../../../../lib/config'); - -const SendinblueProvider = require('../../../../lib/infrastructure/mailers/SendinblueProvider'); -const { - MailingProviderInvalidEmailError, -} = require('../../../../lib/infrastructure/mailers/MailingProviderInvalidEmailError'); +import { sinon, expect, nock, catchErr } from '../../../test-helper.js'; +import { config } from '../../../../lib/config.js'; +import { SendinblueProvider } from '../../../../lib/infrastructure/mailers/SendinblueProvider.js'; +import { MailingProviderInvalidEmailError } from '../../../../lib/infrastructure/mailers/MailingProviderInvalidEmailError.js'; +const { mailing } = config; describe('Unit | Class | SendinblueProvider', function () { beforeEach(function () { diff --git a/api/tests/unit/infrastructure/mailers/mailer_test.js b/api/tests/unit/infrastructure/mailers/mailer_test.js index 64770f545a9..5206d01e4f0 100644 --- a/api/tests/unit/infrastructure/mailers/mailer_test.js +++ b/api/tests/unit/infrastructure/mailers/mailer_test.js @@ -1,11 +1,10 @@ -const { expect, sinon } = require('../../../test-helper'); -const { mailing } = require('../../../../lib/config'); -const logger = require('../../../../lib/infrastructure/logger'); -const { Mailer } = require('../../../../lib/infrastructure/mailers/mailer'); -const EmailingAttempt = require('../../../../lib/domain/models/EmailingAttempt'); -const { - MailingProviderInvalidEmailError, -} = require('../../../../lib/infrastructure/mailers/MailingProviderInvalidEmailError'); +import { expect, sinon } from '../../../test-helper.js'; +import { config } from '../../../../lib/config.js'; +import { logger } from '../../../../lib/infrastructure/logger.js'; +import { Mailer } from '../../../../lib/infrastructure/mailers/mailer.js'; +import { EmailingAttempt } from '../../../../lib/domain/models/EmailingAttempt.js'; +import { MailingProviderInvalidEmailError } from '../../../../lib/infrastructure/mailers/MailingProviderInvalidEmailError.js'; +const { mailing } = config; describe('Unit | Infrastructure | Mailers | mailer', function () { let mailCheck; diff --git a/api/tests/unit/infrastructure/open-api-doc/pole-emploi/envois-doc_test.js b/api/tests/unit/infrastructure/open-api-doc/pole-emploi/envois-doc_test.js index d428f0afca2..3df2f85d2b3 100644 --- a/api/tests/unit/infrastructure/open-api-doc/pole-emploi/envois-doc_test.js +++ b/api/tests/unit/infrastructure/open-api-doc/pole-emploi/envois-doc_test.js @@ -1,5 +1,5 @@ -const { poleEmploiEnvoisDoc } = require('../../../../../lib/infrastructure/open-api-doc/pole-emploi/envois-doc'); -const { expect } = require('../../../../test-helper'); +import { poleEmploiEnvoisDoc } from '../../../../../lib/infrastructure/open-api-doc/pole-emploi/envois-doc.js'; +import { expect } from '../../../../test-helper.js'; describe('Unit | Infrastructure | Open API Doc | Pole Emploi | Envois Documentation', function () { it('should validate payload for a campaign participation', function () { diff --git a/api/tests/unit/infrastructure/open-api-doc/pole-emploi/erreur-doc_test.js b/api/tests/unit/infrastructure/open-api-doc/pole-emploi/erreur-doc_test.js index 92e7ab4ae4e..bc578479ac5 100644 --- a/api/tests/unit/infrastructure/open-api-doc/pole-emploi/erreur-doc_test.js +++ b/api/tests/unit/infrastructure/open-api-doc/pole-emploi/erreur-doc_test.js @@ -1,5 +1,5 @@ -const ErreurDoc = require('../../../../../lib/infrastructure/open-api-doc/pole-emploi/erreur-doc'); -const { expect } = require('../../../../test-helper'); +import { erreurDoc as ErreurDoc } from '../../../../../lib/infrastructure/open-api-doc/pole-emploi/erreur-doc.js'; +import { expect } from '../../../../test-helper.js'; describe('Unit | Infrastructure | Open API Doc | Pole Emploi | Erreur Documentation', function () { it('should validate payload for a campaign participation', function () { diff --git a/api/tests/unit/infrastructure/repositories/competence-tree-repository_test.js b/api/tests/unit/infrastructure/repositories/competence-tree-repository_test.js index 6ec195377c7..5eee6c26028 100644 --- a/api/tests/unit/infrastructure/repositories/competence-tree-repository_test.js +++ b/api/tests/unit/infrastructure/repositories/competence-tree-repository_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../../test-helper'); -const competenceTreeRepository = require('../../../../lib/infrastructure/repositories/competence-tree-repository'); -const CompetenceTree = require('../../../../lib/domain/models/CompetenceTree'); +import { expect, sinon } from '../../../test-helper.js'; +import * as competenceTreeRepository from '../../../../lib/infrastructure/repositories/competence-tree-repository.js'; +import { CompetenceTree } from '../../../../lib/domain/models/CompetenceTree.js'; describe('Unit | Repository | competence-tree-repository', function () { let areaRepository; diff --git a/api/tests/unit/infrastructure/repositories/correction-repository_test.js b/api/tests/unit/infrastructure/repositories/correction-repository_test.js index 290fcc0dc28..16046dbc8a6 100644 --- a/api/tests/unit/infrastructure/repositories/correction-repository_test.js +++ b/api/tests/unit/infrastructure/repositories/correction-repository_test.js @@ -1,12 +1,10 @@ -const { expect, sinon, domainBuilder } = require('../../../test-helper'); -const correctionRepository = require('../../../../lib/infrastructure/repositories/correction-repository'); -const { - challengeDatasource, -} = require('../../../../lib/infrastructure/datasources/learning-content/challenge-datasource'); -const { skillDatasource } = require('../../../../lib/infrastructure/datasources/learning-content/skill-datasource'); -const Correction = require('../../../../lib/domain/models/Correction'); -const ChallengeLearningContentDataObjectFixture = require('../../../tooling/fixtures/infrastructure/challengeLearningContentDataObjectFixture'); -const SkillLearningContentDataObjectFixture = require('../../../tooling/fixtures/infrastructure/skillLearningContentDataObjectFixture'); +import { expect, sinon, domainBuilder } from '../../../test-helper.js'; +import * as correctionRepository from '../../../../lib/infrastructure/repositories/correction-repository.js'; +import { challengeDatasource } from '../../../../lib/infrastructure/datasources/learning-content/challenge-datasource.js'; +import { skillDatasource } from '../../../../lib/infrastructure/datasources/learning-content/skill-datasource.js'; +import { Correction } from '../../../../lib/domain/models/Correction.js'; +import { ChallengeLearningContentDataObjectFixture } from '../../../tooling/fixtures/infrastructure/challengeLearningContentDataObjectFixture.js'; +import { SkillLearningContentDataObjectFixture } from '../../../tooling/fixtures/infrastructure/skillLearningContentDataObjectFixture.js'; describe('Unit | Repository | correction-repository', function () { let tutorialRepository; diff --git a/api/tests/unit/infrastructure/serializers/csv/campaign-profile-collection-export_test.js b/api/tests/unit/infrastructure/serializers/csv/campaign-profile-collection-export_test.js index 676ded70eea..815ccbd304a 100644 --- a/api/tests/unit/infrastructure/serializers/csv/campaign-profile-collection-export_test.js +++ b/api/tests/unit/infrastructure/serializers/csv/campaign-profile-collection-export_test.js @@ -1,8 +1,10 @@ -const { PassThrough } = require('stream'); -const { domainBuilder, expect, sinon, streamToPromise } = require('../../../../test-helper'); +import stream from 'stream'; -const CampaignProfilesCollectionExport = require('../../../../../lib/infrastructure/serializers/csv/campaign-profiles-collection-export'); -const { getI18n } = require('../../../../tooling/i18n/i18n'); +const { PassThrough } = stream; + +import { domainBuilder, expect, sinon, streamToPromise } from '../../../../test-helper.js'; +import { CampaignProfilesCollectionExport } from '../../../../../lib/infrastructure/serializers/csv/campaign-profiles-collection-export.js'; +import { getI18n } from '../../../../tooling/i18n/i18n.js'; describe('Unit | Serializer | CSV | campaign-profiles-collection-export', function () { describe('#export', function () { diff --git a/api/tests/unit/infrastructure/serializers/csv/csv-learner-parser_test.js b/api/tests/unit/infrastructure/serializers/csv/csv-learner-parser_test.js index 76211a236ae..9170d7f300e 100644 --- a/api/tests/unit/infrastructure/serializers/csv/csv-learner-parser_test.js +++ b/api/tests/unit/infrastructure/serializers/csv/csv-learner-parser_test.js @@ -1,9 +1,7 @@ -const iconv = require('iconv-lite'); -const { sinon, expect, catchErr } = require('../../../../test-helper'); -const { - CsvOrganizationLearnerParser, -} = require('../../../../../lib/infrastructure/serializers/csv/csv-learner-parser'); -const { CsvColumn } = require('../../../../../lib/infrastructure/serializers/csv/csv-column'); +import iconv from 'iconv-lite'; +import { sinon, expect, catchErr } from '../../../../test-helper.js'; +import { CsvOrganizationLearnerParser } from '../../../../../lib/infrastructure/serializers/csv/csv-learner-parser.js'; +import { CsvColumn } from '../../../../../lib/infrastructure/serializers/csv/csv-column.js'; class FakeLearnerSet { constructor() { diff --git a/api/tests/unit/infrastructure/serializers/csv/csv-parser_test.js b/api/tests/unit/infrastructure/serializers/csv/csv-parser_test.js index 3eaa28f59df..3bf3f5395d8 100644 --- a/api/tests/unit/infrastructure/serializers/csv/csv-parser_test.js +++ b/api/tests/unit/infrastructure/serializers/csv/csv-parser_test.js @@ -1,7 +1,7 @@ -const iconv = require('iconv-lite'); -const { expect, catchErr } = require('../../../../test-helper'); -const { CsvParser } = require('../../../../../lib/infrastructure/serializers/csv/csv-parser'); -const { CsvColumn } = require('../../../../../lib/infrastructure/serializers/csv/csv-column'); +import iconv from 'iconv-lite'; +import { expect, catchErr } from '../../../../test-helper.js'; +import { CsvParser } from '../../../../../lib/infrastructure/serializers/csv/csv-parser.js'; +import { CsvColumn } from '../../../../../lib/infrastructure/serializers/csv/csv-column.js'; describe('Unit | Infrastructure | CsvParser', function () { context('The header is correctly formed', function () { diff --git a/api/tests/unit/infrastructure/serializers/csv/csv-serializer_test.js b/api/tests/unit/infrastructure/serializers/csv/csv-serializer_test.js index 4df4f2a7d07..5999cb3f7b4 100644 --- a/api/tests/unit/infrastructure/serializers/csv/csv-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/csv/csv-serializer_test.js @@ -1,9 +1,9 @@ -const { expect, sinon, catchErr } = require('../../../../test-helper'); -const csvSerializer = require('../../../../../lib/infrastructure/serializers/csv/csv-serializer'); -const logger = require('../../../../../lib/infrastructure/logger'); -const _ = require('lodash'); -const { FileValidationError } = require('../../../../../lib/domain/errors'); -const { emptySession } = require('../../../../../lib/infrastructure/utils/csv/sessions-import'); +import { expect, sinon, catchErr } from '../../../../test-helper.js'; +import * as csvSerializer from '../../../../../lib/infrastructure/serializers/csv/csv-serializer.js'; +import { logger } from '../../../../../lib/infrastructure/logger.js'; +import _ from 'lodash'; +import { FileValidationError } from '../../../../../lib/domain/errors.js'; +import { emptySession } from '../../../../../lib/infrastructure/utils/csv/sessions-import.js'; describe('Unit | Serializer | CSV | csv-serializer', function () { describe('#serializeLine', function () { diff --git a/api/tests/unit/infrastructure/serializers/csv/higher-organization-learner-parser_test.js b/api/tests/unit/infrastructure/serializers/csv/higher-organization-learner-parser_test.js index 2c583efc095..9f87f86c445 100644 --- a/api/tests/unit/infrastructure/serializers/csv/higher-organization-learner-parser_test.js +++ b/api/tests/unit/infrastructure/serializers/csv/higher-organization-learner-parser_test.js @@ -1,9 +1,9 @@ -const iconv = require('iconv-lite'); -const { expect, catchErr } = require('../../../../test-helper'); -const SupOrganizationLearnerParser = require('../../../../../lib/infrastructure/serializers/csv/sup-organization-learner-parser'); -const SupOrganizationLearnerImportHeader = require('../../../../../lib/infrastructure/serializers/csv/sup-organization-learner-import-header'); -const _ = require('lodash'); -const { getI18n } = require('../../../../tooling/i18n/i18n'); +import iconv from 'iconv-lite'; +import { expect, catchErr } from '../../../../test-helper.js'; +import { SupOrganizationLearnerParser } from '../../../../../lib/infrastructure/serializers/csv/sup-organization-learner-parser.js'; +import { SupOrganizationLearnerImportHeader } from '../../../../../lib/infrastructure/serializers/csv/sup-organization-learner-import-header.js'; +import _ from 'lodash'; +import { getI18n } from '../../../../tooling/i18n/i18n.js'; const i18n = getI18n(); const supOrganizationLearnerImportHeader = new SupOrganizationLearnerImportHeader(i18n).columns diff --git a/api/tests/unit/infrastructure/serializers/csv/organization-learner-parser_test.js b/api/tests/unit/infrastructure/serializers/csv/organization-learner-parser_test.js index 0b1fe395488..29567c8e27c 100644 --- a/api/tests/unit/infrastructure/serializers/csv/organization-learner-parser_test.js +++ b/api/tests/unit/infrastructure/serializers/csv/organization-learner-parser_test.js @@ -1,9 +1,9 @@ -const iconv = require('iconv-lite'); -const { expect, catchErr } = require('../../../../test-helper'); -const OrganizationLearnerParser = require('../../../../../lib/infrastructure/serializers/csv/organization-learner-parser'); -const { CsvImportError } = require('../../../../../lib/domain/errors'); -const OrganizationLearnerImportHeader = require('../../../../../lib/infrastructure/serializers/csv/organization-learner-import-header'); -const { getI18n } = require('../../../../tooling/i18n/i18n'); +import iconv from 'iconv-lite'; +import { expect, catchErr } from '../../../../test-helper.js'; +import { OrganizationLearnerParser } from '../../../../../lib/infrastructure/serializers/csv/organization-learner-parser.js'; +import { CsvImportError } from '../../../../../lib/domain/errors.js'; +import { OrganizationLearnerImportHeader } from '../../../../../lib/infrastructure/serializers/csv/organization-learner-import-header.js'; +import { getI18n } from '../../../../tooling/i18n/i18n.js'; const i18n = getI18n(); const organizationLearnerCsvColumns = new OrganizationLearnerImportHeader(i18n).columns diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/admin-member-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/admin-member-serializer_test.js index bb37d6afe0c..6426e77348f 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/admin-member-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/admin-member-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/admin-member-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/admin-member-serializer.js'; describe('Unit | Serializer | JSONAPI | admin-member-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/answer-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/answer-serializer_test.js index d74f61f1f2b..58bc5f62def 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/answer-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/answer-serializer_test.js @@ -1,8 +1,8 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const Answer = require('../../../../../lib/domain/models/Answer'); -const AnswerStatus = require('../../../../../lib/domain/models/AnswerStatus'); -const answerStatusJSONAPIAdapter = require('../../../../../lib/infrastructure/adapters/answer-status-json-api-adapter'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/answer-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import { Answer } from '../../../../../lib/domain/models/Answer.js'; +import { AnswerStatus } from '../../../../../lib/domain/models/AnswerStatus.js'; +import { AnswerStatusJsonApiAdapter as answerStatusJSONAPIAdapter } from '../../../../../lib/infrastructure/adapters/answer-status-json-api-adapter.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/answer-serializer.js'; describe('Unit | Serializer | JSONAPI | answer-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/assessment-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/assessment-serializer_test.js index 32ab591a362..2c0149745bc 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/assessment-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/assessment-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/assessment-serializer'); -const Assessment = require('../../../../../lib/domain/models/Assessment'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/assessment-serializer.js'; +import { Assessment } from '../../../../../lib/domain/models/Assessment.js'; describe('Unit | Serializer | JSONAPI | assessment-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/authentication-methods-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/authentication-methods-serializer_test.js index 9273b412246..0778ff55c16 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/authentication-methods-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/authentication-methods-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const OidcIdentityProviders = require('../../../../../lib/domain/constants/oidc-identity-providers'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/authentication-methods-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as OidcIdentityProviders from '../../../../../lib/domain/constants/oidc-identity-providers.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/authentication-methods-serializer.js'; describe('Unit | Serializer | JSONAPI | authentication-methods-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/authentication-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/authentication-serializer_test.js index 85f791c09cc..0f475cc5f6c 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/authentication-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/authentication-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/authentication-serializer'); -const Authentication = require('../../../../../lib/domain/models/Authentication'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/authentication-serializer.js'; +import { Authentication } from '../../../../../lib/domain/models/Authentication.js'; describe('Unit | Serializer | JSONAPI | authentication-serializer', function () { const expectedJsonAnswer = { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/badge-creation-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/badge-creation-serializer_test.js index df35d759e8f..f06d284951c 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/badge-creation-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/badge-creation-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/badge-creation-serializer'); +import { expect } from '../../../../test-helper.js'; +import { deserializer } from '../../../../../lib/infrastructure/serializers/jsonapi/badge-creation-serializer.js'; describe('Unit | Serializer | JSONAPI | badge-creation-serializer', function () { describe('#deserialize', function () { @@ -25,7 +25,7 @@ describe('Unit | Serializer | JSONAPI | badge-creation-serializer', function () }; // when - const badgeCreation = await serializer.deserialize(jsonBadge); + const badgeCreation = await deserializer.deserialize(jsonBadge); // then const expectedBadgeCreation = { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/badge-criteria-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/badge-criteria-serializer_test.js index 7aa134f0646..13b7eb795cb 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/badge-criteria-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/badge-criteria-serializer_test.js @@ -1,6 +1,6 @@ -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/badge-criteria-serializer'); -const { expect } = require('../../../../test-helper'); -const BadgeCriterion = require('../../../../../lib/domain/models/BadgeCriterion'); +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/badge-criteria-serializer.js'; +import { expect } from '../../../../test-helper.js'; +import { BadgeCriterion } from '../../../../../lib/domain/models/BadgeCriterion.js'; describe('Unit | Serializer | JSONAPI | badge-criteria-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/badge-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/badge-serializer_test.js index b305a3dc62c..3ac6f783d56 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/badge-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/badge-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/badge-serializer'); -const BadgeCriterion = require('../../../../../lib/domain/models/BadgeCriterion'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/badge-serializer.js'; +import { BadgeCriterion } from '../../../../../lib/domain/models/BadgeCriterion.js'; describe('Unit | Serializer | JSONAPI | badge-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-analysis-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-analysis-serializer_test.js index 07ecebc14ad..da26b79cb86 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-analysis-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-analysis-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-analysis-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-analysis-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-analysis-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer_test.js index 9eca3f070db..28482b6e0c4 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const CampaignAssessmentParticipationResult = require('../../../../../lib/domain/read-models/CampaignAssessmentParticipationResult'); -const CampaignParticipationStatuses = require('../../../../../lib/domain/models/CampaignParticipationStatuses'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import { CampaignAssessmentParticipationResult } from '../../../../../lib/domain/read-models/CampaignAssessmentParticipationResult.js'; +import { CampaignParticipationStatuses } from '../../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-result-serializer.js'; const { SHARED } = CampaignParticipationStatuses; diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer_test.js index 2e33894e911..a3a0ee5f210 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer_test.js @@ -1,8 +1,8 @@ -const { expect } = require('../../../../test-helper'); -const Assessment = require('../../../../../lib/domain/models/Assessment'); -const CampaignParticipationStatuses = require('../../../../../lib/domain/models/CampaignParticipationStatuses'); -const CampaignAssessmentParticipation = require('../../../../../lib/domain/read-models/CampaignAssessmentParticipation'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer'); +import { expect } from '../../../../test-helper.js'; +import { Assessment } from '../../../../../lib/domain/models/Assessment.js'; +import { CampaignParticipationStatuses } from '../../../../../lib/domain/models/CampaignParticipationStatuses.js'; +import { CampaignAssessmentParticipation } from '../../../../../lib/domain/read-models/CampaignAssessmentParticipation.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-assessment-participation-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-assessment-participation-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer_test.js index 4e5610e498a..7a41b11b098 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-assessment-result-minimal-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-assessment-result-minimal-serializer', function () { describe('#serialize campaign-assessment-result-minimal list', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-collective-result-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-collective-result-serializer_test.js index 3d432469b90..4c96094bd6f 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-collective-result-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-collective-result-serializer_test.js @@ -1,6 +1,6 @@ -const _ = require('lodash'); -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-collective-result-serializer'); +import _ from 'lodash'; +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-collective-result-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-collective-results-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-details-management-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-details-management-serializer_test.js index 22c3265c94c..8e102c66153 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-details-management-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-details-management-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-details-management-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-details-management-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-details-management-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-management-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-management-serializer_test.js index 1080c3cbc0a..2fe9dad8047 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-management-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-management-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-management-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-management-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-management-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer_test.js index 0c7c276236b..34670fbd2cc 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer'); -const CampaignParticipantActivity = require('../../../../../lib/domain/read-models/CampaignParticipantActivity'); -const CampaignParticipationStatuses = require('../../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-participant-activity-serializer.js'; +import { CampaignParticipantActivity } from '../../../../../lib/domain/read-models/CampaignParticipantActivity.js'; +import { CampaignParticipationStatuses } from '../../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED, STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer_test.js index 6106796c8e6..0fe1dcfa9a6 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-participation-for-user-management-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-participation-for-user-management-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer_test.js index 3ecc7cfb98a..586edd69598 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer'); -const CampaignParticipationOverview = require('../../../../../lib/domain/read-models/CampaignParticipationOverview'); -const CampaignParticipationStatuses = require('../../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-participation-overview-serializer.js'; +import { CampaignParticipationOverview } from '../../../../../lib/domain/read-models/CampaignParticipationOverview.js'; +import { CampaignParticipationStatuses } from '../../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED, STARTED } = CampaignParticipationStatuses; diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-serializer_test.js index c914f9fb2a0..a47615519c1 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participation-serializer_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-participation-serializer'); -const CampaignParticipation = require('../../../../../lib/domain/models/CampaignParticipation'); -const CampaignParticipationStatuses = require('../../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-participation-serializer.js'; +import { CampaignParticipation } from '../../../../../lib/domain/models/CampaignParticipation.js'; +import { CampaignParticipationStatuses } from '../../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; describe('Unit | Serializer | JSONAPI | campaign-participation-serializer', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer_test.js index 567313ed752..9da1e6ab033 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-participations-count-by-stage-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-participations-count-by-stage-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer_test.js index 16382a50dae..e78ab93a232 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-day-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-participations-counts-by-day-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer_test.js index 4245a3248e9..e1ced546df2 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-participations-counts-by-status-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-participations-counts-by-status-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-profile-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-profile-serializer_test.js index 84ab3f7602a..4f39c84789c 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-profile-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-profile-serializer_test.js @@ -1,9 +1,9 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-profile-serializer'); -const CampaignProfile = require('../../../../../lib/domain/read-models/CampaignProfile'); -const PlacementProfile = require('../../../../../lib/domain/models/PlacementProfile'); -const UserCompetence = require('../../../../../lib/domain/models/UserCompetence'); -const CampaignParticipationStatuses = require('../../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-profile-serializer.js'; +import { CampaignProfile } from '../../../../../lib/domain/read-models/CampaignProfile.js'; +import { PlacementProfile } from '../../../../../lib/domain/models/PlacementProfile.js'; +import { UserCompetence } from '../../../../../lib/domain/models/UserCompetence.js'; +import { CampaignParticipationStatuses } from '../../../../../lib/domain/models/CampaignParticipationStatuses.js'; const { SHARED } = CampaignParticipationStatuses; diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer_test.js index 9cbaf9159d6..97e88505437 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer'); -const CampaignProfilesCollectionParticipationSummary = require('../../../../../lib/domain/read-models/CampaignProfilesCollectionParticipationSummary'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-profiles-collection-participation-summary-serializer.js'; +import { CampaignProfilesCollectionParticipationSummary } from '../../../../../lib/domain/read-models/CampaignProfilesCollectionParticipationSummary.js'; describe('Unit | Serializer | JSONAPI | campaign-profiles-collection-participation-summary-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-report-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-report-serializer_test.js index 557d372df41..4dde054e9e9 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-report-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-report-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-report-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-report-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-report-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-to-join-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-to-join-serializer_test.js index 86a118bf0af..0baff13debb 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign-to-join-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign-to-join-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const campaignToJoinSerializer = require('../../../../../lib/infrastructure/serializers/jsonapi/campaign-to-join-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as campaignToJoinSerializer from '../../../../../lib/infrastructure/serializers/jsonapi/campaign-to-join-serializer.js'; describe('Unit | Serializer | JSONAPI | campaign-to-join-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer_test.js index 290df5d47e9..2419b4c1235 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../../test-helper'); -const serializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer'); -const TargetProfileForSpecifier = require('../../../../../../lib/domain/read-models/campaign/TargetProfileForSpecifier'); +import { expect } from '../../../../../test-helper.js'; +import * as serializer from '../../../../../../lib/infrastructure/serializers/jsonapi/campaign/target-profile-for-specifier-serializer.js'; +import { TargetProfileForSpecifier } from '../../../../../../lib/domain/read-models/campaign/TargetProfileForSpecifier.js'; describe('Unit | Serializer | JSONAPI | target-profile-for-specifier-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-candidate-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-candidate-serializer_test.js index 344816bf0ca..9f19c3704d5 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-candidate-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-candidate-serializer_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const CertificationCandidate = require('../../../../../lib/domain/models/CertificationCandidate'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-candidate-serializer'); -const _ = require('lodash'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import { CertificationCandidate } from '../../../../../lib/domain/models/CertificationCandidate.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-candidate-serializer.js'; +import _ from 'lodash'; describe('Unit | Serializer | JSONAPI | certification-candidate-serializer', function () { let certificationCandidate; diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer_test.js index 9cfcd0d443d..e723409ffba 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-candidate-subscription-serializer.js'; describe('Unit | Serializer | JSONAPI | certification-candidate-subscription-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer_test.js index 9f424f616b3..91858c9f3aa 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-center-for-admin-serializer.js'; describe('Unit | Serializer | JSONAPI | certification-center-for-admin-serializer', function () { describe('#deserialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-invitation-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-invitation-serializer_test.js index 5febcfb8095..e36cfa36409 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-invitation-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-invitation-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-center-invitation-serializer'); -const CertificationCenterInvitation = require('../../../../../lib/domain/models/CertificationCenterInvitation'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-center-invitation-serializer.js'; +import { CertificationCenterInvitation } from '../../../../../lib/domain/models/CertificationCenterInvitation.js'; describe('Unit | Serializer | JSONAPI | certification-center-invitation-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-membership-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-membership-serializer_test.js index 5cd1a11d39c..6b73cf3ba69 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-membership-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-membership-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const certificationCenterMembershipSerializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-center-membership-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as certificationCenterMembershipSerializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-center-membership-serializer.js'; describe('Unit | Serializer | JSONAPI | certification-center-membership-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-serializer_test.js index cfb8322bed6..3e65b152e38 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-center-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-center-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-center-serializer.js'; describe('Unit | Serializer | JSONAPI | certification-center-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-course-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-course-serializer_test.js index 71b12567b6f..e4b9c46b485 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-course-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-course-serializer_test.js @@ -1,11 +1,9 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-course-serializer'); -const Assessment = require('../../../../../lib/domain/models/Assessment'); -const CertificationCourse = require('../../../../../lib/domain/models/CertificationCourse'); -const CertificationIssueReport = require('../../../../../lib/domain/models/CertificationIssueReport'); -const { - CertificationIssueReportCategories, -} = require('../../../../../lib/domain/models/CertificationIssueReportCategory'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-course-serializer.js'; +import { Assessment } from '../../../../../lib/domain/models/Assessment.js'; +import { CertificationCourse } from '../../../../../lib/domain/models/CertificationCourse.js'; +import { CertificationIssueReport } from '../../../../../lib/domain/models/CertificationIssueReport.js'; +import { CertificationIssueReportCategory } from '../../../../../lib/domain/models/CertificationIssueReportCategory.js'; describe('Unit | Serializer | JSONAPI | certification-course-serializer', function () { describe('#serialize', function () { @@ -25,7 +23,7 @@ describe('Unit | Serializer | JSONAPI | certification-course-serializer', functi const issueReport = new CertificationIssueReport({ id: 1234, description: "Signalement de l'examinateur", - category: CertificationIssueReportCategories.OTHER, + category: CertificationIssueReportCategory.OTHER, certificationCourseId: certificationCourse.getId(), }); diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-details-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-details-serializer_test.js index 60df9e19aba..a6957218fe6 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-details-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-details-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-details-serializer'); -const { states } = require('../../../../../lib/domain/models/CertificationAssessment'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-details-serializer.js'; +import { states } from '../../../../../lib/domain/models/CertificationAssessment.js'; describe('Unit | Serializer | JSONAPI | certification-details-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-eligibility-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-eligibility-serializer_test.js index ed7ddf20f04..1cb3b09e1fe 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-eligibility-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-eligibility-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-eligibility-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-eligibility-serializer.js'; describe('Unit | Serializer | JSONAPI | certification-eligibility-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-issue-report-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-issue-report-serializer_test.js index b6e345c0aa3..fb0ba2953eb 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-issue-report-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-issue-report-serializer_test.js @@ -1,10 +1,10 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-issue-report-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-issue-report-serializer.js'; -const { - CertificationIssueReportCategories, +import { + CertificationIssueReportCategory, CertificationIssueReportSubcategories, -} = require('../../../../../lib/domain/models/CertificationIssueReportCategory'); +} from '../../../../../lib/domain/models/CertificationIssueReportCategory.js'; describe('Unit | Serializer | JSONAPI | certification-issue-report-serializer', function () { describe('#serialize()', function () { @@ -68,7 +68,7 @@ describe('Unit | Serializer | JSONAPI | certification-issue-report-serializer', // then const expectedCertificationIssueReport = { certificationCourseId, - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, description, subcategory: CertificationIssueReportSubcategories.IMAGE_NOT_DISPLAYING, questionNumber, diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer_test.js index b452adeab7e..b258692d5c8 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, sinon } = require('../../../../test-helper'); -const settings = require('../../../../../lib/config'); -const certificationPointOfContactSerializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer'); +import { expect, domainBuilder, sinon } from '../../../../test-helper.js'; +import { config as settings } from '../../../../../lib/config.js'; +import * as certificationPointOfContactSerializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-point-of-contact-serializer.js'; describe('Unit | Serializer | JSONAPI | certification-point-of-contact-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-report-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-report-serializer_test.js index 8214812e002..3bcccf6c67a 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-report-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-report-serializer_test.js @@ -1,9 +1,9 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-report-serializer'); -const { - CertificationIssueReportCategories, +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-report-serializer.js'; +import { + CertificationIssueReportCategory, CertificationIssueReportSubcategories, -} = require('../../../../../lib/domain/models/CertificationIssueReportCategory'); +} from '../../../../../lib/domain/models/CertificationIssueReportCategory.js'; describe('Unit | Serializer | JSONAPI | certification-report-serializer', function () { describe('#serialize()', function () { @@ -53,7 +53,7 @@ describe('Unit | Serializer | JSONAPI | certification-report-serializer', functi id: 123, certificationIssueReports: [ domainBuilder.buildCertificationIssueReport({ - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, description: 'Pas content', subcategory: CertificationIssueReportSubcategories.EMBED_NOT_WORKING, questionNumber: '6', @@ -74,7 +74,7 @@ describe('Unit | Serializer | JSONAPI | certification-report-serializer', functi type: 'certificationIssueReports', id: '123', attributes: { - category: CertificationIssueReportCategories.IN_CHALLENGE, + category: CertificationIssueReportCategory.IN_CHALLENGE, description: 'Pas content', subcategory: CertificationIssueReportSubcategories.EMBED_NOT_WORKING, 'question-number': '6', diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certification-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certification-serializer_test.js index 9a94970cfa0..167b4170f3d 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certification-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certification-serializer_test.js @@ -1,8 +1,8 @@ -const { expect, EMPTY_BLANK_AND_NULL, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certification-serializer'); -const { WrongDateFormatError } = require('../../../../../lib/domain/errors'); -const { NO_EXAMINER_COMMENT } = require('../../../../../lib/domain/models/CertificationReport'); -const CertificationCourse = require('../../../../../lib/domain/models/CertificationCourse'); +import { expect, EMPTY_BLANK_AND_NULL, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certification-serializer.js'; +import { WrongDateFormatError } from '../../../../../lib/domain/errors.js'; +import { NO_EXAMINER_COMMENT } from '../../../../../lib/domain/models/CertificationReport.js'; +import { CertificationCourse } from '../../../../../lib/domain/models/CertificationCourse.js'; describe('Unit | Serializer | JSONAPI | certification-serializer', function () { describe('#deserialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certifications-ls/certification-ls-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certifications-ls/certification-ls-serializer_test.js index a44dbac6f58..74c6fc4b404 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certifications-ls/certification-ls-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certifications-ls/certification-ls-serializer_test.js @@ -1,10 +1,12 @@ -const { expect } = require('../../../../../test-helper'); -const serializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/certification-ls-serializer.js'); -const { +import { expect } from '../../../../../test-helper.js'; +import * as serializer from '../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/certification-ls-serializer.js'; + +import { buildCertificateForLS, buildReferentialOfCompetences, buildCertificationsResults, -} = require('../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-certification-result-for-ls'); +} from '../../../../../../lib/infrastructure/serializers/jsonapi/certifications-livret-scolaire/factory/build-certification-result-for-ls.js'; + const VALIDATED_CERTIFICATION = 'validated'; const REJECTED_CERTIFICATION = 'rejected'; diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/certified-profile-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/certified-profile-serializer_test.js index f76d302cf9e..cef3a969b29 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/certified-profile-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/certified-profile-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/certified-profile-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/certified-profile-serializer.js'; describe('Unit | Serializer | JSONAPI | certified-profile-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/challenge-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/challenge-serializer_test.js index 1dad5c72151..8b5e6f7291f 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/challenge-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/challenge-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/challenge-serializer'); -const Challenge = require('../../../../../lib/domain/models/Challenge'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/challenge-serializer.js'; +import { Challenge } from '../../../../../lib/domain/models/Challenge.js'; describe('Unit | Serializer | JSONAPI | challenge-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/competence-evaluation-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/competence-evaluation-serializer_test.js index e6e0e734b25..9b03a0a0033 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/competence-evaluation-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/competence-evaluation-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/competence-evaluation-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/competence-evaluation-serializer.js'; describe('Unit | Serializer | JSONAPI | competence-evaluation-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/complementary-certification-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/complementary-certification-serializer_test.js index 11e5a5707ab..7a1c219da4f 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/complementary-certification-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/complementary-certification-serializer_test.js @@ -1,5 +1,5 @@ -const { domainBuilder, expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/complementary-certification-serializer'); +import { domainBuilder, expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/complementary-certification-serializer.js'; describe('Unit | Serializer | JSONAPI | complementary-certification-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/correction-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/correction-serializer_test.js index 5e285e01867..319248855bf 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/correction-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/correction-serializer_test.js @@ -1,10 +1,10 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/correction-serializer'); -const Correction = require('../../../../../lib/domain/models/Correction'); -const Hint = require('../../../../../lib/domain/models/Hint'); -const TutorialForUser = require('../../../../../lib/domain/read-models/TutorialForUser'); -const UserSavedTutorial = require('../../../../../lib/domain/models/UserSavedTutorial'); -const TutorialEvaluation = require('../../../../../lib/domain/models/TutorialEvaluation'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/correction-serializer.js'; +import { Correction } from '../../../../../lib/domain/models/Correction.js'; +import { Hint } from '../../../../../lib/domain/models/Hint.js'; +import { TutorialForUser } from '../../../../../lib/domain/read-models/TutorialForUser.js'; +import { UserSavedTutorial } from '../../../../../lib/domain/models/UserSavedTutorial.js'; +import { TutorialEvaluation } from '../../../../../lib/domain/models/TutorialEvaluation.js'; describe('Unit | Serializer | JSONAPI | correction-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/country-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/country-serializer_test.js index 46ab68f8eb4..05690c0dfb0 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/country-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/country-serializer_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/country-serializer'); -const { domainBuilder } = require('../../../../test-helper'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/country-serializer.js'; describe('Unit | Serializer | JSONAPI | country-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/course-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/course-serializer_test.js index c78a206bda1..de8421ac904 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/course-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/course-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/course-serializer'); -const Course = require('../../../../../lib/domain/models/Course'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/course-serializer.js'; +import { Course } from '../../../../../lib/domain/models/Course.js'; describe('Unit | Serializer | JSONAPI | course-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/division-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/division-serializer_test.js index b15efeb180c..4a3ebbc1541 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/division-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/division-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/division-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/division-serializer.js'; describe('Unit | Serializer | JSONAPI | division-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/email-verification-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/email-verification-serializer_test.js index af87b32f275..f601a49aa8e 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/email-verification-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/email-verification-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/email-verification-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/email-verification-serializer.js'; describe('Unit | Serializer | JSONAPI | email-verification-serializer', function () { describe('#deserialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/error-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/error-serializer_test.js index 5519b09d11f..e75b96417e6 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/error-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/error-serializer_test.js @@ -1,7 +1,8 @@ -const { expect } = require('../../../../test-helper'); -const JSONAPIError = require('jsonapi-serializer').Error; -const { MissingQueryParamError, ConflictError } = require('../../../../../lib/application/http-errors'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/error-serializer'); +import { expect } from '../../../../test-helper.js'; +import jsonapiSerializer from 'jsonapi-serializer'; +const { Error: JSONAPIError } = jsonapiSerializer; +import { MissingQueryParamError, ConflictError } from '../../../../../lib/application/http-errors.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/error-serializer.js'; describe('Unit | Serializer | JSONAPI | error-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/feature-toggle-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/feature-toggle-serializer_test.js index 5a3e22cc9d7..f2b33d685e5 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/feature-toggle-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/feature-toggle-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/feature-toggle-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/feature-toggle-serializer.js'; describe('Unit | Serializer | JSONAPI | feature-toggle-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/feedback-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/feedback-serializer_test.js index ae2f6f932d6..1a5dadfd7cf 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/feedback-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/feedback-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/feedback-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/feedback-serializer.js'; describe('Unit | Serializer | JSONAPI | feedback-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/framework-areas-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/framework-areas-serializer_test.js index d03a4449fe8..825c2be6e44 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/framework-areas-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/framework-areas-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/framework-areas-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/framework-areas-serializer.js'; describe('Unit | Serializer | JSONAPI | pix-framework-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/framework-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/framework-serializer_test.js index 35c9474f3da..5f6daa62989 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/framework-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/framework-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/framework-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/framework-serializer.js'; describe('Unit | Serializer | JSONAPI | framework-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/group-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/group-serializer_test.js index 7bc67d9de2c..5b8cde6dff3 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/group-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/group-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/group-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/group-serializer.js'; describe('Unit | Serializer | JSONAPI | group-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/jury-certification-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/jury-certification-serializer_test.js index ee24bc60fac..5322554d5af 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/jury-certification-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/jury-certification-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/jury-certification-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/jury-certification-serializer.js'; describe('Unit | Serializer | JSONAPI | jury-certification-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/jury-certification-summary-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/jury-certification-summary-serializer_test.js index 8a852300e52..bcd81f558c1 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/jury-certification-summary-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/jury-certification-summary-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/jury-certification-summary-serializer'); -const JuryCertificationSummary = require('../../../../../lib/domain/read-models/JuryCertificationSummary'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/jury-certification-summary-serializer.js'; +import { JuryCertificationSummary } from '../../../../../lib/domain/read-models/JuryCertificationSummary.js'; describe('Unit | Serializer | JSONAPI | jury-certification-summary-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/jury-session-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/jury-session-serializer_test.js index b1d86bc033a..a497bdc9bd9 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/jury-session-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/jury-session-serializer_test.js @@ -1,22 +1,20 @@ -const { expect, sinon, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/jury-session-serializer'); +import { expect, sinon, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/jury-session-serializer.js'; describe('Unit | Serializer | JSONAPI | jury-session-serializer', function () { describe('#serializeForPaginatedList()', function () { it('should call serialize method by destructuring passed parameter', function () { // given - const restore = serializer.serialize; - serializer.serialize = sinon.stub(); + const serialize = sinon.stub().resolves(); const jurySessions = Symbol('someJurySessions'); const pagination = Symbol('somePagination'); const parameter = { jurySessions, pagination, someUnusedField: 'unused' }; // when - serializer.serializeForPaginatedList(parameter); + serializer.serializeForPaginatedList(parameter, serialize); // then - expect(serializer.serialize).to.have.been.calledWithExactly(jurySessions, undefined, pagination); - serializer.serialize = restore; + expect(serialize).to.have.been.calledWithExactly(jurySessions, undefined, pagination); }); }); diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/membership-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/membership-serializer_test.js index f018605b303..bbbe41ac489 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/membership-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/membership-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/membership-serializer'); -const Membership = require('../../../../../lib/domain/models/Membership'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/membership-serializer.js'; +import { Membership } from '../../../../../lib/domain/models/Membership.js'; describe('Unit | Serializer | JSONAPI | membership-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer_test.js index f9e5d598572..23be2247c90 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/oidc-identity-providers-serializer.js'; describe('Unit | Serializer | JSONAPI | oidc-identity-providers-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/oidc-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/oidc-serializer_test.js index 561bf6712c7..fe1e935ca71 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/oidc-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/oidc-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/oidc-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/oidc-serializer.js'; describe('Unit | Serializer | JSONAPI | oidc-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization-for-admin-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization-for-admin-serializer_test.js index f53861079bf..d83088f46f1 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization-for-admin-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization-for-admin-serializer_test.js @@ -1,9 +1,9 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/organization-for-admin-serializer'); -const Organization = require('../../../../../lib/domain/models/Organization'); -const OrganizationForAdmin = require('../../../../../lib/domain/models/organizations-administration/Organization'); -const Tag = require('../../../../../lib/domain/models/Tag'); -const { SamlIdentityProviders } = require('../../../../../lib/domain/constants/saml-identity-providers'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/organization-for-admin-serializer.js'; +import { Organization } from '../../../../../lib/domain/models/Organization.js'; +import { OrganizationForAdmin } from '../../../../../lib/domain/models/organizations-administration/Organization.js'; +import { Tag } from '../../../../../lib/domain/models/Tag.js'; +import { SamlIdentityProviders } from '../../../../../lib/domain/constants/saml-identity-providers.js'; describe('Unit | Serializer | organization-for-admin-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization-invitation-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization-invitation-serializer_test.js index a6760437ef9..7b94b595c99 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization-invitation-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization-invitation-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/organization-invitation-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/organization-invitation-serializer.js'; describe('Unit | Serializer | JSONAPI | organization-invitation-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-activity-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-activity-serializer_test.js index a225be3fc7f..699a1ec5cc0 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-activity-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-activity-serializer_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/organization-learner-activity-serializer'); -const OrganizationLearnerParticipation = require('../../../../../lib/domain/read-models/OrganizationLearnerParticipation'); -const OrganizationLearnerActivity = require('../../../../../lib/domain/read-models/OrganizationLearnerActivity'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/organization-learner-activity-serializer.js'; +import { OrganizationLearnerParticipation } from '../../../../../lib/domain/read-models/OrganizationLearnerParticipation.js'; +import { OrganizationLearnerActivity } from '../../../../../lib/domain/read-models/OrganizationLearnerActivity.js'; describe('Unit | Serializer | JSONAPI | organization-learner-participation-serialize', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer_test.js index d9905c49928..f15819466ab 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../../test-helper'); -const serializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer'); -const OrganizationLearner = require('../../../../../../lib/domain/read-models/organization-learner-follow-up/OrganizationLearner'); +import { expect } from '../../../../../test-helper.js'; +import * as serializer from '../../../../../../lib/infrastructure/serializers/jsonapi/organization-learner-follow-up/organization-learner-serializer.js'; +import { OrganizationLearner } from '../../../../../../lib/domain/read-models/organization-learner-follow-up/OrganizationLearner.js'; describe('Unit | Serializer | JSONAPI | organization-learner-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-identity-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-identity-serializer_test.js index 25733e8edda..78ed0716db9 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-identity-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization-learner-identity-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/organization-learner-identity-serializer'); -const OrganizationLearner = require('../../../../../lib/domain/models/OrganizationLearner'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/organization-learner-identity-serializer.js'; +import { OrganizationLearner } from '../../../../../lib/domain/models/OrganizationLearner.js'; describe('Unit | Serializer | JSONAPI | organization-learner-identity-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization-member-identity-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization-member-identity-serializer_test.js index 41e8b4f390c..ca530977938 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization-member-identity-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization-member-identity-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/organization-member-identity-serializer'); -const OrganizationMemberIdentity = require('../../../../../lib/domain/models/OrganizationMemberIdentity'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/organization-member-identity-serializer.js'; +import { OrganizationMemberIdentity } from '../../../../../lib/domain/models/OrganizationMemberIdentity.js'; describe('Unit | Serializer | organization-members-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization-serializer_test.js index e87361b9a59..dc636b7b9ab 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization-serializer_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/organization-serializer'); -const Organization = require('../../../../../lib/domain/models/Organization'); -const Tag = require('../../../../../lib/domain/models/Tag'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/organization-serializer.js'; +import { Organization } from '../../../../../lib/domain/models/Organization.js'; +import { Tag } from '../../../../../lib/domain/models/Tag.js'; describe('Unit | Serializer | organization-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-participants-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-participants-serializer_test.js index cc51b22d7c7..a408cabcb08 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-participants-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-participants-serializer_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../../test-helper'); -const OrganizationParticipant = require('../../../../../../lib/domain/read-models/OrganizationParticipant'); -const serializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/organization/organization-participants-serializer'); -const campaignParticipationsStatuses = require('../../../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect } from '../../../../../test-helper.js'; +import { OrganizationParticipant } from '../../../../../../lib/domain/read-models/OrganizationParticipant.js'; +import * as serializer from '../../../../../../lib/infrastructure/serializers/jsonapi/organization/organization-participants-serializer.js'; +import { CampaignParticipationStatuses as campaignParticipationsStatuses } from '../../../../../../lib/domain/models/CampaignParticipationStatuses.js'; describe('Unit | Serializer | JSONAPI | organization-participants-serializer', function () { describe('#serialize', function () { it('should convert an organization participant model object into JSON API data', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-capacity-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-capacity-serializer_test.js index 44591385c94..08e51cf9f7f 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-capacity-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-capacity-serializer_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../../test-helper'); -const categories = require('../../../../../../lib/domain/constants/organization-places-categories'); -const serializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/organization-places-capacity-serializer'); -const OrganizationPlacesCapacity = require('../../../../../../lib/domain/read-models/OrganizationPlacesCapacity'); +import { expect } from '../../../../../test-helper.js'; +import * as categories from '../../../../../../lib/domain/constants/organization-places-categories.js'; +import * as serializer from '../../../../../../lib/infrastructure/serializers/jsonapi/organization-places-capacity-serializer.js'; +import { OrganizationPlacesCapacity } from '../../../../../../lib/domain/read-models/OrganizationPlacesCapacity.js'; describe('Unit | Serializer | JSONAPI | organization-places-capacity-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-lot-managment-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-lot-managment-serializer_test.js index d8d6b9aadc6..e838fefae92 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-lot-managment-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-lot-managment-serializer_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../../test-helper'); -const organizationPlaceLotManagementSerializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-management-serializer'); -const OrganizationPlacesLotManagement = require('../../../../../../lib/domain/read-models/OrganizationPlacesLotManagement'); -const organizationPlacesLotCategories = require('../../../../../../lib/domain/constants/organization-places-categories'); +import { expect, domainBuilder } from '../../../../../test-helper.js'; +import * as organizationPlaceLotManagementSerializer from '../../../../../../lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-management-serializer.js'; +import { OrganizationPlacesLotManagement } from '../../../../../../lib/domain/read-models/OrganizationPlacesLotManagement.js'; +import * as organizationPlacesLotCategories from '../../../../../../lib/domain/constants/organization-places-categories.js'; describe('Unit | Serializer | JSONAPI | organization-places-lot-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer_test.js index 731b76bdcd9..59b0bd60d1e 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../../test-helper'); -const organizationPlacesLotSerializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer'); -const { FREE_RATE } = require('../../../../../../lib/domain/constants/organization-places-categories'); +import { expect } from '../../../../../test-helper.js'; +import * as organizationPlacesLotSerializer from '../../../../../../lib/infrastructure/serializers/jsonapi/organization/organization-places-lot-serializer.js'; +import { FREE_RATE } from '../../../../../../lib/domain/constants/organization-places-categories.js'; describe('Unit | Serializer | JSONAPI | organization-places-lot-serializer', function () { describe('#deserialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer_test.js index acfee13a8c8..3efd5b8da39 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../../test-helper'); -const ScoOrganizationParticipant = require('../../../../../../lib/domain/read-models/ScoOrganizationParticipant'); -const serializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer'); -const campaignParticipationsStatuses = require('../../../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect } from '../../../../../test-helper.js'; +import { ScoOrganizationParticipant } from '../../../../../../lib/domain/read-models/ScoOrganizationParticipant.js'; +import * as serializer from '../../../../../../lib/infrastructure/serializers/jsonapi/organization/sco-organization-participants-serializer.js'; +import { CampaignParticipationStatuses as campaignParticipationsStatuses } from '../../../../../../lib/domain/models/CampaignParticipationStatuses.js'; describe('Unit | Serializer | JSONAPI | sco-organization-participants-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer_test.js index d3909db30a4..ac8f0e1162f 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../../test-helper'); -const SupOrganizationParticipant = require('../../../../../../lib/domain/read-models/SupOrganizationParticipant'); -const serializer = require('../../../../../../lib/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer'); -const campaignParticipationsStatuses = require('../../../../../../lib/domain/models/CampaignParticipationStatuses'); +import { expect } from '../../../../../test-helper.js'; +import { SupOrganizationParticipant } from '../../../../../../lib/domain/read-models/SupOrganizationParticipant.js'; +import * as serializer from '../../../../../../lib/infrastructure/serializers/jsonapi/organization/sup-organization-participants-serializer.js'; +import { CampaignParticipationStatuses as campaignParticipationsStatuses } from '../../../../../../lib/domain/models/CampaignParticipationStatuses.js'; describe('Unit | Serializer | JSONAPI | sup-organization-participants-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/participant-result-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/participant-result-serializer_test.js index 14573b76418..59e2712f386 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/participant-result-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/participant-result-serializer_test.js @@ -1,8 +1,8 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/participant-result-serializer'); -const AssessmentResult = require('../../../../../lib/domain/read-models/participant-results/AssessmentResult'); -const KnowledgeElement = require('../../../../../lib/domain/models/KnowledgeElement'); -const StageCollection = require('../../../../../lib/domain/models/user-campaign-results/StageCollection'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/participant-result-serializer.js'; +import { AssessmentResult } from '../../../../../lib/domain/read-models/participant-results/AssessmentResult.js'; +import { KnowledgeElement } from '../../../../../lib/domain/models/KnowledgeElement.js'; +import { StageCollection } from '../../../../../lib/domain/models/user-campaign-results/StageCollection.js'; describe('Unit | Serializer | JSON API | participant-result-serializer', function () { context('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer_test.js index d931f1d1e85..a1cbabff523 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/participation-for-campaign-management-serializer.js'; describe('Unit | Serializer | JSONAPI | participation-for-campaign-management-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate_test.js index 5f1b968050f..e6f8e6cb9dd 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/participations-count-by-mastery-rate.js'; describe('Unit | Serializer | JSONAPI | participations-count-by-mastery-rate', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/password-reset-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/password-reset-serializer_test.js index a72e58492fa..d624bc2a37e 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/password-reset-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/password-reset-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/password-reset-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/password-reset-serializer.js'; describe('Unit | Serializer | JSONAPI | password-reset-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/prescriber-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/prescriber-serializer_test.js index c31dfb49ec7..f00dd9d2376 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/prescriber-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/prescriber-serializer_test.js @@ -1,8 +1,8 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); +import { expect, domainBuilder } from '../../../../test-helper.js'; -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/prescriber-serializer'); -const Membership = require('../../../../../lib/domain/models/Membership'); -const { SamlIdentityProviders } = require('../../../../../lib/domain/constants/saml-identity-providers'); +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/prescriber-serializer.js'; +import { Membership } from '../../../../../lib/domain/models/Membership.js'; +import { SamlIdentityProviders } from '../../../../../lib/domain/constants/saml-identity-providers.js'; describe('Unit | Serializer | JSONAPI | prescriber-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/private-certificate-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/private-certificate-serializer_test.js index c6ac244810f..01cafcdabce 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/private-certificate-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/private-certificate-serializer_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/private-certificate-serializer'); -const ResultCompetenceTree = require('../../../../../lib/domain/models/ResultCompetenceTree'); -const ResultCompetence = require('../../../../../lib/domain/models/ResultCompetence'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/private-certificate-serializer.js'; +import { ResultCompetenceTree } from '../../../../../lib/domain/models/ResultCompetenceTree.js'; +import { ResultCompetence } from '../../../../../lib/domain/models/ResultCompetence.js'; describe('Unit | Serializer | JSONAPI | private-certificate-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/profile-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/profile-serializer_test.js index d45b953605e..d89c547281e 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/profile-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/profile-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/profile-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/profile-serializer.js'; describe('Unit | Serializer | JSONAPI | profile', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/progression-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/progression-serializer_test.js index 9c86c143265..d467122f423 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/progression-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/progression-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/progression-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/progression-serializer.js'; describe('Unit | Serializer | JSONAPI | progression-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer_test.js index b9685be4bb2..d5f241ce40c 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/sco-organization-invitation-serializer.js'; describe('Unit | Serializer | JSONAPI | sco-organization-invitation-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/sco-organization-learner-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/sco-organization-learner-serializer_test.js index 663b06b3e79..764cbd202af 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/sco-organization-learner-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/sco-organization-learner-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/sco-organization-learner-serializer'); -const OrganizationLearner = require('../../../../../lib/domain/models/OrganizationLearner'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/sco-organization-learner-serializer.js'; +import { OrganizationLearner } from '../../../../../lib/domain/models/OrganizationLearner.js'; describe('Unit | Serializer | JSONAPI | sco-organization-learner-serializer', function () { describe('#serializeIdentity', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/scorecard-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/scorecard-serializer_test.js index 6dfd0851802..a2ca2a8e00b 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/scorecard-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/scorecard-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/scorecard-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/scorecard-serializer.js'; describe('Unit | Serializer | JSONAPI | scorecard-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/session-for-supervising-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/session-for-supervising-serializer_test.js index 10d3a4c46a6..f464a149725 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/session-for-supervising-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/session-for-supervising-serializer_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/session-for-supervising-serializer'); -const Assessment = require('../../../../../lib/domain/models/Assessment'); -const { CertificationCandidateForSupervising } = require('../../../../../lib/domain/models'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/session-for-supervising-serializer.js'; +import { Assessment } from '../../../../../lib/domain/models/Assessment.js'; +import { CertificationCandidateForSupervising } from '../../../../../lib/domain/models/index.js'; describe('Unit | Serializer | JSONAPI | session-for-supervising-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/session-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/session-serializer_test.js index 53796ec9693..14c380165b3 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/session-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/session-serializer_test.js @@ -1,8 +1,7 @@ -const { expect, EMPTY_BLANK_AND_NULL } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/session-serializer'); +import { expect, EMPTY_BLANK_AND_NULL } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/session-serializer.js'; -const Session = require('../../../../../lib/domain/models/Session'); -const { statuses } = require('../../../../../lib/domain/models/Session'); +import { Session, statuses } from '../../../../../lib/domain/models/Session.js'; describe('Unit | Serializer | JSONAPI | session-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/session-summary-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/session-summary-serializer_test.js index e1680a9e9f9..30c37bf67b2 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/session-summary-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/session-summary-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/session-summary-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/session-summary-serializer.js'; describe('Unit | Serializer | JSONAPI | session-summary-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/shareable-certificate-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/shareable-certificate-serializer_test.js index b8bfc854109..b9961f1f0bf 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/shareable-certificate-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/shareable-certificate-serializer_test.js @@ -1,7 +1,7 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/shareable-certificate-serializer'); -const ResultCompetenceTree = require('../../../../../lib/domain/models/ResultCompetenceTree'); -const ResultCompetence = require('../../../../../lib/domain/models/ResultCompetence'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/shareable-certificate-serializer.js'; +import { ResultCompetenceTree } from '../../../../../lib/domain/models/ResultCompetenceTree.js'; +import { ResultCompetence } from '../../../../../lib/domain/models/ResultCompetence.js'; describe('Unit | Serializer | JSONAPI | shareable-certificate-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer_test.js index 481a9f6ffa7..3e115fba00c 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder, sinon } = require('../../../../test-helper'); -const SharedProfileForCampaign = require('../../../../../lib/domain/read-models/SharedProfileForCampaign'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer'); +import { expect, domainBuilder, sinon } from '../../../../test-helper.js'; +import { SharedProfileForCampaign } from '../../../../../lib/domain/read-models/SharedProfileForCampaign.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/shared-profile-for-campaign-serializer.js'; describe('Unit | Serializer | JSONAPI | shared-profile-for-campaign-serializer', function () { let clock; diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/skill-set-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/skill-set-serializer_test.js index 1c22155165e..653de38a884 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/skill-set-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/skill-set-serializer_test.js @@ -1,6 +1,6 @@ -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/skill-set-serializer'); -const { expect } = require('../../../../test-helper'); -const SkillSet = require('../../../../../lib/domain/models/SkillSet'); +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/skill-set-serializer.js'; +import { expect } from '../../../../test-helper.js'; +import { SkillSet } from '../../../../../lib/domain/models/SkillSet.js'; describe('Unit | Serializer | JSONAPI | skill-set-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/student-certification-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/student-certification-serializer_test.js index 6c1320250aa..8865aac18b9 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/student-certification-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/student-certification-serializer_test.js @@ -1,6 +1,6 @@ -const { domainBuilder, expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/student-certification-serializer'); -const StudentForEnrolment = require('../../../../../lib/domain/read-models/StudentForEnrolment'); +import { domainBuilder, expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/student-certification-serializer.js'; +import { StudentForEnrolment } from '../../../../../lib/domain/read-models/StudentForEnrolment.js'; describe('Unit | Serializer | JSONAPI | student-certification-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer_test.js index 0e8ecd1157f..858625b447c 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js'); -const StudentInformationForAccountRecovery = require('../../../../../lib/domain/read-models/StudentInformationForAccountRecovery'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/student-information-for-account-recovery-serializer.js'; +import { StudentInformationForAccountRecovery } from '../../../../../lib/domain/read-models/StudentInformationForAccountRecovery.js'; describe('Unit | Serializer | JSONAPI | student-information-for-account-recovery-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer_test.js index 6aa3c7ee347..050180d5ac7 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/sup-organization-learner-warnings-serializer.js'; describe('Unit | Serializer | sup-organization-learner-warnings-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/tag-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/tag-serializer_test.js index 65d081acb8d..a8f1707f4f3 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/tag-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/tag-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/tag-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/tag-serializer.js'; describe('Unit | Serializer | JSONAPI | tag-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer_test.js index c12e7568c1f..d60ce50d1f9 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/target-profile-attach-organization-serializer.js'; describe('Unit | Serializer | JSONAPI | target-profile-attach-organization-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer_test.js index bce7f36eae2..c10e9e4fad8 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer'); -const TargetProfileForAdmin = require('../../../../../lib/domain/models/TargetProfileForAdmin'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/target-profile-for-admin-serializer.js'; +import { TargetProfileForAdmin } from '../../../../../lib/domain/models/TargetProfileForAdmin.js'; describe('Unit | Serializer | JSONAPI | target-profile-for-admin-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-serializer_test.js index 34ea8347b8a..0801bbd42b9 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/target-profile-serializer'); -const TargetProfile = require('../../../../../lib/domain/models/TargetProfile'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/target-profile-serializer.js'; +import { TargetProfile } from '../../../../../lib/domain/models/TargetProfile.js'; describe('Unit | Serializer | JSONAPI | target-profile-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer_test.js index 8cb9f1bd533..d2fc335e1ac 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/target-profile-summary-for-admin-serializer.js'; describe('Unit | Serializer | JSONAPI | target-profile-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/to-be-published-session-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/to-be-published-session-serializer_test.js index d3716f05224..18ceef43a5b 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/to-be-published-session-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/to-be-published-session-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/to-be-published-session-serializer'); -const FinalizedSession = require('../../../../../lib/domain/models/FinalizedSession'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/to-be-published-session-serializer.js'; +import { FinalizedSession } from '../../../../../lib/domain/models/FinalizedSession.js'; describe('Unit | Serializer | JSONAPI | to-be-published-session-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/training-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/training-serializer_test.js index a365fd5ed81..7bd99c96269 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/training-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/training-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/training-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/training-serializer.js'; describe('Unit | Serializer | JSONAPI | training-serializer', function () { describe('#serializeForAdmin', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/training-summary-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/training-summary-serializer_test.js index 58be2ee7c15..099f1243ee5 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/training-summary-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/training-summary-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/training-summary-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/training-summary-serializer.js'; describe('Unit | Serializer | JSONAPI | training-summary-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/training-trigger-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/training-trigger-serializer_test.js index a2816b758ef..bb24e30fb65 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/training-trigger-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/training-trigger-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/training-trigger-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/training-trigger-serializer.js'; describe('Unit | Serializer | JSONAPI | training-trigger-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer_test.js index d74604b881d..211e57bd1d7 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer'); -const TutorialEvaluation = require('../../../../../lib/domain/models/TutorialEvaluation'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/tutorial-evaluation-serializer.js'; +import { TutorialEvaluation } from '../../../../../lib/domain/models/TutorialEvaluation.js'; describe('Unit | Serializer | JSONAPI | tutorial-evaluation-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/tutorial-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/tutorial-serializer_test.js index 42d94397a50..93c8847001f 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/tutorial-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/tutorial-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/tutorial-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/tutorial-serializer.js'; describe('Unit | Serializer | JSONAPI | tutorial-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/update-email-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/update-email-serializer_test.js index 3a5c1528df7..9d8ed1b688d 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/update-email-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/update-email-serializer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/update-email-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/update-email-serializer.js'; describe('Unit | Serializer | JSONAPI | update-email-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer_test.js index 770afbd33df..504c0c217f4 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-anonymized-details-for-admin-serializer.js'; describe('Unit | Serializer | JSONAPI | user-anonymized-details-for-admin-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-details-for-admin-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-details-for-admin-serializer_test.js index 617f4282a22..c580294b52b 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-details-for-admin-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-details-for-admin-serializer_test.js @@ -1,5 +1,5 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-details-for-admin-serializer'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-details-for-admin-serializer.js'; describe('Unit | Serializer | JSONAPI | user-details-for-admin-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-for-admin-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-for-admin-serializer_test.js index 09b1ff63c47..462da84fc2d 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-for-admin-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-for-admin-serializer_test.js @@ -1,7 +1,6 @@ -const { expect } = require('../../../../test-helper'); - -const User = require('../../../../../lib/domain/models/User'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-for-admin-serializer'); +import { expect } from '../../../../test-helper.js'; +import { User } from '../../../../../lib/domain/models/User.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-for-admin-serializer.js'; describe('Unit | Serializer | JSONAPI | user-for-adminserializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-login-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-login-serializer_test.js index 2622f65cb1f..e2f0b864855 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-login-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-login-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-login-serializer'); -const UserLogin = require('../../../../../lib/domain/models/UserLogin'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-login-serializer.js'; +import { UserLogin } from '../../../../../lib/domain/models/UserLogin.js'; describe('Unit | Serializer | JSONAPI | user-login-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-orga-settings-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-orga-settings-serializer_test.js index 48875a070b6..fea05aad50d 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-orga-settings-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-orga-settings-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-orga-settings-serializer'); -const UserOrgaSettings = require('../../../../../lib/domain/models/UserOrgaSettings'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-orga-settings-serializer.js'; +import { UserOrgaSettings } from '../../../../../lib/domain/models/UserOrgaSettings.js'; describe('Unit | Serializer | JSONAPI | user-orga-settings-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer_test.js index 2f556320170..b1953ef12d7 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../../test-helper'); -const UserOrganizationForAdmin = require('../../../../../lib/domain/read-models/UserOrganizationForAdmin'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer'); +import { expect } from '../../../../test-helper.js'; +import { UserOrganizationForAdmin } from '../../../../../lib/domain/read-models/UserOrganizationForAdmin.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-organization-for-admin-serializer.js'; describe('Unit | Serializer | JSONAPI | user-organization-for-admin-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer_test.js index ab1b7782097..2371fcd9b35 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer_test.js @@ -1,6 +1,6 @@ -const { expect, domainBuilder } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer'); -const UserSavedTutorial = require('../../../../../lib/domain/models/UserSavedTutorial'); +import { expect, domainBuilder } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-saved-tutorial-serializer.js'; +import { UserSavedTutorial } from '../../../../../lib/domain/models/UserSavedTutorial.js'; describe('Unit | Serializer | JSONAPI | user-saved-tutorial-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-serializer_test.js index a9283109080..e43098bacc9 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-serializer_test.js @@ -1,8 +1,7 @@ -const { expect, catchErrSync } = require('../../../../test-helper'); - -const User = require('../../../../../lib/domain/models/User'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-serializer'); -const { LocaleFormatError, LocaleNotSupportedError } = require('../../../../../lib/domain/errors'); +import { expect, catchErrSync } from '../../../../test-helper.js'; +import { User } from '../../../../../lib/domain/models/User.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-serializer.js'; +import { LocaleFormatError, LocaleNotSupportedError } from '../../../../../lib/domain/errors.js'; describe('Unit | Serializer | JSONAPI | user-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/user-with-activity-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/user-with-activity-serializer_test.js index 7096b274de1..ffd393d21db 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/user-with-activity-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/user-with-activity-serializer_test.js @@ -1,8 +1,7 @@ -const { expect } = require('../../../../test-helper'); - -const UserWithActivity = require('../../../../../lib/domain/read-models/UserWithActivity'); -const User = require('../../../../../lib/domain/models/User'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/user-with-activity-serializer'); +import { expect } from '../../../../test-helper.js'; +import { UserWithActivity } from '../../../../../lib/domain/read-models/UserWithActivity.js'; +import { User } from '../../../../../lib/domain/models/User.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/user-with-activity-serializer.js'; describe('Unit | Serializer | JSONAPI | user-with-activity-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/validation-error-serializer_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/validation-error-serializer_test.js index dc67a9c9013..68bcb7e6bc1 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/validation-error-serializer_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/validation-error-serializer_test.js @@ -1,7 +1,7 @@ -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/validation-error-serializer'); +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/validation-error-serializer.js'; -const Bookshelf = require('../../../../../lib/infrastructure/bookshelf'); +import { Bookshelf } from '../../../../../lib/infrastructure/bookshelf.js'; describe('Unit | Serializer | JSONAPI | validation-error-serializer', function () { describe('#serialize', function () { diff --git a/api/tests/unit/infrastructure/serializers/jsonapi/with-required-action-session_test.js b/api/tests/unit/infrastructure/serializers/jsonapi/with-required-action-session_test.js index ffd3361dc55..5e8594e4ed6 100644 --- a/api/tests/unit/infrastructure/serializers/jsonapi/with-required-action-session_test.js +++ b/api/tests/unit/infrastructure/serializers/jsonapi/with-required-action-session_test.js @@ -1,6 +1,6 @@ -const FinalizedSession = require('../../../../../lib/domain/models/FinalizedSession'); -const { expect } = require('../../../../test-helper'); -const serializer = require('../../../../../lib/infrastructure/serializers/jsonapi/with-required-action-session-serializer'); +import { FinalizedSession } from '../../../../../lib/domain/models/FinalizedSession.js'; +import { expect } from '../../../../test-helper.js'; +import * as serializer from '../../../../../lib/infrastructure/serializers/jsonapi/with-required-action-session-serializer.js'; describe('Unit | Serializer | JSONAPI | with-required-action-session-serializer', function () { describe('#serialize()', function () { diff --git a/api/tests/unit/infrastructure/temporary-storage/InMemoryTemporaryStorage_test.js b/api/tests/unit/infrastructure/temporary-storage/InMemoryTemporaryStorage_test.js index 50a41a8a38f..390e6f91a1a 100644 --- a/api/tests/unit/infrastructure/temporary-storage/InMemoryTemporaryStorage_test.js +++ b/api/tests/unit/infrastructure/temporary-storage/InMemoryTemporaryStorage_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const InMemoryTemporaryStorage = require('../../../../lib/infrastructure/temporary-storage/InMemoryTemporaryStorage'); +import { expect, sinon } from '../../../test-helper.js'; +import { InMemoryTemporaryStorage } from '../../../../lib/infrastructure/temporary-storage/InMemoryTemporaryStorage.js'; describe('Unit | Infrastructure | temporary-storage | InMemoryTemporaryStorage', function () { let inMemoryTemporaryStorage; diff --git a/api/tests/unit/infrastructure/temporary-storage/RedisTemporaryStorage_test.js b/api/tests/unit/infrastructure/temporary-storage/RedisTemporaryStorage_test.js index 8d40b1beddc..ef7bcfb6925 100644 --- a/api/tests/unit/infrastructure/temporary-storage/RedisTemporaryStorage_test.js +++ b/api/tests/unit/infrastructure/temporary-storage/RedisTemporaryStorage_test.js @@ -1,5 +1,5 @@ -const { expect, sinon } = require('../../../test-helper'); -const RedisTemporaryStorage = require('../../../../lib/infrastructure/temporary-storage/RedisTemporaryStorage'); +import { expect, sinon } from '../../../test-helper.js'; +import { RedisTemporaryStorage } from '../../../../lib/infrastructure/temporary-storage/RedisTemporaryStorage.js'; describe('Unit | Infrastructure | temporary-storage | RedisTemporaryStorage', function () { const REDIS_URL = 'redis_url'; diff --git a/api/tests/unit/infrastructure/temporary-storage/TemporaryStorage_test.js b/api/tests/unit/infrastructure/temporary-storage/TemporaryStorage_test.js index c2d5c53aeee..859bde26d85 100644 --- a/api/tests/unit/infrastructure/temporary-storage/TemporaryStorage_test.js +++ b/api/tests/unit/infrastructure/temporary-storage/TemporaryStorage_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const TemporaryStorage = require('../../../../lib/infrastructure/temporary-storage/TemporaryStorage'); +import { expect } from '../../../test-helper.js'; +import { TemporaryStorage } from '../../../../lib/infrastructure/temporary-storage/TemporaryStorage.js'; describe('Unit | Infrastructure | temporary-storage | TemporaryStorage', function () { describe('#save', function () { diff --git a/api/tests/unit/infrastructure/utils/CampaignAssessmentCsvLine_test.js b/api/tests/unit/infrastructure/utils/CampaignAssessmentCsvLine_test.js index da01d63d10e..37ec94f9528 100644 --- a/api/tests/unit/infrastructure/utils/CampaignAssessmentCsvLine_test.js +++ b/api/tests/unit/infrastructure/utils/CampaignAssessmentCsvLine_test.js @@ -1,8 +1,8 @@ -const { expect, domainBuilder } = require('../../../test-helper'); -const CampaignAssessmentCsvLine = require('../../../../lib/infrastructure/utils/CampaignAssessmentCsvLine'); -const campaignParticipationService = require('../../../../lib/domain/services/campaign-participation-service'); -const KnowledgeElement = require('../../../../lib/domain/models/KnowledgeElement'); -const { getI18n } = require('../../../tooling/i18n/i18n'); +import { expect, domainBuilder } from '../../../test-helper.js'; +import { CampaignAssessmentCsvLine } from '../../../../lib/infrastructure/utils/CampaignAssessmentCsvLine.js'; +import * as campaignParticipationService from '../../../../lib/domain/services/campaign-participation-service.js'; +import { KnowledgeElement } from '../../../../lib/domain/models/KnowledgeElement.js'; +import { getI18n } from '../../../tooling/i18n/i18n.js'; function _computeExpectedColumnsIndex(campaign, organization, badges, stages) { const studentNumberPresenceModifier = organization.type === 'SUP' && organization.isManagingStudents ? 1 : 0; diff --git a/api/tests/unit/infrastructure/utils/code-utils_test.js b/api/tests/unit/infrastructure/utils/code-utils_test.js index 89cd6861460..bfd9da427ef 100644 --- a/api/tests/unit/infrastructure/utils/code-utils_test.js +++ b/api/tests/unit/infrastructure/utils/code-utils_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const { generateNumericalString } = require('../../../../lib/infrastructure/utils/code-utils'); +import { expect } from '../../../test-helper.js'; +import { generateNumericalString } from '../../../../lib/infrastructure/utils/code-utils.js'; describe('Unit | Utils | code-utils', function () { describe('#generateNumericalString', function () { diff --git a/api/tests/unit/infrastructure/utils/date-utils_test.js b/api/tests/unit/infrastructure/utils/date-utils_test.js index a982807698f..81985a4d057 100644 --- a/api/tests/unit/infrastructure/utils/date-utils_test.js +++ b/api/tests/unit/infrastructure/utils/date-utils_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const { isValidDate, convertDateValue } = require('../../../../lib/infrastructure/utils/date-utils'); +import { expect } from '../../../test-helper.js'; +import { isValidDate, convertDateValue } from '../../../../lib/infrastructure/utils/date-utils.js'; describe('Unit | Utils | date-utils', function () { describe('#isValidDate', function () { diff --git a/api/tests/unit/infrastructure/utils/dependency-injection_test.js b/api/tests/unit/infrastructure/utils/dependency-injection_test.js index 610eed7eb77..3412e94238f 100644 --- a/api/tests/unit/infrastructure/utils/dependency-injection_test.js +++ b/api/tests/unit/infrastructure/utils/dependency-injection_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const { injectDependencies } = require('../../../../lib/infrastructure/utils/dependency-injection'); +import { expect } from '../../../test-helper.js'; +import { injectDependencies } from '../../../../lib/infrastructure/utils/dependency-injection.js'; describe('Unit | Utils | #injectDependencies', function () { it('should inject dependencies by name', function () { diff --git a/api/tests/unit/infrastructure/utils/lodash-utils_test.js b/api/tests/unit/infrastructure/utils/lodash-utils_test.js index 0d722f066b1..9bddddac86c 100644 --- a/api/tests/unit/infrastructure/utils/lodash-utils_test.js +++ b/api/tests/unit/infrastructure/utils/lodash-utils_test.js @@ -1,6 +1,6 @@ -const { expect } = require('../../../test-helper'); -const original_lodash = require('lodash'); -const _ = require('../../../../lib/infrastructure/utils/lodash-utils'); +import { expect } from '../../../test-helper.js'; +import original_lodash from 'lodash'; +import { _ } from '../../../../lib/infrastructure/utils/lodash-utils.js'; describe('Unit | Utils | lodash-utils', function () { describe('#scope', function () { diff --git a/api/tests/unit/infrastructure/utils/paginate_test.js b/api/tests/unit/infrastructure/utils/paginate_test.js index 1a00e2efd2f..ede2d290514 100644 --- a/api/tests/unit/infrastructure/utils/paginate_test.js +++ b/api/tests/unit/infrastructure/utils/paginate_test.js @@ -1,5 +1,8 @@ -const { expect } = require('chai'); -const { paginate } = require('../../../../lib/infrastructure/utils/paginate'); +import chai from 'chai'; + +const { expect } = chai; + +import { paginate } from '../../../../lib/infrastructure/utils/paginate.js'; describe('Unit | Utils | paginate', function () { describe('#paginate', function () { diff --git a/api/tests/unit/infrastructure/utils/query-params-utils_test.js b/api/tests/unit/infrastructure/utils/query-params-utils_test.js index aaa45b44b21..74c14068e02 100644 --- a/api/tests/unit/infrastructure/utils/query-params-utils_test.js +++ b/api/tests/unit/infrastructure/utils/query-params-utils_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const { extractParameters } = require('../../../../lib/infrastructure/utils/query-params-utils'); +import { expect } from '../../../test-helper.js'; +import { extractParameters } from '../../../../lib/infrastructure/utils/query-params-utils.js'; describe('Unit | Utils | Query Params Utils', function () { describe('#extractParameters', function () { diff --git a/api/tests/unit/infrastructure/utils/random_test.js b/api/tests/unit/infrastructure/utils/random_test.js index d8fd4fba648..9ced722ffa4 100644 --- a/api/tests/unit/infrastructure/utils/random_test.js +++ b/api/tests/unit/infrastructure/utils/random_test.js @@ -1,6 +1,9 @@ -const { expect } = require('../../../test-helper'); -const { range, countBy } = require('lodash'); -const pseudoRandom = require('../../../../lib/infrastructure/utils/pseudo-random'); +import { expect } from '../../../test-helper.js'; +import lodash from 'lodash'; + +const { range, countBy } = lodash; + +import * as pseudoRandom from '../../../../lib/infrastructure/utils/pseudo-random.js'; describe('Unit | Infrastructure | Utils | Random', function () { describe('#binaryTreeRandom', function () { diff --git a/api/tests/unit/infrastructure/utils/request-response-utils_test.js b/api/tests/unit/infrastructure/utils/request-response-utils_test.js index de9b8d3cf3a..210c0537b9b 100644 --- a/api/tests/unit/infrastructure/utils/request-response-utils_test.js +++ b/api/tests/unit/infrastructure/utils/request-response-utils_test.js @@ -1,10 +1,12 @@ -const { expect, generateValidRequestAuthorizationHeader } = require('../../../test-helper'); -const { +import { expect, generateValidRequestAuthorizationHeader } from '../../../test-helper.js'; +import { escapeFileName, extractUserIdFromRequest, extractLocaleFromRequest, -} = require('../../../../lib/infrastructure/utils/request-response-utils'); -const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = require('../../../../lib/domain/constants').LOCALE; +} from '../../../../lib/infrastructure/utils/request-response-utils.js'; +import { LOCALE } from '../../../../lib/domain/constants.js'; + +const { ENGLISH_SPOKEN, FRENCH_FRANCE, FRENCH_SPOKEN } = LOCALE; describe('Unit | Utils | Request Utils', function () { describe('#extractUserIdFromRequest', function () { diff --git a/api/tests/unit/infrastructure/utils/string-utils_test.js b/api/tests/unit/infrastructure/utils/string-utils_test.js index 59fc3261296..d67bd85dce2 100644 --- a/api/tests/unit/infrastructure/utils/string-utils_test.js +++ b/api/tests/unit/infrastructure/utils/string-utils_test.js @@ -1,5 +1,6 @@ -const { expect } = require('../../../test-helper'); -const { +import { expect } from '../../../test-helper.js'; + +import { isNumeric, cleanStringAndParseFloat, getArrayOfStrings, @@ -7,7 +8,7 @@ const { normalizeAndSortChars, normalize, toArrayOfFixedLengthStringsConservingWords, -} = require('../../../../lib/infrastructure/utils/string-utils'); +} from '../../../../lib/infrastructure/utils/string-utils.js'; describe('Unit | Utils | string-utils', function () { const zeroWidthSpaceChar = '​'; diff --git a/api/tests/unit/infrastructure/utils/url-builder_test.js b/api/tests/unit/infrastructure/utils/url-builder_test.js index 3034adb9a1b..8e933481798 100644 --- a/api/tests/unit/infrastructure/utils/url-builder_test.js +++ b/api/tests/unit/infrastructure/utils/url-builder_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const { getCampaignUrl } = require('../../../../lib/infrastructure/utils/url-builder'); +import { expect } from '../../../test-helper.js'; +import { getCampaignUrl } from '../../../../lib/infrastructure/utils/url-builder.js'; describe('Unit | Utils | url-builder', function () { describe('#getCampaignUrl', function () { diff --git a/api/tests/unit/scripts/add-tags-to-organizations_test.js b/api/tests/unit/scripts/add-tags-to-organizations_test.js index f6ce5db1b3f..33355e7e3d9 100644 --- a/api/tests/unit/scripts/add-tags-to-organizations_test.js +++ b/api/tests/unit/scripts/add-tags-to-organizations_test.js @@ -1,6 +1,6 @@ -const { expect, sinon } = require('../../test-helper'); -const { addTagsToOrganizations } = require('../../../scripts/add-tags-to-organizations'); -const Tag = require('../../../lib/domain/models/Tag'); +import { expect, sinon } from '../../test-helper.js'; +import { addTagsToOrganizations } from '../../../scripts/add-tags-to-organizations.js'; +import { Tag } from '../../../lib/domain/models/Tag.js'; describe('Unit | Scripts | add-tags-to-organizations.js', function () { context('When tag already exists for an organization', function () { diff --git a/api/tests/unit/scripts/compare-pix-with-latest-release_test.js b/api/tests/unit/scripts/compare-pix-with-latest-release_test.js deleted file mode 100644 index 2bdb7ba3215..00000000000 --- a/api/tests/unit/scripts/compare-pix-with-latest-release_test.js +++ /dev/null @@ -1,145 +0,0 @@ -const { expect, sinon } = require('../../test-helper'); -const { - getUserValidatedKnowledgeElements, - getTubeByIds, - getUserSkillsGroupedByTubeId, - getHardestSkillByTubeId, - compareUserScoreWithLatestRelease, -} = require('../../../scripts/compare-pix-with-latest-release'); -const knowledgeElementRepository = require('../../../lib/infrastructure/repositories/knowledge-element-repository'); -const tubeRepository = require('../../../lib/infrastructure/repositories/tube-repository'); -const skillRepository = require('../../../lib/infrastructure/repositories/skill-repository'); - -// mock datas -const KnowledgeElement = require('../../../lib/domain/models/KnowledgeElement'); -const Tube = require('../../../lib/domain/models/Tube'); -const Skill = require('../../../lib/domain/models/Skill'); - -const skill1 = new Skill({ - id: 'skill1', - name: '@info1', - tubeId: 'tube1', - tutorialIds: [], - pixValue: 10, - competenceId: 'comp1', - difficulty: 1, -}); -const skill2 = new Skill({ - id: 'skill2', - name: '@info2', - tubeId: 'tube1', - tutorialIds: [], - pixValue: 10, - competenceId: 'comp1', - difficulty: 2, -}); -const skill3 = new Skill({ - id: 'skill3', - name: '@hack3', - tubeId: 'tube2', - tutorialIds: [], - pixValue: 10, - competenceId: 'comp1', - difficulty: 3, -}); - -// additionnal 'active' skill which level is beyond user level -// should not be retained for calculating today score -const skill4 = new Skill({ - id: 'skill4', - name: '@info3', - tubeId: 'tube1', - tutorialIds: [], - pixValue: 10, - competenceId: 'comp1', - difficulty: 3, -}); - -const activeSkills = [skill1, skill2, skill3, skill4]; -const skills = [skill1, skill2, skill3]; - -const tube1 = new Tube({ id: 'tube1', skills: [skill1, skill2] }); -const tube2 = new Tube({ id: 'tube2', skills: [skill3] }); -const tubes = [tube1, tube2]; - -const knowledge1 = new KnowledgeElement({ id: 'ke1', status: 'validated', skillId: 'skill1', earnedPix: 5 }); -const knowledge2 = new KnowledgeElement({ id: 'ke2', status: 'validated', skillId: 'skill2', earnedPix: 5 }); -const knowledge3 = new KnowledgeElement({ id: 'ke3', status: 'validated', skillId: 'skill3', earnedPix: 5 }); - -const invalidatedKe = new KnowledgeElement({ id: 'ke3', status: 'invalidated', skillId: 'skill1' }); -const knowledgeElements = [knowledge1, knowledge2, invalidatedKe, knowledge3]; - -describe('Unit | Scripts | compare-pix-with-latest-release.js', function () { - beforeEach(async function () { - // stub repositories - knowledgeElementRepository.findUniqByUserId = sinon.stub().resolves(knowledgeElements); - tubeRepository.get = sinon.stub().callsFake((tubeId) => tubes.find((tube) => tube.id === tubeId)); - skillRepository.get = sinon.stub().callsFake((skillId) => skills.find((skill) => skill.id === skillId)); - skillRepository.findActiveByTubeId = sinon.stub().callsFake((tubeId) => { - const result = activeSkills.filter((skill) => skill.tubeId === tubeId); - return result; - }); - }); - - describe('#getUserValidatedKnowledgeElements', function () { - it('should return validated knowledgeElementsOnly', async function () { - // when - const validated = await getUserValidatedKnowledgeElements(1); - - // then - validated.forEach((current) => { - expect(current.status).to.equal('validated'); - }); - }); - }); - - describe('#getTubeByIds', function () { - it('should return the tube instances by their ids', async function () { - // when - const result = await getTubeByIds(['tube1', 'tube2']); - - // then - expect(tubes).to.deep.equal(result); - }); - }); - - describe('#getUserSkillsGroupedByTubeId', function () { - it('should return the skills associated to the knowledgeElements grouped by their tube ids', async function () { - // when - const validated = await getUserValidatedKnowledgeElements(1); - const result = await getUserSkillsGroupedByTubeId(validated); - - // then - expect(result).to.deep.equal({ - tube1: [skill1, skill2], - tube2: [skill3], - }); - }); - }); - - describe('#getHardestSkillByTubeId', function () { - it('should keep only the hardest skill for each tube', async function () { - // when - const validated = await getUserValidatedKnowledgeElements(1); - const grouped = await getUserSkillsGroupedByTubeId(validated); - const hardest = getHardestSkillByTubeId(grouped); - - // then - expect(hardest).to.deep.equal({ - tube1: skill2, - tube2: skill3, - }); - }); - }); - - describe('#compareUserScoreWithLatestRelease', function () { - it('should be able to calculate the user score according to his knowledge elements', async function () { - // when - const result = await compareUserScoreWithLatestRelease(1); - - // then - expect(result.userScore).to.equal(15); - expect(result.todayScore).to.equal(30); - }); - }); -}); diff --git a/api/tests/unit/scripts/create-certification-center-memberships-from-organization-admins_test.js b/api/tests/unit/scripts/create-certification-center-memberships-from-organization-admins_test.js index f4c4f25ad15..900f4529810 100644 --- a/api/tests/unit/scripts/create-certification-center-memberships-from-organization-admins_test.js +++ b/api/tests/unit/scripts/create-certification-center-memberships-from-organization-admins_test.js @@ -1,8 +1,5 @@ -const { expect } = require('../../test-helper'); - -const { - buildCertificationCenterMemberships, -} = require('../../../scripts/create-certification-center-memberships-from-organization-admins'); +import { expect } from '../../test-helper.js'; +import { buildCertificationCenterMemberships } from '../../../scripts/create-certification-center-memberships-from-organization-admins.js'; describe('Unit | Scripts | create-certification-center-memberships-from-organization-admins.js', function () { describe('#buildCertificationCenterMemberships', function () { diff --git a/api/tests/unit/scripts/create-sco-certification-centers_test.js b/api/tests/unit/scripts/create-sco-certification-centers_test.js index 37d4a0ad6a6..3e0d6b7d5d0 100644 --- a/api/tests/unit/scripts/create-sco-certification-centers_test.js +++ b/api/tests/unit/scripts/create-sco-certification-centers_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../test-helper'); - -const { prepareDataForInsert } = require('../../../scripts/create-sco-certification-centers'); +import { expect } from '../../test-helper.js'; +import { prepareDataForInsert } from '../../../scripts/create-sco-certification-centers.js'; describe('Unit | Scripts | create-sco-certification-centers.js', function () { describe('#prepareDataForInsert', function () { diff --git a/api/tests/unit/scripts/create-users-accounts-for-contest_test.js b/api/tests/unit/scripts/create-users-accounts-for-contest_test.js index ed40deff7d1..12c15aef1d1 100644 --- a/api/tests/unit/scripts/create-users-accounts-for-contest_test.js +++ b/api/tests/unit/scripts/create-users-accounts-for-contest_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../test-helper'); - -const { prepareDataForInsert } = require('../../../scripts/create-users-accounts-for-contest'); +import { expect } from '../../test-helper.js'; +import { prepareDataForInsert } from '../../../scripts/create-users-accounts-for-contest.js'; describe('Unit | Scripts | create-users-accounts-for-contest.js', function () { describe('#prepareDataForInsert', function () { diff --git a/api/tests/unit/scripts/delete-assessment_test.js b/api/tests/unit/scripts/delete-assessment_test.js index 53d51d970f8..3a786f40dae 100644 --- a/api/tests/unit/scripts/delete-assessment_test.js +++ b/api/tests/unit/scripts/delete-assessment_test.js @@ -1,6 +1,5 @@ -const { expect, sinon } = require('../../test-helper'); - -const { ScriptQueryBuilder, AssessmentEraser } = require('../../../scripts/delete-assessment'); +import { expect, sinon } from '../../test-helper.js'; +import { ScriptQueryBuilder, AssessmentEraser } from '../../../scripts/delete-assessment.js'; describe('Delete Assessment Script', function () { describe('ScriptQueryBuilder', function () { diff --git a/api/tests/unit/scripts/delete-user_test.js b/api/tests/unit/scripts/delete-user_test.js index 30c3c978f30..6f6e65a27a6 100644 --- a/api/tests/unit/scripts/delete-user_test.js +++ b/api/tests/unit/scripts/delete-user_test.js @@ -1,6 +1,5 @@ -const { expect, sinon } = require('../../test-helper'); - -const { ScriptQueryBuilder, ClientQueryAdapter, UserEraser } = require('../../../scripts/delete-user'); +import { expect, sinon } from '../../test-helper.js'; +import { ScriptQueryBuilder, ClientQueryAdapter, UserEraser } from '../../../scripts/delete-user.js'; describe('Delete User Script', function () { describe('ScriptQueryBuilder', function () { diff --git a/api/tests/unit/scripts/get-cpf-import-status-from-xml_test.js b/api/tests/unit/scripts/get-cpf-import-status-from-xml_test.js index 5fe67836f6d..13e2fbf8e11 100644 --- a/api/tests/unit/scripts/get-cpf-import-status-from-xml_test.js +++ b/api/tests/unit/scripts/get-cpf-import-status-from-xml_test.js @@ -1,5 +1,7 @@ -const { expect } = require('../../test-helper'); -const { getCpfImportResults } = require('../../../scripts/certification/get-cpf-import-status-from-xml'); +import { expect } from '../../test-helper.js'; +import { getCpfImportResults } from '../../../scripts/certification/get-cpf-import-status-from-xml.js'; +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('UNIT | Scripts | Certification | get-cpf-import-status-from-xml', function () { describe('#getCpfImportResults', function () { diff --git a/api/tests/unit/scripts/get-next-commit-subject_test.js b/api/tests/unit/scripts/get-next-commit-subject_test.js index 7d52f30eb75..d538522913c 100644 --- a/api/tests/unit/scripts/get-next-commit-subject_test.js +++ b/api/tests/unit/scripts/get-next-commit-subject_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../test-helper'); -const getNextCommitSubject = require('../../../scripts/get-next-commit-subject'); +import { expect } from '../../test-helper.js'; +import { getNextCommitSubject } from '../../../scripts/get-next-commit-subject.js'; describe('get-next-commit-subject', function () { const commitSubject = 'Add a user repository'; diff --git a/api/tests/unit/scripts/get-results-certifications-old_test.js b/api/tests/unit/scripts/get-results-certifications-old_test.js index 3d977d5ef7d..ff8d6fe565c 100644 --- a/api/tests/unit/scripts/get-results-certifications-old_test.js +++ b/api/tests/unit/scripts/get-results-certifications-old_test.js @@ -1,12 +1,14 @@ -const { expect } = require('chai'); +import chai from 'chai'; -const { +const { expect } = chai; + +import { parseArgs, toCSVRow, buildRequestObject, findCompetence, HEADERS, -} = require('../../../scripts/certification/get-results-certifications-old'); +} from '../../../scripts/certification/get-results-certifications-old.js'; describe('Get Result Certifications Script OLD', function () { describe('parseArgs', function () { diff --git a/api/tests/unit/scripts/get-results-certifications_test.js b/api/tests/unit/scripts/get-results-certifications_test.js index f4ef9de3c3c..1f161cec91d 100644 --- a/api/tests/unit/scripts/get-results-certifications_test.js +++ b/api/tests/unit/scripts/get-results-certifications_test.js @@ -1,5 +1,8 @@ -const { expect } = require('chai'); -const getResultsCertifications = require('../../../scripts/certification/get-results-certifications'); +import chai from 'chai'; + +const { expect } = chai; + +import * as getResultsCertifications from '../../../scripts/certification/get-results-certifications.js'; describe('Unit | Scripts | get-results-certifications.js', function () { const HEADERS = [ diff --git a/api/tests/unit/scripts/helpers/csvHelpers_test.js b/api/tests/unit/scripts/helpers/csvHelpers_test.js index eaf47d50c6c..2311ac3baf9 100644 --- a/api/tests/unit/scripts/helpers/csvHelpers_test.js +++ b/api/tests/unit/scripts/helpers/csvHelpers_test.js @@ -1,16 +1,19 @@ -const { expect, catchErr } = require('../../../test-helper'); -const { NotFoundError, FileValidationError } = require('../../../../lib/domain/errors'); -const { +import { expect, catchErr } from '../../../test-helper.js'; +import { NotFoundError, FileValidationError } from '../../../../lib/domain/errors.js'; + +import { parseCsv, readCsvFile, parseCsvWithHeader, checkCsvHeader, parseCsvWithHeaderAndRequiredFields, -} = require('../../../../scripts/helpers/csvHelpers'); -const { - batchOrganizationOptionsWithHeader, -} = require('../../../../scripts/create-organizations-with-tags-and-target-profiles'); -const { UnprocessableEntityError } = require('../../../../lib/application/http-errors'); +} from '../../../../scripts/helpers/csvHelpers.js'; + +import { batchOrganizationOptionsWithHeader } from '../../../../scripts/create-organizations-with-tags-and-target-profiles.js'; +import { UnprocessableEntityError } from '../../../../lib/application/http-errors.js'; + +import * as url from 'url'; +const __dirname = url.fileURLToPath(new URL('.', import.meta.url)); describe('Unit | Scripts | Helpers | csvHelpers.js', function () { const notExistFilePath = 'notExist.csv'; diff --git a/api/tests/unit/scripts/helpers/organizations-by-external-id-helper_test.js b/api/tests/unit/scripts/helpers/organizations-by-external-id-helper_test.js index 13fd1b3c544..7be5b379ae3 100644 --- a/api/tests/unit/scripts/helpers/organizations-by-external-id-helper_test.js +++ b/api/tests/unit/scripts/helpers/organizations-by-external-id-helper_test.js @@ -1,10 +1,8 @@ -const { expect, sinon } = require('../../../test-helper'); - -const { +import { expect, sinon } from '../../../test-helper.js'; +import { findOrganizationsByExternalIds, organizeOrganizationsByExternalId, -} = require('../../../../scripts/helpers/organizations-by-external-id-helper'); -const organizationRepository = require('../../../../lib/infrastructure/repositories/organization-repository'); +} from '../../../../scripts/helpers/organizations-by-external-id-helper.js'; describe('Unit | Scripts | organizations-by-external-id-helper.js', function () { describe('#organizeOrganizationsByExternalId', function () { @@ -35,7 +33,9 @@ describe('Unit | Scripts | organizations-by-external-id-helper.js', function () }); describe('#findOrganizationsByExternalIds', function () { - let organizationRepositoryStub; + afterEach(function () { + sinon.restore(); + }); it('should find organizations with given externalIds', async function () { // given @@ -43,16 +43,14 @@ describe('Unit | Scripts | organizations-by-external-id-helper.js', function () { externalId: 'A100', targetProfileIdList: ['1', '2', '999'] }, { externalId: 'B200', targetProfileIdList: ['1', '3', '6'] }, ]; - organizationRepositoryStub = sinon - .stub(organizationRepository, 'findByExternalIdsFetchingIdsOnly') - .withArgs(['A100', 'B200']) - .resolves([]); + const findByExternalIdsFetchingIdsOnlyStub = sinon.stub().withArgs(['A100', 'B200']).resolves([]); + const organizationRepository = { findByExternalIdsFetchingIdsOnly: findByExternalIdsFetchingIdsOnlyStub }; // when - await findOrganizationsByExternalIds({ checkedData }); + await findOrganizationsByExternalIds({ checkedData }, organizationRepository); // then - expect(organizationRepositoryStub).to.have.been.calledOnce; + expect(findByExternalIdsFetchingIdsOnlyStub).to.have.been.calledOnce; }); }); }); diff --git a/api/tests/unit/scripts/import-certification-cpf-cities_test.js b/api/tests/unit/scripts/import-certification-cpf-cities_test.js index 92b25511071..8a6f785e36b 100644 --- a/api/tests/unit/scripts/import-certification-cpf-cities_test.js +++ b/api/tests/unit/scripts/import-certification-cpf-cities_test.js @@ -1,9 +1,8 @@ -const { expect, sinon } = require('../../test-helper'); -const { - buildCities, - getCitiesWithDistricts, -} = require('../../../scripts/certification/import-certification-cpf-cities'); -const { noop } = require('lodash/noop'); +import { expect, sinon } from '../../test-helper.js'; +import { buildCities, getCitiesWithDistricts } from '../../../scripts/certification/import-certification-cpf-cities.js'; +import lodash from 'lodash'; + +const { noop } = lodash; describe('Unit | Scripts | import-certification-cpf-cities.js', function () { beforeEach(function () { diff --git a/api/tests/unit/scripts/import-certification-cpf-countries_test.js b/api/tests/unit/scripts/import-certification-cpf-countries_test.js index 76ce4990f74..1034cf12a5c 100644 --- a/api/tests/unit/scripts/import-certification-cpf-countries_test.js +++ b/api/tests/unit/scripts/import-certification-cpf-countries_test.js @@ -1,9 +1,11 @@ -const { expect, catchErr, sinon } = require('../../test-helper'); -const { +import { expect, catchErr, sinon } from '../../test-helper.js'; +import { buildCountries, checkTransformUnicity, -} = require('../../../scripts/certification/import-certification-cpf-countries'); -const { noop } = require('lodash/noop'); +} from '../../../scripts/certification/import-certification-cpf-countries.js'; +import lodash from 'lodash'; + +const { noop } = lodash; describe('Unit | Scripts | import-certification-cpf-countries.js', function () { beforeEach(function () { diff --git a/api/tests/unit/scripts/update-sco-organizations-with-is-managing-students-to-true_test.js b/api/tests/unit/scripts/update-sco-organizations-with-is-managing-students-to-true_test.js index 3c1fd906ef2..417d672f549 100644 --- a/api/tests/unit/scripts/update-sco-organizations-with-is-managing-students-to-true_test.js +++ b/api/tests/unit/scripts/update-sco-organizations-with-is-managing-students-to-true_test.js @@ -1,9 +1,8 @@ -const { expect, nock } = require('../../test-helper'); - -const { +import { expect, nock } from '../../test-helper.js'; +import { checkData, updateOrganizations, -} = require('../../../scripts/update-sco-organizations-with-is-managing-students-to-true'); +} from '../../../scripts/update-sco-organizations-with-is-managing-students-to-true.js'; describe('Unit | Scripts | update-sco-organizations-with-is-managing-students-to-true.js', function () { describe('#updateOrganizations', function () { diff --git a/api/tests/unit/server/server_test.js b/api/tests/unit/server/server_test.js index 9309ea88cc8..7435f87bfd5 100644 --- a/api/tests/unit/server/server_test.js +++ b/api/tests/unit/server/server_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../test-helper'); - -const createServer = require('../../../server'); +import { expect } from '../../test-helper.js'; +import { createServer } from '../../../server.js'; describe('Unit | Server | server', function () { describe('#createServer', function () { diff --git a/api/tests/unit/tooling/chai-custom-helpers/deep-equal-array_test.js b/api/tests/unit/tooling/chai-custom-helpers/deep-equal-array_test.js index 564fe456818..9a0b720e8b5 100644 --- a/api/tests/unit/tooling/chai-custom-helpers/deep-equal-array_test.js +++ b/api/tests/unit/tooling/chai-custom-helpers/deep-equal-array_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | chai-custom-helpers | deepEqualArray', function () { it('should fail assertion when compared objects are not arrays', function () { diff --git a/api/tests/unit/tooling/chai-custom-helpers/deep-equal-instance-omitting_test.js b/api/tests/unit/tooling/chai-custom-helpers/deep-equal-instance-omitting_test.js index 7d5926929d4..97993d2f17f 100644 --- a/api/tests/unit/tooling/chai-custom-helpers/deep-equal-instance-omitting_test.js +++ b/api/tests/unit/tooling/chai-custom-helpers/deep-equal-instance-omitting_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | chai-custom-helpers | deepEqualInstanceOmitting', function () { it('should fail assertion when both objects are not of the same instance', function () { diff --git a/api/tests/unit/tooling/chai-custom-helpers/deep-equal-instance_test.js b/api/tests/unit/tooling/chai-custom-helpers/deep-equal-instance_test.js index cedf4786407..bf947cf7734 100644 --- a/api/tests/unit/tooling/chai-custom-helpers/deep-equal-instance_test.js +++ b/api/tests/unit/tooling/chai-custom-helpers/deep-equal-instance_test.js @@ -1,4 +1,4 @@ -const { expect, domainBuilder } = require('../../../test-helper'); +import { expect, domainBuilder } from '../../../test-helper.js'; describe('Unit | chai-custom-helpers | deepEqualInstance', function () { it('should fail assertion when both objects are not of the same instance', function () { diff --git a/api/tests/unit/tooling/database-builder/database-buffer_test.js b/api/tests/unit/tooling/database-builder/database-buffer_test.js index fb687998e80..67e841982e9 100644 --- a/api/tests/unit/tooling/database-builder/database-buffer_test.js +++ b/api/tests/unit/tooling/database-builder/database-buffer_test.js @@ -1,5 +1,5 @@ -const { expect } = require('../../../test-helper'); -const databaseBuffer = require('../../../../db/database-builder/database-buffer'); +import { expect } from '../../../test-helper.js'; +import { databaseBuffer } from '../../../../db/database-builder/database-buffer.js'; describe('Unit | Tooling | DatabaseBuilder | database-buffer', function () { afterEach(function () { diff --git a/api/tests/unit/tooling/database-builder/database-builder_test.js b/api/tests/unit/tooling/database-builder/database-builder_test.js index 47d7992a85f..22dbb9abaa6 100644 --- a/api/tests/unit/tooling/database-builder/database-builder_test.js +++ b/api/tests/unit/tooling/database-builder/database-builder_test.js @@ -1,5 +1,5 @@ -const { expect, sinon, catchErr } = require('../../../test-helper'); -const DatabaseBuilder = require('../../../../db/database-builder/database-builder'); +import { expect, sinon, catchErr } from '../../../test-helper.js'; +import { DatabaseBuilder } from '../../../../db/database-builder/database-builder.js'; describe('Unit | Tooling | DatabaseBuilder | database-builder', function () { describe('#clean', function () { diff --git a/api/tests/unit/tooling/http-test-server_test.js b/api/tests/unit/tooling/http-test-server_test.js index 2287c8e3522..bca781298ea 100644 --- a/api/tests/unit/tooling/http-test-server_test.js +++ b/api/tests/unit/tooling/http-test-server_test.js @@ -1,6 +1,5 @@ -const { expect } = require('../../test-helper'); - -const HttpTestServer = require('../../tooling/server/http-test-server'); +import { expect } from '../../test-helper.js'; +import { HttpTestServer } from '../../tooling/server/http-test-server.js'; describe('Unit | Tooling | Http-test-server', function () { describe('#constructor', function () { diff --git a/api/tests/unit/validate_test.js b/api/tests/unit/validate_test.js index af6da09365f..7dfae3fbae1 100644 --- a/api/tests/unit/validate_test.js +++ b/api/tests/unit/validate_test.js @@ -1,9 +1,10 @@ -const { pick } = require('lodash'); +import lodash from 'lodash'; -const { expect, hFake } = require('../test-helper'); -const { BadRequestError } = require('../../lib/application/http-errors'); +const { pick } = lodash; -const { handleFailAction } = require('../../lib/validate'); +import { expect, hFake } from '../test-helper.js'; +import { BadRequestError } from '../../lib/application/http-errors.js'; +import { handleFailAction } from '../../lib/validate.js'; describe('Unit | Validate', function () { let expectedResponse; diff --git a/api/translations/index.js b/api/translations/index.js index 50d2f79703b..e3b542aef46 100644 --- a/api/translations/index.js +++ b/api/translations/index.js @@ -1,4 +1,4 @@ -const fr = require('./fr'); -const en = require('./en'); +import fr from "./fr.json" assert {type:'json'}; +import en from "./en.json" assert {type:'json'}; -module.exports = { fr, en }; +export { fr, en }; diff --git a/api/worker.js b/api/worker.js index 0f38efb18f9..b1bb0be8b3c 100644 --- a/api/worker.js +++ b/api/worker.js @@ -1,16 +1,17 @@ -const dotenv = require('dotenv'); +import * as dotenv from 'dotenv'; dotenv.config(); -const PgBoss = require('pg-boss'); -const _ = require('lodash'); -const config = require('./lib/config'); -const logger = require('./lib/infrastructure/logger'); -const JobQueue = require('./lib/infrastructure/jobs/JobQueue'); -const ParticipationResultCalculationJob = require('./lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob'); -const SendSharedParticipationResultsToPoleEmploiJob = require('./lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob'); -const ParticipationResultCalculationJobHandler = require('./lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler'); -const SendSharedParticipationResultsToPoleEmploiHandler = require('./lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler'); -const scheduleCpfJobs = require('./lib/infrastructure/jobs/cpf-export/schedule-cpf-jobs'); -const MonitoredJobQueue = require('./lib/infrastructure/jobs/monitoring/MonitoredJobQueue'); +import PgBoss from 'pg-boss'; +import _ from 'lodash'; +import { config } from './lib/config.js'; +import { logger } from './lib/infrastructure/logger.js'; +import { JobQueue } from './lib/infrastructure/jobs/JobQueue.js'; +import { ParticipationResultCalculationJob } from './lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJob.js'; +import { SendSharedParticipationResultsToPoleEmploiJob } from './lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiJob.js'; +import { ParticipationResultCalculationJobHandler } from './lib/infrastructure/jobs/campaign-result/ParticipationResultCalculationJobHandler.js'; +import { SendSharedParticipationResultsToPoleEmploiHandler } from './lib/infrastructure/jobs/campaign-result/SendSharedParticipationResultsToPoleEmploiHandler.js'; +import { scheduleCpfJobs } from './lib/infrastructure/jobs/cpf-export/schedule-cpf-jobs.js'; +import { MonitoredJobQueue } from './lib/infrastructure/jobs/monitoring/MonitoredJobQueue.js'; +import * as url from 'url'; async function runJobs() { logger.info('Starting pg-boss'); @@ -37,7 +38,7 @@ async function runJobs() { const monitoredJobQueue = new MonitoredJobQueue(jobQueue); process.on('SIGINT', async () => { await monitoredJobQueue.stop(); - // eslint-disable-next-line node/no-process-exit + // eslint-disable-next-line node/no-process-exit,no-process-exit process.exit(0); }); @@ -50,13 +51,15 @@ async function runJobs() { await scheduleCpfJobs(pgBoss); } const startInWebProcess = process.env.START_JOB_IN_WEB_PROCESS; -const isEntryPointFromOtherFile = require.main.filename !== __filename; +const modulePath = url.fileURLToPath(import.meta.url); +const isEntryPointFromOtherFile = process.argv[1] !== modulePath; + if (!startInWebProcess || (startInWebProcess && isEntryPointFromOtherFile)) { runJobs(); } else { logger.error( 'Worker process is started in the web process. Please unset the START_JOB_IN_WEB_PROCESS environment variable to start a dedicated worker process.' ); - // eslint-disable-next-line node/no-process-exit + // eslint-disable-next-line node/no-process-exit,no-process-exit process.exit(1); } diff --git a/docs/adr/0046-modulariser-le-code-nodejs.md b/docs/adr/0046-modulariser-le-code-nodejs.md new file mode 100644 index 00000000000..6ad321aa597 --- /dev/null +++ b/docs/adr/0046-modulariser-le-code-nodejs.md @@ -0,0 +1,128 @@ +# 46. Modulariser le code NodeJS + +Date : 2023-05-05 + +## État + +Accepté + +## Contexte + +Sur ce projet, nous avons besoin de : + +- répartir le code dans des unités, appelées modules; +- faire collaborer ces modules; +- tester indépendamment et en collaboration ces modules; +- dans un environnement NodeJS. + +Cette décision relève de l'architecture applicative, mais se situe à un niveau plus bas que des patterns tels que +l'architecture en couche, ou l'architecture hexagonale. Elle s'applique aussi bien à l'API qu'aux front-ends. + +Nous examinons uniquement les deux solutions les plus maintenues: CommonJS et ECMA script. +Il existe d'autres solutions : AMD, CJS, CJS2, UMD. + +### Solution n°1 : Modules CommonJS + +**Description** + +Les modules CommonJs ont longtemps constitué [la seule solution native](https://nodejs.org/api/modules.html) depuis la +release originelle de NodeJS, en 2009. +> CommonJS modules are the original way to package JavaScript code for Node.js + +**Avantage(s):** + +- syntaxe connue des développeurs +- syntaxe permissive, permettant de nombreux cas d'usages + +**Inconvénient(s):** + +- cette solution n'étant plus la solution officielle, sa maintenance sera réduite +- le caractère permissif de la syntaxe peut mener à de la complexité inutile + - export + - de nombreuses opérations sont possibles lors de l'export : + - instanciation de singleton + - déstructuration et renommage d'import précédents + +Export CJS + +```js + +module.exports = { + EMPTY_BLANK_AND_NULL, + domainBuilder: require('./tooling/domain-builder/factory'), + testErr: new Error('Fake Error'), +``` + +Export ESM + +```js +export { + EMPTY_BLANK_AND_NULL, + domainBuilder, + testErr, +``` + +- import + - les imports ne sont pas limités en début de fichier, mais n'importe où dans le code, même dans une boucle + - de nombreuses opérations sont possibles lors de l'export : + - déstructuration + - instanciation + +Import CJS + +```js +``` + +Import ESM + +```js +``` + +### Solution n°2 : ECMA script modules + +**Description** + +Les modules ECMA script sont disponibles nativement et leur interface est stable depuis ( +2021)[https://nodejs.org/docs/latest-v14.x/api/esm.html#introduction] +> ECMAScript modules are the official standard format to package JavaScript code for reuse. + +**Avantage(s):** + +- solution utilisée nativement dans les navigateurs +- solution officielle de NodeJS, pour laquelle la majorité des efforts de développement est développée + - dans le coeur NodeJS + - dans les librairies de l'écosystème, par exemple les règles `eslint` +- syntaxe plus stricte + - limitée aux opérations d'export et d'import + - les modules exposés sont immutables, en lecture seule, ce qui impose l'injection de dépendance pour tester un + composant sans ses dépendances +- permet une meilleure complétion lors de l'import dans les IDE +- éviter les erreurs en activant (le mode strict par + défaut)[https://262.ecma-international.org/6.0/#sec-strict-mode-code] + +**Inconvénient(s):** + +- syntaxe moins connue des développeurs +- coût de migration, car elle n'est pas utilisée dans l'API + - migration des imports et exports + - injection de dépendances pour les modules qui sont testés en isolation de leurs dépendances + +## Décision + +Nous avons choisi la solution n°2, à savoir les modules ECMA script, car le support officiel et le caractère strict sont +des avantages déterminants, malgré les coûts de migration. + +## Conséquences + +Migrer le code de l'API des modules CommonJS vers les modules ECMA script. + +Pour cela : + +- utiliser une solution de modification de code (codemod), à savoir la librairie + éprouvée (`jscodeshift`)[https://github.com/facebook/jscodeshift]; +- effectuer des corrections manuelles lorsque la migration automatisée n'est pas judicieuse (volumétrie/complexité). + +Encadrer l'usage des modules ECMA script avec des règles de lint: + +- les imports doivent référencer un fichier existant +- les imports seront majoritairement nommés diff --git a/high-level-tests/e2e/.eslintrc.js b/high-level-tests/e2e/.eslintrc.js index 910c21758d5..95c54288848 100644 --- a/high-level-tests/e2e/.eslintrc.js +++ b/high-level-tests/e2e/.eslintrc.js @@ -3,10 +3,13 @@ module.exports = { root: true, parserOptions: { ecmaVersion: 2017, - sourceType: 'module' + sourceType: "module" }, plugins: [ - 'cypress', + "cypress" + ], + ignorePatterns: [ + "**/cypress/plugins/*.js" ], env: { browser: false, diff --git a/high-level-tests/e2e/cypress/plugins/index.js b/high-level-tests/e2e/cypress/plugins/index.js index 5d44137d23a..59d6c8c0d60 100644 --- a/high-level-tests/e2e/cypress/plugins/index.js +++ b/high-level-tests/e2e/cypress/plugins/index.js @@ -1,6 +1,5 @@ -const { knex } = require('../../../../api/db/knex-database-connection'); -const cucumber = require('cypress-cucumber-preprocessor').default; -const getCompareSnapshotsPlugin = require('cypress-visual-regression/dist/plugin'); +const cucumber = require("cypress-cucumber-preprocessor").default; +const getCompareSnapshotsPlugin = require("cypress-visual-regression/dist/plugin"); const SEQUENCE_RESTART_AT_NUMBER = 10000000; @@ -8,16 +7,17 @@ module.exports = (on, config) => { config.env.AUTH_SECRET = process.env.AUTH_SECRET; getCompareSnapshotsPlugin(on); - on('file:preprocessor', cucumber()); - on('task', { - async 'db:fixture' (data) { - const file = require('../fixtures/' + data + '.json'); + on("file:preprocessor", cucumber()); + on("task", { + async "db:fixture"(data) { + const file = require("../fixtures/" + data + ".json"); + const { knex } = await import("../../../../api/db/knex-database-connection.js"); for (const row of file) { await knex(data).insert(row); } - return knex.raw('SELECT sequence_name FROM information_schema.sequences;') + return knex.raw("SELECT sequence_name FROM information_schema.sequences;") .then((sequenceNameQueryResult) => { const sequenceNames = sequenceNameQueryResult.rows.map((row) => row.sequence_name); @@ -28,10 +28,10 @@ module.exports = (on, config) => { }); }, log(message) { - console.log(message) + console.log(message); - return null - }, + return null; + } }); return config; }; diff --git a/high-level-tests/test-algo/algo.js b/high-level-tests/test-algo/algo.js index 71ef8599b14..b475ea7d393 100644 --- a/high-level-tests/test-algo/algo.js +++ b/high-level-tests/test-algo/algo.js @@ -3,19 +3,10 @@ require('dotenv').config(); const hashInt = require('hash-int'); const fs = require('fs'); const { find, isEmpty } = require('lodash'); -const smartRandom = require('../../api/lib/domain/services/algorithm-methods/smart-random'); -const dataFetcher = require('../../api/lib/domain/services/algorithm-methods/data-fetcher'); -const challengeRepository = require('../../api/lib/infrastructure/repositories/challenge-repository'); -const skillRepository = require('../../api/lib/infrastructure/repositories/skill-repository'); -const campaignRepository = require('../../api/lib/infrastructure/repositories/campaign-repository'); -const improvementService = require('../../api/lib/domain/services/improvement-service'); -const pickChallengeService = require('../../api/lib/domain/services/pick-challenge-service'); -const Answer = require('../../api/lib/domain/models/Answer'); -const AnswerStatus = require('../../api/lib/domain/models/AnswerStatus'); -const KnowledgeElement = require('../../api/lib/domain/models/KnowledgeElement'); -const AlgoResult = require('./AlgoResult'); +const AlgoResult = require('./AlgoResult.js'); -const POSSIBLE_ANSWER_STATUSES = [AnswerStatus.OK, AnswerStatus.KO]; +let campaignRepository; +let Answer; function _readUsersKEFile(path) { if (path) { @@ -27,7 +18,25 @@ function _readUsersKEFile(path) { return [[]]; } -function answerTheChallenge({ challenge, allAnswers, allKnowledgeElements, targetSkills, userId, userResult, userKE }) { +async function answerTheChallenge({ + challenge, + allAnswers, + allKnowledgeElements, + targetSkills, + userId, + userResult, + userKE, +}) { + const AnswerStatus = ( + await import('../../api/lib/domain/models/AnswerStatus.js') + ).AnswerStatus; + const POSSIBLE_ANSWER_STATUSES = [AnswerStatus.OK, AnswerStatus.KO]; + + const KnowledgeElement = ( + await import('../../api/lib/domain/models/KnowledgeElement.js') + ).KnowledgeElement; + Answer = (await import('../../api/lib/domain/models/Answer.js')).Answer; + let result; const isFirstAnswer = !allAnswers.length; switch (userResult) { @@ -49,7 +58,10 @@ function answerTheChallenge({ challenge, allAnswers, allKnowledgeElements, targe case 'KE': { const ke = find(userKE, (ke) => challenge.skill.id === ke.skillId); const status = ke ? ke.status : KnowledgeElement.StatusType.INVALIDATED; - result = status === KnowledgeElement.StatusType.VALIDATED ? AnswerStatus.OK : AnswerStatus.KO; + result = + status === KnowledgeElement.StatusType.VALIDATED + ? AnswerStatus.OK + : AnswerStatus.KO; break; } default: @@ -57,34 +69,42 @@ function answerTheChallenge({ challenge, allAnswers, allKnowledgeElements, targe } const newAnswer = new Answer({ challengeId: challenge.id, result }); - const _getSkillsFilteredByStatus = (knowledgeElements, targetSkills, status) => { + const _getSkillsFilteredByStatus = ( + knowledgeElements, + targetSkills, + status, + ) => { return knowledgeElements .filter((knowledgeElement) => knowledgeElement.status === status) .map((knowledgeElement) => knowledgeElement.skillId) .map((skillId) => targetSkills.find((skill) => skill.id === skillId)); }; - const newKnowledgeElements = KnowledgeElement.createKnowledgeElementsForAnswer({ - answer: newAnswer, - challenge, - previouslyFailedSkills: _getSkillsFilteredByStatus( - allKnowledgeElements, - targetSkills, - KnowledgeElement.StatusType.INVALIDATED, - ), - previouslyValidatedSkills: _getSkillsFilteredByStatus( - allKnowledgeElements, + const newKnowledgeElements = + KnowledgeElement.createKnowledgeElementsForAnswer({ + answer: newAnswer, + challenge, + previouslyFailedSkills: _getSkillsFilteredByStatus( + allKnowledgeElements, + targetSkills, + KnowledgeElement.StatusType.INVALIDATED, + ), + previouslyValidatedSkills: _getSkillsFilteredByStatus( + allKnowledgeElements, + targetSkills, + KnowledgeElement.StatusType.VALIDATED, + ), targetSkills, - KnowledgeElement.StatusType.VALIDATED, - ), - targetSkills, - userId, - }); + userId, + }); return { answerStatus: result, updatedAnswers: [...allAnswers, newAnswer], - updatedKnowledgeElements: [...allKnowledgeElements, ...newKnowledgeElements], + updatedKnowledgeElements: [ + ...allKnowledgeElements, + ...newKnowledgeElements, + ], }; } @@ -97,7 +117,17 @@ async function _getReferentiel({ skillRepository, improvementService, campaignRepository, + dependencies, }) { + let dataFetcher; + if (!dependencies?.dataFetcher) { + dataFetcher = await import( + '../../api/lib/domain/services/algorithm-methods/data-fetcher.js' + ); + } else { + dataFetcher = dependencies.dataFetcher; + } + if (campaignId) { const skills = await campaignRepository.findSkills({ campaignId }); const campaignRepositoryStub = { @@ -118,25 +148,38 @@ async function _getReferentiel({ challengeRepository, knowledgeElementRepository, improvementService, - campaignParticipationRepository: campaignParticipationRepositoryStub, }); return { targetSkills, challenges }; } else { - const { targetSkills, challenges } = await dataFetcher.fetchForCompetenceEvaluations({ - assessment, - answerRepository, - challengeRepository, - knowledgeElementRepository, - skillRepository, - improvementService, - }); + const { targetSkills, challenges } = + await dataFetcher.fetchForCompetenceEvaluations({ + assessment, + answerRepository, + challengeRepository, + knowledgeElementRepository, + skillRepository, + improvementService, + }); return { targetSkills, challenges }; } } -async function _getChallenge({ challenges, targetSkills, assessment, locale, knowledgeElements, allAnswers }) { +async function _getChallenge({ + challenges, + targetSkills, + assessment, + locale, + knowledgeElements, + allAnswers, +}) { + const smartRandom = await import( + '../../api/lib/domain/services/algorithm-methods/smart-random.js' + ); + const pickChallengeService = await import( + '../../api/lib/domain/services/pick-challenge-service.js' + ); const result = smartRandom.getPossibleSkillsForNextChallenge({ knowledgeElements, challenges, @@ -184,25 +227,27 @@ async function proceedAlgo( const algoResult = new AlgoResult(); while (!isAssessmentOver) { - const { challenge, hasAssessmentEnded, estimatedLevel, challengeLevel } = await _getChallenge({ - challenges, - targetSkills, - assessment, - locale, - knowledgeElements, - allAnswers, - }); - algoResult.addEstimatedLevels(estimatedLevel); - if (challenge) { - const { answerStatus, updatedAnswers, updatedKnowledgeElements } = answerTheChallenge({ - challenge, - allAnswers, - userId: assessment.userId, - allKnowledgeElements: knowledgeElements, + const { challenge, hasAssessmentEnded, estimatedLevel, challengeLevel } = + await _getChallenge({ + challenges, targetSkills, - userResult: isEmpty(userKE) ? userResult : 'KE', - userKE, + assessment, + locale, + knowledgeElements, + allAnswers, }); + algoResult.addEstimatedLevels(estimatedLevel); + if (challenge) { + const { answerStatus, updatedAnswers, updatedKnowledgeElements } = + answerTheChallenge({ + challenge, + allAnswers, + userId: assessment.userId, + allKnowledgeElements: knowledgeElements, + targetSkills, + userResult: isEmpty(userKE) ? userResult : 'KE', + userKE, + }); allAnswers = updatedAnswers; knowledgeElements = updatedKnowledgeElements; algoResult.addChallenge(challenge); @@ -218,7 +263,14 @@ async function proceedAlgo( } async function launchTest(argv) { - const { competenceId, campaignId, locale, userResult, usersKEFile, enabledCsvOutput } = argv; + const { + competenceId, + campaignId, + locale, + userResult, + usersKEFile, + enabledCsvOutput, + } = argv; const allAnswers = []; const knowledgeElements = []; @@ -237,7 +289,15 @@ async function launchTest(argv) { }; const usersKE = _readUsersKEFile(usersKEFile); - + const skillRepository = await import( + '../../api/lib/infrastructure/repositories/skill-repository.js' + ); + const challengeRepository = await import( + '../../api/lib/infrastructure/repositories/challenge-repository.js' + ); + const improvementService = await import( + '../../api/lib/domain/services/improvement-service.js' + ); const { challenges, targetSkills } = await _getReferentiel({ assessment, campaignId, @@ -250,7 +310,16 @@ async function launchTest(argv) { }); const proceedUsers = usersKE.map((userKE) => { - return proceedAlgo(challenges, targetSkills, assessment, locale, knowledgeElements, allAnswers, userResult, userKE); + return proceedAlgo( + challenges, + targetSkills, + assessment, + locale, + knowledgeElements, + allAnswers, + userResult, + userKE, + ); }); const algoResults = await Promise.all(proceedUsers); diff --git a/high-level-tests/test-algo/tests/AlgoResult_test.js b/high-level-tests/test-algo/tests/AlgoResult_test.js index b6ad9267791..b6b0bb460fa 100644 --- a/high-level-tests/test-algo/tests/AlgoResult_test.js +++ b/high-level-tests/test-algo/tests/AlgoResult_test.js @@ -1,17 +1,31 @@ +const { beforeEach } = require('mocha'); const { expect, sinon } = require('./test-helpers'); const AlgoResult = require('../AlgoResult'); -const AnswerStatus = require('../../../api/lib/domain/models/AnswerStatus'); -const domainBuilder = require('../../../api/tests/tooling/domain-builder/domain-builder'); const CsvFile = require('../utils/CsvFile'); describe('AlgoResult', () => { + let AnswerStatus; + let domainBuilder; + + beforeEach(async function() { + AnswerStatus = (await import('../../../api/lib/domain/models/AnswerStatus.js')).AnswerStatus; + domainBuilder = (await import( + '../../../api/tests/tooling/domain-builder/domain-builder.js' + )).domainBuilder; + }); describe('#log', () => { it('should return total challenge asked', () => { // given const algoResult = new AlgoResult(); - const challenge1 = domainBuilder.buildChallenge({ id: 'rec1', skill: {} }); - const challenge2 = domainBuilder.buildChallenge({ id: 'rec2', skill: {} }); + const challenge1 = domainBuilder.buildChallenge({ + id: 'rec1', + skill: {}, + }); + const challenge2 = domainBuilder.buildChallenge({ + id: 'rec2', + skill: {}, + }); algoResult.addChallenge(challenge1); algoResult.addChallenge(challenge2); @@ -25,8 +39,14 @@ describe('AlgoResult', () => { it('should return challengeIds asked', () => { // given const algoResult = new AlgoResult(); - const challenge1 = domainBuilder.buildChallenge({ id: 'rec1', skill: {} }); - const challenge2 = domainBuilder.buildChallenge({ id: 'rec2', skill: {} }); + const challenge1 = domainBuilder.buildChallenge({ + id: 'rec1', + skill: {}, + }); + const challenge2 = domainBuilder.buildChallenge({ + id: 'rec2', + skill: {}, + }); algoResult.addChallenge(challenge1); algoResult.addChallenge(challenge2); @@ -57,9 +77,15 @@ describe('AlgoResult', () => { it('should return unique names of the skills', () => { // given const algoResult = new AlgoResult(); - const challenge1 = domainBuilder.buildChallenge({ skill: { name: 'skill1' } }); - const challenge2 = domainBuilder.buildChallenge({ skill: { name: 'skill1' } }); - const challenge3 = domainBuilder.buildChallenge({ skill: { name: 'skill2' } }); + const challenge1 = domainBuilder.buildChallenge({ + skill: { name: 'skill1' }, + }); + const challenge2 = domainBuilder.buildChallenge({ + skill: { name: 'skill1' }, + }); + const challenge3 = domainBuilder.buildChallenge({ + skill: { name: 'skill2' }, + }); algoResult.addChallenge(challenge1); algoResult.addChallenge(challenge2); algoResult.addChallenge(challenge3); @@ -95,7 +121,6 @@ describe('AlgoResult', () => { }); describe('display first answer status', () => { - it('should return N/A if there is no answer status', () => { // given const algoResult = new AlgoResult(); @@ -149,7 +174,6 @@ describe('AlgoResult', () => { expect(log).contains('----- biggest DESC gap: 4'); }); }); - }); describe('#getResults', () => { @@ -158,8 +182,14 @@ describe('AlgoResult', () => { beforeEach(() => { // given const algoResult = new AlgoResult(); - const challenge1 = domainBuilder.buildChallenge({ id: 'rec1', skill: { name: 'skill1' } }); - const challenge2 = domainBuilder.buildChallenge({ id: 'rec2', skill: { name: 'skill2' } }); + const challenge1 = domainBuilder.buildChallenge({ + id: 'rec1', + skill: { name: 'skill1' }, + }); + const challenge2 = domainBuilder.buildChallenge({ + id: 'rec2', + skill: { name: 'skill2' }, + }); algoResult.addChallenge(challenge1); algoResult.addChallenge(challenge2); algoResult.addChallengeLevel(2); @@ -230,8 +260,14 @@ describe('AlgoResult', () => { it('should get results and write it in file', () => { // given const algoResult = new AlgoResult(); - const challenge1 = domainBuilder.buildChallenge({ id: 'rec1', skill: { name: 'skill1' } }); - const challenge2 = domainBuilder.buildChallenge({ id: 'rec2', skill: { name: 'skill2' } }); + const challenge1 = domainBuilder.buildChallenge({ + id: 'rec1', + skill: { name: 'skill1' }, + }); + const challenge2 = domainBuilder.buildChallenge({ + id: 'rec2', + skill: { name: 'skill2' }, + }); algoResult.addChallenge(challenge1); algoResult.addChallenge(challenge2); algoResult.addChallengeLevel(2); @@ -240,7 +276,10 @@ describe('AlgoResult', () => { algoResult.addEstimatedLevels(4); algoResult.addAnswerStatus({ status: 'ko' }); algoResult.addAnswerStatus({ status: 'ok' }); - const csvFileCreateStub = sinon.stub(CsvFile.prototype, '_createAndAddHeadersIfNotExisting'); + const csvFileCreateStub = sinon.stub( + CsvFile.prototype, + '_createAndAddHeadersIfNotExisting', + ); const csvFileAppendStub = sinon.stub(CsvFile.prototype, 'append'); algoResult._id = 'fixed-id'; const testSet = 'test-set'; diff --git a/high-level-tests/test-algo/tests/algo_test.js b/high-level-tests/test-algo/tests/algo_test.js index e8d2be23601..34fba32dffb 100644 --- a/high-level-tests/test-algo/tests/algo_test.js +++ b/high-level-tests/test-algo/tests/algo_test.js @@ -1,20 +1,24 @@ const { expect, sinon } = require('./test-helpers'); -const { answerTheChallenge, _getReferentiel } = require('../algo'); -const DataFetcher = require('../../../api/lib/domain/services/algorithm-methods/data-fetcher'); -const KnowledgeElement = require('../../../api/lib/domain/models/KnowledgeElement'); +const { answerTheChallenge, _getReferentiel } = require('../algo.js'); describe('#answerTheChallenge', () => { let previousAnswers; let previousKE; let newKe; let challenge; + let KnowledgeElement; - beforeEach(() => { + beforeEach(async () => { previousAnswers = [{ id: 1, result: 'ko' }]; previousKE = [{ id: 1 }]; challenge = { id: 'recId' }; newKe = { id: 'KE-id' }; - sinon.stub(KnowledgeElement, 'createKnowledgeElementsForAnswer').returns([newKe]); + KnowledgeElement = ( + await import('../../../api/lib/domain/models/KnowledgeElement.js') + ).KnowledgeElement; + sinon + .stub(KnowledgeElement, 'createKnowledgeElementsForAnswer') + .returns([newKe]); sinon.stub(console, 'log'); }); @@ -22,9 +26,9 @@ describe('#answerTheChallenge', () => { sinon.restore(); }); - it('should return the list of answers with previous answer with the new one', () => { + it('should return the list of answers with previous answer with the new one', async () => { // when - const result = answerTheChallenge({ + const result = await answerTheChallenge({ challenge, allAnswers: previousAnswers, allKnowledgeElements: previousKE, @@ -38,9 +42,9 @@ describe('#answerTheChallenge', () => { expect(result.updatedAnswers[1].challengeId).to.be.equal(challenge.id); }); - it('should return the list of previous KE with the new one', () => { + it('should return the list of previous KE with the new one', async () => { // when - const result = answerTheChallenge({ + const result = await answerTheChallenge({ challenge, allAnswers: previousAnswers, allKnowledgeElements: previousKE, @@ -57,9 +61,9 @@ describe('#answerTheChallenge', () => { describe('when userResult is "ok"', () => { const userResult = 'ok'; - it('should return the list of answers with the new one validated', () => { + it('should return the list of answers with the new one validated', async () => { // when - const result = answerTheChallenge({ + const result = await answerTheChallenge({ challenge, allAnswers: previousAnswers, allKnowledgeElements: previousKE, @@ -81,9 +85,9 @@ describe('#answerTheChallenge', () => { describe('when userResult is "ko"', () => { const userResult = 'ko'; - it('should return the list of answers with the new one invalidated', () => { + it('should return the list of answers with the new one invalidated', async () => { // when - const result = answerTheChallenge({ + const result = await answerTheChallenge({ challenge, allAnswers: previousAnswers, allKnowledgeElements: previousKE, @@ -105,12 +109,12 @@ describe('#answerTheChallenge', () => { describe('when userResult is "random"', () => { const userResult = 'random'; - it('should return the list of answers with some validated and some invalidated', () => { + it('should return the list of answers with some validated and some invalidated', async () => { // when previousAnswers = []; const allResults = []; for (let i = 0; i < 50; i++) { - const result = answerTheChallenge({ + const result = await answerTheChallenge({ challenge, allAnswers: previousAnswers, allKnowledgeElements: previousKE, @@ -130,12 +134,12 @@ describe('#answerTheChallenge', () => { describe('when userResult is first OK then all KO', () => { const userResult = 'firstOKthenKO'; - it('should return the list of answers with the first one validated and the rest invalidated', () => { + it('should return the list of answers with the first one validated and the rest invalidated', async () => { // when const allResults = []; previousAnswers = []; for (let i = 0; i < 10; i++) { - const result = answerTheChallenge({ + const result = await answerTheChallenge({ challenge, allAnswers: previousAnswers, allKnowledgeElements: previousKE, @@ -157,12 +161,12 @@ describe('#answerTheChallenge', () => { describe('when userResult is first K0 then all OK', () => { const userResult = 'firstKOthenOK'; - it('should return the list of answers with the first one invalidated and the rest validated', () => { + it('should return the list of answers with the first one invalidated and the rest validated', async () => { // when const allResults = []; let previousAnswers = []; for (let i = 0; i < 10; i++) { - const result = answerTheChallenge({ + const result = await answerTheChallenge({ challenge, allAnswers: previousAnswers, allKnowledgeElements: previousKE, @@ -201,14 +205,16 @@ describe('#answerTheChallenge', () => { }, { userKE: null, answerStatus: 'ko' }, ].forEach((testCase) => { - it(`should return the list of answers with ${testCase.answerStatus} answers for ${ + it(`should return the list of answers with ${ + testCase.answerStatus + } answers for ${ testCase.userKE ? testCase.userKE.status : 'empty' - } KE`, () => { + } KE`, async () => { // given challenge.skill = { id: 'recPgkHUdzk0HPGt1' }; // when - const result = answerTheChallenge({ + const result = await answerTheChallenge({ challenge, allAnswers: previousAnswers, allKnowledgeElements: [], @@ -244,13 +250,22 @@ describe('#_getReferentiel', () => { findSkills: () => {}, }; - const expectedSkills = [{ id: 'recSkill1' }, { id: 'recSkill2' }, { id: 'recSkill3' }]; - const expectedChallenges = [{ id: 'recChallenge1' }, { id: 'recChallenge2' }, { id: 'recChallenge3' }]; - - sinon.stub(DataFetcher, 'fetchForCampaigns').returns({ - targetSkills: expectedSkills, - challenges: expectedChallenges, - }); + const expectedSkills = [ + { id: 'recSkill1' }, + { id: 'recSkill2' }, + { id: 'recSkill3' }, + ]; + const expectedChallenges = [ + { id: 'recChallenge1' }, + { id: 'recChallenge2' }, + { id: 'recChallenge3' }, + ]; + const DataFetcher = { + fetchForCampaigns: sinon.stub().returns({ + targetSkills: expectedSkills, + challenges: expectedChallenges, + }), + }; // when const result = await _getReferentiel({ @@ -262,6 +277,7 @@ describe('#_getReferentiel', () => { skillRepository, improvementService, campaignRepository, + dependencies: { dataFetcher: DataFetcher }, }); // then @@ -280,13 +296,23 @@ describe('#_getReferentiel', () => { const improvementService = {}; const targetProfileRepository = {}; - const expectedSkills = [{ id: 'recSkill1' }, { id: 'recSkill2' }, { id: 'recSkill3' }]; - const expectedChallenges = [{ id: 'recChallenge1' }, { id: 'recChallenge2' }, { id: 'recChallenge3' }]; - - sinon.stub(DataFetcher, 'fetchForCompetenceEvaluations').returns({ - targetSkills: expectedSkills, - challenges: expectedChallenges, - }); + const expectedSkills = [ + { id: 'recSkill1' }, + { id: 'recSkill2' }, + { id: 'recSkill3' }, + ]; + const expectedChallenges = [ + { id: 'recChallenge1' }, + { id: 'recChallenge2' }, + { id: 'recChallenge3' }, + ]; + + const DataFetcher = { + fetchForCompetenceEvaluations: sinon.stub().returns({ + targetSkills: expectedSkills, + challenges: expectedChallenges, + }), + }; // when const result = await _getReferentiel({ @@ -298,6 +324,7 @@ describe('#_getReferentiel', () => { skillRepository, improvementService, targetProfileRepository, + dependencies: { dataFetcher: DataFetcher }, }); // then diff --git a/ts b/ts new file mode 100644 index 00000000000..406f9fc6124 --- /dev/null +++ b/ts @@ -0,0 +1,38 @@ +usage: git tag [-a | -s | -u ] [-f] [-m | -F ] + [] + or: git tag -d ... + or: git tag -l [-n[]] [--contains ] [--no-contains ] [--points-at ] + [--format=] [--merged ] [--no-merged ] [...] + or: git tag -v [--format=] ... + + -l, --list list tag names + -n[] print lines of each tag message + -d, --delete delete tags + -v, --verify verify tags + +Tag creation options + -a, --annotate annotated tag, needs a message + -m, --message + tag message + -F, --file read message from file + -e, --edit force edit of tag message + -s, --sign annotated and GPG-signed tag + --cleanup how to strip spaces and #comments from message + -u, --local-user + use another key to sign the tag + -f, --force replace the tag if exists + --create-reflog create a reflog + +Tag listing options + --column[=